Git教程之git pull和git clone的区别(总结分享)
本篇文章给大家带来了Git教程中git pull和git clone的区别相关知识,希望对大家有帮助。
网上看好多人解释pull和clone的区别,说什么pull是更新本地代码,clone是本地从无到有的过程,但有一点没提到,恰好我今天又犯了这个问题,因为我原来都是直接从远程仓库pull,今天突然发现发现pull不能用,clone才生效,我才意识到这个问题。决定记录一下。
1 git pull
git pull适用于从用户有权限的仓库下拉代码,不管本地有没有代码。
因为我平时下拉代码都是直接git pull。
1.1 我有权限的仓库
我有权限的仓库指的是我自己的,或者团队中我可以使用的仓库。
要使用git pull首先你要确定已经连接远程仓库。要不然你直接git pull orgin master那Github会问你:“什么master?哪个master?你就是老子的master吗?”
所以首先要连接远程仓库。
init初始化空白的本地仓库,里边除了.git啥也没有
连接远程仓库
1.1.1 本地没代码
git remote -v用于显示当前本地仓库连接的远程仓库,你可以连接好几个。然后一个仓库是成对存在的,一个上传一个下拉。前边origin我一般称为远程仓库代称,后边的是你的连接方式。
现在显示我连接了一个github的远程仓库取名叫origin。
空白仓库直接使用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密钥无法使用,让我确认我是否有权限访问或者这个仓库是不是存在。
仓库确实是存在的。所以肯定是我没有权限。
解释一下三步操作:
添加远程仓库,用SSH连接
从仓库master分支下拉代码
删除我添加的远程仓库(既然不能用我当然删掉了)
这时候我想起来:SSH只有仓库所有者能用。因为你电脑上配置的SSH和你github上的SSH是一对的,只有你在你电脑上使用你的github仓库才能用SSH。
既然仓库所有者才能用SSH,那我换HTTP不就行了。(此时我还没意识到问题的严重性)
我又添加了https的连接
第二步我又下拉的仓库
然后他又提示我:
fatal: unable to access 'github.com/hitvoice/Dr…': OpenSSL SSL_read: Connection was reset, errno 10054
意思还是我无法连接。
这时候我突然意识到了问题:neutral_face:。这好像是人家的仓库哎,我不能使用remote连接远程仓库之后下拉啊。因为如果我能连上的话就意味着我能随意修改人家的代码。所以我肯定不能使用这样的方式pull代码啊!!!
所以得用git clone
2 git clone
git clone适用于本地没有代码,你要下载。你连不连接远程仓库。有无仓库权限皆可。
接上边的说,意识到使用git clone之后,我删除了刚才的HTTPS连接远程仓库,然后直接git clone,代码成功下载下来了。
我删除了上边的https连接远程仓库的方法
git remote -v用于查看你本地仓库都连接了哪些远程仓库,如果连接了会显示仓库代号和连接方式,我这里输出空白,就是没连接任何远程仓库的状态
git clone下载代码成功了。
上边说的是别人的仓库,那如果是我有权限的仓库呢?
新建一个本地仓库。很明显是成功的。SSH能成功,那HTTPS必定成功。不用remote能成功,那用了remote也必定成功。
推荐学习:《Git教程》
以上是Git教程之git pull和git clone的区别(总结分享)的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

更新 git 代码的步骤:检出代码:git clone https://github.com/username/repo.git获取最新更改:git fetch合并更改:git merge origin/master推送更改(可选):git push origin master

要通过 Git 下载项目到本地,请按以下步骤操作:安装 Git。导航到项目目录。使用以下命令克隆远程存储库:git clone https://github.com/username/repository-name.git

Git 代码合并过程:拉取最新更改以避免冲突。切换到要合并的分支。发起合并,指定要合并的分支。解决合并冲突(如有)。暂存和提交合并,提供提交消息。

解决 Git 下载速度慢时可采取以下步骤:检查网络连接,尝试切换连接方式。优化 Git 配置:增加 POST 缓冲区大小(git config --global http.postBuffer 524288000)、降低低速限制(git config --global http.lowSpeedLimit 1000)。使用 Git 代理(如 git-proxy 或 git-lfs-proxy)。尝试使用不同的 Git 客户端(如 Sourcetree 或 Github Desktop)。检查防火

在开发一个电商网站时,我遇到了一个棘手的问题:如何在大量商品数据中实现高效的搜索功能?传统的数据库搜索效率低下,用户体验不佳。经过一番研究,我发现了Typesense这个搜索引擎,并通过其官方PHP客户端typesense/typesense-php解决了这个问题,大大提升了搜索性能。

Git Commit 是一种命令,将文件变更记录到 Git 存储库中,以保存项目当前状态的快照。使用方法如下:添加变更到暂存区域编写简洁且信息丰富的提交消息保存并退出提交消息以完成提交可选:为提交添加签名使用 git log 查看提交内容

如何更新本地 Git 代码?用 git fetch 从远程仓库拉取最新更改。用 git merge origin/<远程分支名称> 将远程变更合并到本地分支。解决因合并产生的冲突。用 git commit -m "Merge branch <远程分支名称>" 提交合并更改,应用更新。

要删除 Git 仓库,请执行以下步骤:确认要删除的仓库。本地删除仓库:使用 rm -rf 命令删除其文件夹。远程删除仓库:导航到仓库设置,找到“删除仓库”选项,确认操作。
