Git与远程仓库之间的通讯与协作

GitHub和Gitee支持两种方式同步本地版本库到远程仓库.
“https”和“ssh”

  • 如果使用https方式很简单基本不需要配置就可以使用,但是每次提交代码和下载代码时都需要输入用户名和密码。
  • 如果使用ssh方式就需要客户端先生成一个密钥对,即一个公钥一个私钥。然后还需要把公钥放到githib的服务器上。这两种方式在实际开发中都用应用,所以我们都需要掌握。

一 .关于ssh

1. 什么是ssh?

SSH 为 Secure Shell(安全外壳协议)的缩写,由 IETF 的网络小组(Network Working Group)所制定。SSH 是目前非常可靠,专为远程登录会话和其他网络服务提供安全性的协议。利用 SSH 协议可以有效防止远程管理过程中的信息泄露问题

2. 基于密匙的安全验证

使用ssh协议通信时,推荐使用基于密钥的验证方式

大致工作流程和安全原理:
我们必须再客户端为自己创建一对密匙,并把公用密匙放在需要访问的服务器上。如果你要连接到SSH服务器上,客户端软件就会向服务器发出请求,请求用你的密匙进行安全验证。服务器收到请求之后,先在该服务器上你的主目录下寻找你的公用密匙,然后把它和你发送过来的公用密匙进行比较。如果两个密匙一致,服务器就用公用密匙加密“质询”(challenge)并把它发送给客户端软件。客户端软件收到“质询”之后就可以用你的私人密匙解密再把它发送给服务器。

ssh连接远程仓库

其实就是有仓库加个远程链接地址然后推送到指定分支就行了

跟命令的显示的一致 git remote(远程) add(增加) origin(地址) 地址
方法的话跟人家仓库显示的命令一致
当然其实这里呢,有个问题,我们ssh需要创建密钥对,然后上传到服务器一个公钥才行.
3.ssh创建密钥对并配置公钥到远程仓库

在仓库打开git命令行bash
输入ssh-keygen -t rsa 一路回车即可创建一个密钥对,然后去C/user/.ssh文件夹去看就有俩密钥了
然后就是去github的仓库或者账号里添加公钥进去即可.

参考:
https://gitee.com/help/articles/4181#article-header0
https://gitee.com/help/articles/4191#article-header0

4.推送到远程仓库

如果用的是小乌龟,可以在工作空间右键选择同步->添加远程origin->网络中选择git>usr>bin>ssh.exe,这样就可以使用到我们之前user/.ssh文件夹下生生的密钥对,并且在putty中选择我们的私钥

二 https方式推送

HTTPS方式推送基本和之前的ssh一致,区别呢是原来是需要使用公钥密钥进行验证,现在是需要我们输入远程仓库(github/gitee等)的账号和密码

三 克隆远程仓库到本地

克隆也有两种方式,https/ssh.
不过对于public仓库来说都是一样的,因为不需要账号密码或者密钥对进行验证了
git bash输入
git clone git@gitee.com:xxxx/xxxx.git 即可
或者用小乌龟点同步也行,直接url黏贴下来远程仓库地址即可

四 拉取最新代码

再看一下我们的工作图

如果别人修改了版本库,我们想拿到最新代码可以pull下来(方法是fetch(抓取)
merge匹对)
git pull origin master (前提你添加好了远程仓库地址)


\color{red}{推送和拉取可能产生的冲突问题}
举个栗子
A和B都持有远程仓库的版本1
A在1的基础上修改了库并更新了远程仓库(假设现在远程仓库的版本为2)
B也在1的基础上修改了,这时候他要推送到远程仓库就会出现不成功问题.因为他不是在2的基础上修改,如果我们可以推送的话岂不是覆盖了原来的版本2?覆盖了A做的事情?

再举个栗子
和上面同样的事情,本来都持有仓库1,A更新了自己的仓库到2也推送到了远端,这个时候我们B也修改了自己的代码,这时候我们直接拉取远程仓库必然会失败,因为我们不是在2的基础上修改的内容,如果直接拉取了会覆盖我们B自身的修改.

如何解决冲突呢?
手动合并,选择自己到底要什么版本,可以看码云的方案
https://gitee.com/help/articles/4194
言而总之呢,就是先拉取,肯定会得到错误提示,并且其实已经拉取了新值到我们的冲突文件里,我们需要自己进入文件选择到底我们是要保留啥还是怎么样都行,如果需要pull上去的话,需要先告诉gitee我们已经解决冲突可以上传了操作方法,如果用的小乌龟可以先点击解决冲突确定一下. 如果用的是git bash可以用git add .
eg

git add .
git commit -m "fixed conflicts"
git push origin master`

有时候我们已经提交的代码,但push时候发现打错字了或者意思跟我们想真正表达的意思不同想要换备注,可以执行一下命令

git commit --amend

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,110评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,443评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,474评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,881评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,902评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,698评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,418评论 3 419
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,332评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,796评论 1 316
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,968评论 3 337
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,110评论 1 351
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,792评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,455评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,003评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,130评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,348评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,047评论 2 355