现在的情景是,你已经在本地创建了一个Git仓库后,又想在GitHub创建一个Git仓库,并且让这两个仓库进行远程同步,这样,GitHub上的仓库既可以作为备份,又可以让其他人通过该仓库来协作,真是一举多得。
首先,登陆GitHub,然后,在右上角找到“Create a new repo”按钮,创建一个新的仓库:
在Repository name填入myRepos,其他保持默认设置,点击“Create repository”按钮,就成功地创建了一个新的Git仓库:
目前,在GitHub上的这个myRepos仓库还是空的,GitHub告诉我们,可以从这个仓库克隆出新的仓库,也可以把一个已有的本地仓库与之关联,然后,把本地仓库的内容推送到GitHub仓库。
现在,我们根据GitHub的提示,在本地的myRepos仓库下运行命令:
$git remote add origin https://github.com/zhangchunxing/myRepos.git
添加后,远程库的名字就是origin,这是Git默认的叫法,也可以改成别的,但是origin这个名字一看就知道是远程库。
下一步,就可以把本地库的所有内容推送到远程库上:(如果push出错: src refspec master does not match any
,这是因为本地git库从没提commit过,等于本地仓库目录是空的。你在本地提交一次,再push就好了。)
$ git push -u origin master
Counting objects: 158, done.
Delta compression using up to 4 threads.
Compressing objects: 100% (149/149), done.
Writing objects: 100% (158/158), 98.94 KiB | 0 bytes/s, done.
Total 158 (delta 21), reused 0 (delta 0)
remote: Resolving deltas: 100% (21/21), done.
To https://github.com/zhangchunxing/myRepos.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远程库和我本地的代码库已经关联上了,每次有新的提交都可以随时更新到github上。
不过还有个小问题,就是我们在公司团队协作时,其实项目中有些东西是不需要同步到远程库里的,最基本的我们项目里build文件夹下生成的class是不需要同步到远程库的!
这时候我们可以用git忽略文件,每次提交忽略那些我们不想提交的文件和代码。
在项目根目录下新建文件.gitignore,然后把你要忽略的文件下的内容写在这个文件里。
这时候我们就要利用git先删除被版本控制的目录,然后重新提交,再push到远程库上即可。
$ git rm -r --cached .
$ git add .
$ git commit -m 'update .gitignore'
$ git push
依次执行以上4个git命令即可。