Git教程 git pull 和 git clone的区别

Git教程 git pull 和 git clone的区别.

大家好,又见面了,我是你们的朋友全栈君。

网上看好多人解释pull和clone的区别,说什么pull是更新本地代码,clone是本地从无到有的过程,但有一点没提到,恰好我今天又犯了这个问题,因为我原来都是直接从远程仓库pull,今天突然发现发现pull不能用,clone才生效,我才意识到这个问题。决定记录一下。


使用方法

  • 有权限的仓库 本地无代码
    • git pull
    • git clone
  • 有权限的仓库 本地有代码
    • git pull
  • 无权限的仓库 本地无代码
    • git clone
  • 无权限的仓库 本地有代码
    • 删了重新下

换个说法

  • git pull:必须连接远程仓库才能用。可以用于下载完整代码更新本地代码。
  • git clone:只要你想往本地下远程仓库完整的代码就可以用,不用连接远程仓库(连接了也可以)。 不适用于更新本地代码。

如果只想知道怎么用就不用往下看了,如果想知道原因继续看。


—————————分割线—————————


1 git pull

git pull适用于从用户有权限的仓库下拉代码不管本地有没有代码

因为我平时下拉代码都是直接git pull

1.1 我有权限的仓库

我有权限的仓库指的是我自己的,或者团队中我可以使用的仓库。

要使用git pull首先你要确定已经连接远程仓库。要不然你直接git pull orgin master那Github会问你:“??什么master?哪个master?你就是老子的master吗?”

所以首先要连接远程仓库。

在这里插入图片描述

  1. init初始化空白的本地仓库,里边除了.git啥也没有
  2. 连接远程仓库

1.1.1 本地没代码

在这里插入图片描述
git remote -v用于显示当前本地仓库连接的远程仓库,你可以连接好几个。然后一个仓库是成对存在的,一个上传一个下拉。前边origin我一般称为远程仓库代称,后边的是你的连接方式。

现在显示我连接了一个github的远程仓库取名叫origin。

Git教程 git pull 和 git clone的区别

空白仓库直接使用git pull就可以下拉代码了。

1.1.2 本地有代码

本地有代码是什么情况。

  • 团队合作,一个仓库多人使用
  • 你自己的仓库,你在多台电脑上使用(比如宿舍一个,实验室一个)

为什么要git pull呢?不同电脑上代码版本不一样。所以为了减少工作并且保证代码版本一致,要在每次写代码的时候下拉代码。在写完之后push到远程仓库。画个图解释一下。
在这里插入图片描述
在这里插入图片描述

1.2 我没权限的仓库

没权限的仓库指的是别人的仓库。别人不给权限,你当然不能随意修改人家的代码了。

没权限的仓库不能使用git pull。比如:

今天我像往常一样去下载代码。但是这是我第一次下载别人的代码。
在这里插入图片描述
我像往常一样添加仓库链接,git pull下拉。但是他提示我:

Permission denied (publickey).
fatal: Could not read from remote repository.

Please make sure you have the correct access rightsand the repository exists.

Permission denied是说SSH密钥无法使用,让我确认我是否有权限访问或者这个仓库是不是存在。
仓库确实是存在的。所以肯定是我没有权限。
在这里插入图片描述
解释一下三步操作:

  1. 添加远程仓库,用SSH连接
  2. 从仓库master分支下拉代码
  3. 删除我添加的远程仓库(既然不能用我当然删掉了)

这时候我想起来:SSH只有仓库所有者能用。因为你电脑上配置的SSH和你github上的SSH是一对的,只有你在你电脑上使用你的github仓库才能用SSH。

既然仓库所有者才能用SSH,那我换HTTP不就行了。(此时我还没意识到问题的严重性?)
在这里插入图片描述

  1. 我又添加了https的连接
  2. 第二步我又下拉的仓库

然后他又提示我:

fatal: unable to access ‘https://github.com/hitvoice/DrQA.git/’: OpenSSL SSL_read: Connection was reset, errno 10054

意思还是我无法连接。
这时候我突然意识到了问题?。这好像是人家的仓库哎,我不能使用remote连接远程仓库之后下拉啊。因为如果我能连上的话就意味着我能随意修改人家的代码。所以我肯定不能使用这样的方式pull代码啊!!!

所以得用git clone

2 git clone

git clone适用于本地没有代码,你要下载。

你连不连接远程仓库都可以,有无仓库权限皆可

接上边的说,意识到使用git clone之后,我删除了刚才的HTTPS连接远程仓库,然后直接git clone,代码成功下载下来了???。
在这里插入图片描述

  1. 我删除了上边的https连接远程仓库的方法
  2. git remote -v用于查看你本地仓库都连接了哪些远程仓库,如果连接了会显示仓库代号和连接方式,我这里输出空白,就是没连接任何远程仓库的状态
  3. git clone下载代码成功了。

上边说的是别人的仓库,那如果是我有权限的仓库呢?

新建一个空白的本地仓库。直接用SSH clone能成功,那HTTPS必定成功。不用remote能成功,那用了remote也必定成功。(觉得这些稍微会用github的一般不用解释了,如果实在不明白评论区问我。)
在这里插入图片描述


我是萝莉安。今天又拿出勤时间写博客了。离谱。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/162565.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Java锁的概念「建议收藏」

    Java锁的概念「建议收藏」一:悲观锁在Java中,synchronized和lock锁都是悲观锁。定义:悲观锁认为自己在使用数据的时候一定有别的线程来修改数据,因此在获取数据的时候会先加锁,确保数据不会被别的线程修改二:乐观锁定义:认为自己在使用数据时不会有别的线程修改数据,所以不会添加锁,只是在更新数据的时候去判断之前有没有别的线程更新了这个数据。如果这个数据没有被更新,当前线程将自己修改的数据成功写入。如果数据已经被其他线程更新,则根据不同的实现方式执行不同的操作(例如报错或者自动重试)。乐观锁在Java中.

    2022年7月7日
    22
  • Pycharm远程连接服务器(windows下远程修改服务器代码)[通俗易懂]

    Pycharm远程连接服务器(windows下远程修改服务器代码)[通俗易懂]http://blog.csdn.net/duankaifei/article/details/418986411、写在前面  之前一致用putty,ssh,修改代码,或者本地修改,上传到服务器,各种不爽,现在改用xshell,但是有时候还是不方便感觉,于是自己配置了远程连接pycharm,这样不用总是到代码里修改,直接在windows下pycharm里修改再保存就可以实现同步更新

    2022年8月29日
    3
  • QT QStringList 与 QString 常用方法

    QT QStringList 与 QString 常用方法本文汇集了QString与(QStringList|QByteArray)之间的转换,以及QString、QStringList的一些常用方法。

    2022年4月30日
    48
  • Linux 路由表详解及 route 命令详解

    Linux 路由表详解及 route 命令详解Linux内核的路由表通过route命令查看Linux内核的路由表:[root@VM_139_74_centos~]#routeKernelIProutingtableDestinationGatewayGenmaskFlagsMetricRefUseIfacedefaultgatewa…

    2022年7月18日
    56
  • finsh AJax

    finsh AJax2019独角兽企业重金招聘Python工程师标准>>>…

    2022年5月11日
    33
  • mac idea 2021.5.4 激活码【在线注册码/序列号/破解码】

    mac idea 2021.5.4 激活码【在线注册码/序列号/破解码】,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月18日
    40

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号