Git学习笔记(二) 远程仓库及分支

添加远程仓库(以GitHub为例)

  所谓的远程仓库,其实就和本地仓库一样,只是我们本地电脑可能会关机什么的。远程仓库的目的就是保证7*24小时开启状态。GitHub是一个很好的公共Git远程仓库(后面会介绍如何自己搭建一个Git服务器),在本笔记开始前请去https://github.com/官网免费注册一个账号。

  1.创建SSH KEY

  在用户主目录下,看看有没有.ssh目录,如果有,再看看这个目录下有没有id_rsaid_rsa.pub这两个文件,如果已经有了,可直接跳到下一步。如果没有,打开Shell(Windows下打开Git Bash),创建SSH Key:

$ ssh-keygen -t rsa -C "zuxingyu@gmail.com" 

promote:~ zuxingyu$ cd .ssh
promote:.ssh zuxingyu$ ls
github_rsa    github_rsa.pub    id_rsa        id_rsa.pub    known_hosts

  在当前用户主目录下找到 .ssh 目录,在这个目录里面有 id_rsa 和 id_rsa.pub 两个文件,这两个就是SSH Key的秘钥对, id_rsa 是私钥,不能泄露出去, id_rsa.pub 是公钥,可以放心地告诉任何人。

  2.添加SSH KEY

  登录GitHub,在自己的用户中心里添加SSH KEY

           

   点击Add SSH key后就能看到所自己添加的Key了。

   为什么GitHub需要SSH Key呢?因为GitHub需要识别出你推送的提交确实是你推送的,而不是别人冒充的,而Git支持SSH协议,所以,GitHub只要知道了你的公钥,就可以确认只有你自己才能推送。

   当然,GitHub允许你添加多个Key。假定你有若干电脑,你一会儿在公司提交,一会儿在家里提交,只要把每台电脑的Key都添加到GitHub,就可以在每台电脑上往GitHub推送了。

最后友情提示,在GitHub上免费托管的Git仓库,任何人都可以看到喔(但只有你自己才能改)。所以,不要把敏感信息放进去。

如果你不想让别人看到Git库,有两个办法,一个是交点保护费,让GitHub把公开的仓库变成私有的,这样别人就看不见了(不可读更不可写)。另一个办法是自己动手,搭一个Git服务器,因为是你自己的Git服务器,所以别人也是看不见的。这个方法我们后面会讲到的,相当简单,公司内部开发必备。

确保你拥有一个GitHub账号后,我们就即将开始远程仓库的学习。

  创建远程仓库

  登录后GitHub后,进入https://github.com/new页面创建资源库:ServerManagementSystem

      

   创建完成后,我们得到了一个空的资源库。

         

  图中GitHub告诉有三种方法去添加库里的内容:1.可以在本地创建空文件夹作为版本库。2.选定一个本地存在的版本库。3.选择其他类型的版本库(如VCS等)

  将本地代码提交到远程仓库中

  在我本地有个项目需要放到这个远程资源库里,但是我本地没有资源库,所以我使用第一种方法来创建我的远程资源库。

  我们看下这里面的命令:

bogon:ServerManagementSystem zuxingyu$ echo "# ServerManagementSystem" >> README.md    // 添加README.md
bogon:ServerManagementSystem zuxingyu$ git add . // 将文件夹中的所有文件add进去
bogon:ServerManagementSystem zuxingyu$ git commit -m "设定框架" // commit到本地库
bogon:ServerManagementSystem zuxingyu$ git remote add origin https://github.com/zuxingyu/ServerManagementSystem.git  // 将本地库与GitHub上的库进行关联
bogon:ServerManagementSystem zuxingyu$ git push -u origin master
Username for 'https://github.com': zuxingyu
Password for 'https://zuxingyu@github.com': 
Counting objects: 277, done.
Delta compression using up to 4 threads.
Compressing objects: 100% (264/264), done.
Writing objects: 100% (277/277), 3.90 MiB | 147.00 KiB/s, done.
Total 277 (delta 22), reused 0 (delta 0)
remote: Resolving deltas: 100% (22/22), done.
To https://github.com/zuxingyu/ServerManagementSystem.git
 * [new branch]      master -> master
Branch master set up to track remote branch master from origin.

  这样我们就能把我们上传的代码push到GitHub的那个远程库中了, git push origin master 意思就是把本地 master 分支的最新修改推送至GitHub,现在,你就拥有了真正的分布式版本库!

  从远程仓库克隆

  在项目库中,复制SSH 

  

promote:src zuxingyu$ git clone git@github.com:zuxingyu/ServerManagementSystem.git
Cloning into 'ServerManagementSystem'...
remote: Counting objects: 277, done.
remote: Compressing objects: 100% (242/242), done.
remote: Total 277 (delta 22), reused 277 (delta 22), pack-reused 0
Receiving objects: 100% (277/277), 3.90 MiB | 451.00 KiB/s, done.
Resolving deltas: 100% (22/22), done.
Checking connectivity... done.

  当然,你也可以使用HTTPS这种方式去克隆库。 

分支管理

  分支就像火影忍者里鸣人的影分身之术一样,和本体没有区别,可以有很多个分身。当某一天分身都消失的时候,本体能够继承分身的所有记忆。

  分支就是这样,一旦合并了,各个分支的代码都会合到一起。

    分支的作用就是自己是个独立的,不会对别人产生影响。你创建了一个属于你自己的分支,别人看不到,还继续在原来的分支上正常工作,而你在自己的分支上干活,想提交就提交,直到开发完毕后,再一次性合并到原来的分支上,这样,既安全,又不影响别人工作。

  Git的分支好处就是不像SVN那些版本控制工具,切换分支很慢。Git切换分支很快,基本做到了秒切。

 创建分支

git checkout -b dev // 创建并检出dev分支 
// 上面命令是一个合并的命令。它可以划分为 
git branch dev // 创建分支dev 
git check out dev // 检出dev
promote:ServerManagementSystem zuxingyu$ git checkout -b dev
Switched to a new branch 'dev'

  如果你想列出所有分支那么可以使用 git branch 命令:

promote:ServerManagementSystem zuxingyu$ git branch
* dev
  master
  test

      注:   *  号代表当前分支。

  提交的话我们就像之前那样正常提交就行了。但是这个提交只会提交到当前版本。

 合并分支

  我们把 dev 分支的工作成果合并到 master 分支上:

  使用 git merge dev 命令

 删除分支

  使用 git branch -d dev 命令

  建议先合并再进行删除。

  

 

posted @ 2016-11-07 15:24  骑头猪逛街  阅读(1403)  评论(0编辑  收藏  举报