美文网首页
Git与远程仓库之间的通讯与协作

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

作者: 名字是乱打的 | 来源:发表于2020-02-24 18:05 被阅读0次

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

相关文章

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

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

  • Git 入门到放弃

    简介 git关联远程仓库 本地仓库与远程仓库同步问题 Git 终端命令 git关联远程仓库 基本流程 注册gith...

  • git远程操作: git push, git fetch, gi

      工作中使用git来管理项目的小伙伴是不是会频繁地使用git的远程操作,下面是我对git在本地仓库与远程仓库之间...

  • 学习如何使用git

    学习如何使用git git的初始设置 git仓库的ssh密钥 远程仓库的设置 远程仓库与本地仓库的同步(参考了这篇...

  • Git 基础 - 远程仓库的使用

    Git 基础 - 远程仓库的使用 远程仓库的使用 为了能在任意 Git 项目上协作,你需要知道如何管理自己的远程仓...

  • git-远程仓库使用

    git远程仓库使用 官方文档 要参与任何一个 Git 项目的协作,必须要了解该如何管理远程仓库。远程仓库是指托管在...

  • Git 命令

    将目录转化为Git仓库 添加文件到Git仓库 查看状态 版本回退 撤销修改 远程仓库 分支 多人协作

  • [git] git拉取远程仓库,同步远程分支,解决冲突

    [git] git拉取远程仓库,同步远程分支,解决冲突 1.本地仓库存在 本地仓库与远程master已绑定 1.拉...

  • Git概览

    Git到底是个什么鬼?远程仓库又是个什么鬼?本地Git仓库与远程仓库有什么区别? Git到底是个什么鬼? Git不...

  • Git使用手册2 —— 基础操作(下)

    五、远程仓库的使用 为了能在任意 Git 项目上协作,你需要知道如何管理自己的远程仓库。 远程仓库是指托管在因特网...

网友评论

      本文标题:Git与远程仓库之间的通讯与协作

      本文链接:https://www.haomeiwen.com/subject/ouabqhtx.html