(目录)
1. 出现问题:[How to resolve "git pull,fatal: unable to access 'https://github.com...': Empty reply from server"
git config --global --unset http.proxy
git config --global --unset https.proxy
2. Git error: unable to create file xxx: Filename too long(使用IDEA 下载git工程出现错误:无法创建文件xxx:文件名太长)
解决方法:
1.鼠标右键进入Git Bash Here
2.找到需要从git远程下载到本地目录的文件,切入到该文件目录下,输入:
git config --global core.longpaths true
# 回车,然后再使用IDEA重新拉取git上的工程即可。
3.提示拉取成功
git同步fork仓库同步upstream仓库
常见问题
开发中,经常要求我们fork一个自己的仓库,然后,在自己仓库中开发,最后,merge到upstream仓库。 但是,由于,upstream仓库可能会被很多人修改,因此,你自己fork的仓库就会落后。 此时,就需要和upstream仓库同步。 注意: 这里是fork仓库和upstream仓库同步,而不是本地仓库和远程仓库同步。 常规开发,仓库一般就有两个:本地仓库和远程仓库 但是,有些稍微大些的项目,会需要你fork一个自己的仓库。 此时,你fork的仓库才相当于远程仓库。 那么,此时你就有了三个仓库: 本地仓库:本地开发 你fork的仓库:相当于远程仓库 upstream仓库:一般只有最后merge的时候才会动
fork仓库同步upstream仓库
第一步,先在本地shell中,查看对应的远程仓库:
git remote -v
结果只显示: 这个是你fork的仓库,你还没有关联upstream仓库。
origin [email protected] (fetch)
origin [email protected] (push)
关联pstream仓库: URL就是你clone upstream仓库时的https地址
git remote add upstream URL
然后再:
git remote -v
出现:
origin [email protected] (fetch)
origin [email protected] (push)
upstream https://github.xxx.git (fetch)
upstream https://github.xxx.git (push)
说明成功关联上了upstream仓库。
此时从upstream仓库垃取最新的更新:
git fetch upstream
然后就会有很多:
dev -> upstream/dev
这个的意思就是说,你已经把upstream仓库的更新拉取到本地了,叫upstream/develop等等 注意: 是本地,你要想更新你fork的仓库,还需要从本地提交到远程:
git merge upstream/develop
这个的意思就把upstream/dev这个分支更新到你origin/dev 当然,如果你想指定某个分支更新到某个分支,你需要先切换本地对应的那个远程仓库的分支:本地xxx–> origin/xxx ,然后:
git merge upstream/xxx
最后注意
最后merge的时候,避免远程和upstream仓库有冲突,不然很恶心的,不让merge。 所以,fork仓库同步upstream仓库,这个操作,应该是你每次准备pull request之前做。如果你先pull request,再操作,就会有冲突,就很恶心喽,需要重新fork了。
标签:fork,同步,仓库,xxx,github,git,upstream From: https://blog.51cto.com/panyujie/6779627