2017-08-01
理解与应用git
• 分类:
linux
• 标签:
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 | origin git@github.com:dzzxjl/Cluster-analysis-platform.git (fetch) |
可以看到这是一个远程的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最佳实践
fork
原始仓库clone
自己的仓库- 在
master
分支添加原始仓库为远程分支git remote add upstream
远程仓库 - 自己分支开发,如
dev
分支开发:git checkout -b dev
- 本地
dev
提交 - 切换
master
分支,同步原始仓库:git checkout master
,git pull upstream master
- 切换本地
dev
分支,合并本地master
分支(已经和原始仓库同步),可能需要解冲突 - 提交本地
dev
分支到自己的远程dev
仓库 - 现在才是给原始仓库发
pull request
请求 - 等待原作者回复(接受/拒绝)
dzzxjl