- 添加远程库
现在已经在本地创建了一个Git仓库后,又想在GitHub创建一个Git仓库,并且让这两个仓库进行远程同步,这样,GitHub上的仓库既可以作为备份,又可以让其他人通过该仓库来协作。
首先,登陆GitHub,然后,在右上角找到“Create a new repo”按钮,创建一个新的仓库;
在Repository name填入learngit(本地仓库的名字),其他保持默认设置,点击“Create repository”按钮,就成功地创建了一个新的Git仓库;
目前,在GitHub上的这个新建的learngit仓库还是空的,GitHub告诉我们,可以从这个仓库克隆出新的仓库,也可以把一个已有的本地仓库与之关联,然后,把本地仓库的内容推送到GitHub仓库;
根据GitHub的提示,在本地的learngit仓库下运行命令:
$ git remote add origin git@github.com:pengyang97/learngit.git
下一步,就可以把本地库的所有内容推送到远程库上:
$ git push -u origin master
Enumerating objects: 23, done.
Counting objects: 100% (23/23), done.
Delta compression using up to 4 threads
Compressing objects: 100% (18/18), done.
Writing objects: 100% (23/23), 1.86 KiB | 318.00 KiB/s, done.
Total 23 (delta 6), reused 0 (delta 0), pack-reused 0
remote: Resolving deltas: 100% (6/6), done.
To github.com:pengyang97/learngit.git
* [new branch] master -> master
Branch 'master' set up to track remote branch 'master' from 'origin'.
把本地库的内容推送到远程,用git push命令,实际上是把当前分支master推送到远程。
由于远程库是空的,我们第一次推送master分支时,加上了-u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令。
推送成功后,可以立刻在GitHub页面中看到远程库的内容已经和本地一模一样。
从现在起,只要本地作了提交,就可以通过命令:
$ git push origin master
要关联一个远程库,使用命令git remote add origin git@server-name:path/repo-name.git;
关联后,使用命令git push -u origin master第一次推送master分支的所有内容;
此后,每次本地提交后,只要有必要,就可以使用命令git push origin master推送最新修改;
- 在将本地的仓库push到远程GitHub仓库时,出现了如图所示的问题:
这里提示的信息说是ssh连接超时,找不到远程的仓库。解决的方法参考博文,运行下面这行代码:
$ ssh -T git@github.com
命令运行中按照提示输入yes即可
问题解决,接下来就可以正常的向远程仓库push了!
- 从远程库克隆
这里主要是参考廖雪峰的讲解:git远程库克隆
- 创建与合并分支
主要参考廖雪峰的讲解:创建与合并分支
查看分支:git branch
创建分支:git branch <name>
切换分支:git checkout <name>
或git switch <name>
创建加切换分支:git checkout -b <name>
或git switch -c <name>
合并某分支到当前分支:git merge <name>
删除分支:git branch -d <name>