Git学习:分布式版本控制(二)

分布式版本控制

远程仓库

  Git是分布式版本控制系统,同一个Git仓库,可以分布在不同的机器上。怎么分布呢?实际情况是,找一台电脑24小时开机,其他每个人都从这个服务器仓库克隆一份到自己的电脑上,并且各自把各自的提交推送到服务器仓库里,也从服务器仓库中拉取别人的提交。
  为了学习远程仓库,可以使用GitHub网站,这个网站相信大家都很熟悉了。
步骤如下:
1. 创建SSH Key。
 在用户主目录下,看看有没有.ssh目录。如果有,看看有没有id_rsa和id_ras.pub文件,如果没有,则打开Git Bash,创建SSH Key:
    ssh-keygen -t rsa -C “youremail@example.com”
  一直回车,直到在主目录下看见那两个文件。
2. 登录GitHub。
在如下界面下输入Title和key。
Title里的内容自己随便填写。
key里的内容是SSH Key里的公钥:id_ras.pub里的内容。
这里写图片描述
  这样就添加成功了。
 

添加远程库

  现在的情景是,已经在本地创建了一个Git仓库,又想在GitHub创建一个仓库,并且这两个仓库之间进行远程同步。
  首先在GitHub上创建一个新的仓库。点击“Create anew repo”按钮。然后在本地的git bash上写下如下命令

$ git remote add origin git@github.com:yanghuiysz/learngit.git

  把yanghuiysz换成自己的账户,后边的是自己在GitHub上创建的远程仓库。
  下一步,将本地库的所有内容推送到远程库上去,命令如下:

$ git push -u origin master
接下来就能在GitHub上看见了。

 这里写图片描述

  提示:
  如果出现以下错误:
  这里写图片描述
  原因:远程分支上存在本地分支中不存在的提交,往往是多人协作开发过程中遇到的问题,可以先fetch再merge,也就是pull,把远程分支上的提交合并到本地分支之后再push。
  这里写图片描述
  
  把本地库的内容推送到远程,用git push命令,实际上是把当前分支master推送到远程。由于远程库是空的,我们第一次推送master分支时,加上了-u参数,Git不但会把本地的master分⽀支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令。
  只要本地作了提交,就可以通过命令:$ git push origin master把本地master分支的最新修改推送至GitHub。

从远程库克隆

  假设我们从零开发,那么最好的⽅方式是先创建远程库,然后,从远程库克隆。
  首先,登陆GitHub,创建一个新的仓库,名字叫gitskills。
  创建完成之后,用命令git clone克隆一个本地库:
  这里写图片描述
  如果有多个人协作开发,那么每个人各自从远程克隆一份就可以了。
  GitHub给出的地址不止一个,还可以用https://github.com/yanghuiysz/gitskills.git这样的地址。实际上,Git支持多种协议,默认的git://使用ssh,但也可以用https等其他协议。
  使用https除了速度慢以外,还有个最大的麻烦是每次推送都必须输入口令,但是在某些只开放http端口的公司内部就无法使用ssh协议而只能用https。
  要克隆一个仓库,首先必须知道仓库的地址,然后使用git clone命令克隆。
  Git支持多种协议,包括https,但通过ssh支持的原生git协议速度最快。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值