同步到远程库
现在我们已经有了一个本地的git管理的项目。git是一个分布式项目管理系统,每一份项目文件中都包含该项目的几乎所有文件,所以其实任何参与项目的人都可以做服务器。现在比较流行的git项目托管网站是GitHub,这里就用GitHub来说明。
首先需要注册一个GitHub账号,然后新建一个git仓库。
按照上图完成后,我们已经有了一个空的远程仓库,现在要做的工作是把本地的项目同远程的仓库联系起来。
在本地执行下面的命令即可:
$ git remote add origin https://github.com/mwanggh/myFirstGit.git
$
没有提示就是好提示。注意把上面的地址换成你的地址,不然的话你就添加了我的仓库,而你并没有权限推送更改给我的仓库。
其中origin
是一个可以根据自己喜好更改的远程库的名字,origin
是默认的名字。
接下来,把我们本地的更改推送到远程仓库:
$ git push -u origin master
Username for 'https://github.com': [email protected]
Password for 'https://[email protected]@github.com':
Counting objects: 29, done.
Compressing objects: 100% (22/22), done.
Writing objects: 100% (29/29), 2.65 KiB | 0 bytes/s, done.
Total 29 (delta 4), reused 0 (delta 0)
remote: Resolving deltas: 100% (4/4), done.
To https://github.com/mwanggh/myFirstGit.git
* [new branch] master -> master
Branch master set up to track remote branch master from origin.
-u
选项使本地的master
分支与远程库的master
分支关联起来,推送(push)需要用户名和密码,然后是推送信息,推送完之后git提示我们本地的master
分支已经与远程的master
分支关联起来了。
现在到GitHub该项目的页面去看,发现本地项目已经被推送到GitHub了:
现在让我们更改一下README.md
文件,并且提交:
$ cat README.md
# Hi, Git!
This is my first git project and i use it to learn git.
Git is a free and open source distributed version control system.
Git is very easy to learn.
Git is very fast and convenient.
$ git commit -a -m "make README.md more friendly."
[master beac1f4] make README.md more friendly.
1 file changed, 6 insertions(+), 4 deletions(-)
现在让我们推送到GitHub:
$ git push origin master
Username for 'https://github.com': [email protected]
Password for 'https://[email protected]@github.com':
Counting objects: 3, done.
Compressing objects: 100% (3/3), done.
Writing objects: 100% (3/3), 416 bytes | 0 bytes/s, done.
Total 3 (delta 0), reused 0 (delta 0)
To https://github.com/mwanggh/myFirstGit.git
14bd627..beac1f4 master -> master
现在快去GitHub项目主页看看推送成功了没有!
这里使用的是https://
协议,GitHub还支持SSH、git://
等协议。
从远程库拉取
我们刚刚将本地的master
推送到远程的origin
,现在本地和远程的都是最新的、一样的文件,让我们看看文件的内容:
$ cat README.md
# Hi, Git!
This is my first git project and i use it to learn git.
Git is a free and open source distributed version control system.
Git is very easy to learn.
Git is very fast and convenient.
现在到GitHub上面去更新一下README.md
文件,在文件末尾添加一行:
GitHub is a Web-based Git version control repository hosting service.
并且提交。在GitHub上的操作如下图:
现在远程的文件比本地的新,我们现在把文件拉取到本地,使用下面的命令:
$ git pull origin master
remote: Counting objects: 3, done.
remote: Compressing objects: 100% (3/3), done.
remote: Total 3 (delta 1), reused 0 (delta 0), pack-reused 0
Unpacking objects: 100% (3/3), done.
From https://github.com/mwanggh/myFirstGit
* branch master -> FETCH_HEAD
beac1f4..57b75e6 master -> origin/master
Updating beac1f4..57b75e6
Fast-forward
README.md | 2 ++
1 file changed, 2 insertions(+)
$ cat README.md | tail -3
Git is very fast and convenient.
GitHub is a Web-based Git version control repository hosting service.
$ git log --oneline -3
57b75e6 Add GitHub description.
beac1f4 make README.md more friendly.
14bd627 add two wrong line to README.md
可见,远程仓库已经被拉取到了本地,并且做了自动合并。
如果不想做自动合并,而仅仅是拉取,使用下面的命令:
$ git fetch origin master
从远程库克隆仓库
上面的情况是已经有了本地仓库,后来新建的远程仓库。生活中常常遇到的情况是已经有了远程仓库,需要将其克隆到本地,可以使用git clone
命令:
$ git clone https://github.com/mwanggh/myFirstGit.git myFirstGit
末尾的myFirstGit
是本地仓库的名字,可以根据喜好更改。这样远程仓库就会克隆到本地的myFirstGit
仓库中。
查看远程仓库
使用git remote
来查看远程仓库:
$ git remote
origin
$ git remote -v
origin https://github.com/mwanggh/myFirstGit.git (fetch)
origin https://github.com/mwanggh/myFirstGit.git (push)
-v
选项可以查看远程仓库URL。
使用git remote show
显示更多信息,这在一些情况下很有用:
$ git remote show origin
* remote origin
Fetch URL: https://github.com/mwanggh/myFirstGit.git
Push URL: https://github.com/mwanggh/myFirstGit.git
HEAD branch: master
Remote branch:
master tracked
Local branch configured for 'git pull':
master merges with remote master
Local ref configured for 'git push':
master pushes to master (up to date)
重命名或者移除远程仓库
使用git remote rename
重命名远程仓库的简写名,比如现在有一个名叫develop
的远程库需要重命名为beta
,可以使用下面的命令:
$ git remote rename develop beta
如果想要删除一个远程仓库,需使用git remote rm
命令:
$ git remote rm beta