十一城

跬步千里,小流江海。

Home Linux ML Python Java Thoughts KmKg BookCan Links About

2017-08-01
理解与应用git

• 分类: linux • 标签:

打开github.com,寻找到入站信息,

Joined GitHub on January 17, 2014

已经近四年了。

github分享与开源的精神已经深入人心,愿这个程序员的大家庭越来越好。今天记录一下使用git的相关心得。

git原理

其实可以将git中许多操作与c++中的指针联系在一起。

关键词origin

之前一直不理解git push origin master中的origin的意义,今天特意百度一下,实质这个origin代表的就是远程的仓库,我们在本地的git目录下使用git remote -v命令,可以得到如下信息:

1
2
origin	git@github.com:dzzxjl/Cluster-analysis-platform.git (fetch)
origin git@github.com:dzzxjl/Cluster-analysis-platform.git (push)

可以看到这是一个远程的url,举个不恰当的例子,这里的url我们可以看做一个网站,而提交时的命令git push -u origin master中的master可以看做是一个端口,这样通过二级坐标来定义一个地址。

再次引用知乎的一段话来加深对于origin的理解:

origin指向的是repository,master只是这个repository中默认创建的第一个branch。当你git push的时候因为origin和master都是默认创建的,所以可以这样省略,但是这个是bad practice,因为当你换一个branch再git push的时候,有时候就纠结了。

客户端与github remote建立连接的两种方式

  • https——https方式每次提交都需要输入账号和密码进行认证

  • 基于密钥的SSH连接——SSH方式是在客户端所在的电脑生成密钥,同时把密钥部署到github服务器上,客户端与github服务器通过密钥进行认证。

    如果每次push都要输入账号和密码,原因是使用了https方式push。

如何把https换成ssh方式

通过下面的命令

1
1. git remote rm origin

git remote add origin git@github.com:fety/fety.github.com.git

git push origin

什么是SSH?

Secure Shell(缩写为SSH),由IETF的网络工作小组(Network Working Group)所制定;SSH为一项创建在应用层和传输层基础上的安全协议,为计算机上的Shell(壳层)提供安全的传输和使用环境。

优点:

  • SSH是目前较可靠,专为远程登录会话和其他网络服务提供安全性的协议
  • 利用SSH协议可以有效防止远程管理过程中的信息泄露问题
  • 通过SSH可以对所有传输的数据进行加密,也能够防止DNS欺骗和IP欺骗
  • 其传输的数据可以是经过压缩的,所以可以加快传输的速度

在客户端来看,SSH提供两种级别的安全验证。

第一种级别(基于密码的安全验证),知道帐号和密码,就可以登录到远程主机,并且所有传输的数据都会被加密。但是,可能会有别的服务器在冒充真正的服务器,无法避免被“中间人”攻击。

第二种级别(基于密匙的安全验证),需要依靠密匙,也就是你必须为自己创建一对密匙,并把公有密匙放在需要访问的服务器上。客户端软件会向服务器发出请求,请求用你的密匙进行安全验证。服务器收到请求之后,先在你在该服务器的用户根目录下寻找你的公有密匙,然后把它和你发送过来的公有密匙进行比较。如果两个密匙一致,服务器就用公有密匙加密“质询”(challenge)并把它发送给客户端软件。从而避免被“中间人”攻击。

通过SSH连接github,正是基于第二种级别(基于密钥的安全验证)的验证方式。

github生成SSH密钥步骤,请参考generating-ssh-keys,或者使用Github Pages建独立博客

PR最佳实践

  1. fork 原始仓库
  2. clone 自己的仓库
  3. master 分支添加原始仓库为远程分支 git remote add upstream 远程仓库
  4. 自己分支开发,如 dev 分支开发:git checkout -b dev
  5. 本地 dev 提交
  6. 切换 master 分支,同步原始仓库:git checkout mastergit pull upstream master
  7. 切换本地 dev 分支,合并本地 master 分支(已经和原始仓库同步),可能需要解冲突
  8. 提交本地 dev 分支到自己的远程 dev 仓库
  9. 现在才是给原始仓库发 pull request 请求
  10. 等待原作者回复(接受/拒绝)

dzzxjl

Home Linux ML Python Java Thoughts KmKg BookCan Links About