本文主要介绍了git使用SSH密钥、入门知识、分支管理以及常用命令,掌握了以下内容,你就可以轻松的在工作中使用Git了。
SSH密钥
git使用https协议,每次pull,push都要输入密码,相当麻烦;
使用git协议,然后使用ssh密钥。这样可以省去每次都要输密码。
需要三个步骤:
- 本地生成密钥对;
- 设置github上的公钥;
- 修改git的remote url为git协议。
1、生成密钥
大多数Git服务器都会选择使用SSH公钥来进行授权,没有的话就要生成一个。生成公钥的过程在所有操作系统上都差不多。
首先确认一下是否已经有一个公钥了;
SSH公钥默认储存在账户的主目录下的~/.ssh目录,进去看看:
$ cd ~/.ssh
$ ls
authorized_keys2 id_dsa known_hosts config id_dsa.pub
关键是看有没有用something和something.pub来命名的一对文件,这个something通常就是id_dsa或id_rsa。有.pub后缀的文件就是公钥,另一个文件则是密钥。假如没有这些文件,或者干脆连.ssh目录都没有,可以用ssh-keygen来创建。该程序在Linux/Mac系统上由SSH提供,而在Windows上则包含在MSysGit包里:
$ ssh-keygen -t rsa -C "your_email@youremail.com"
# Creates a new ssh key using the provided email # Generating public/private rsa key pair.
# Enter file in which to save the key (/home/you/.ssh/id_rsa):
直接Enter就行,然后,会提示你输入密码,如下(建议输一个,安全一点,当然不输也行):
Enter passphrase (empty for no passphrase): [Type a passphrase]
# Enter same passphrase again: [Type passphrase again]
完了之后,大概就是这样子:
Your identification has been saved in /home/you/.ssh/id_rsa.
# Your public key has been saved in /home/you/.ssh/id_rsa.pub.
# The key fingerprint is: # 01:0f:f4:3b:ca:85:d6:17:a1:7d:f0:68:9d:f0:a2:db your_email@youremail.com
这样,你本地生成密钥对的工作就做好了。
2、添加公钥到你的github账户
2-1、查看你生成的公钥:大概如下:
$ cat ~/.ssh/id_rsa.pub
ssh-rsa AAAAB3NzaC1yc2EAAAABIwAAAQEAklOUpkDHrfHY17SbrmTIpNLTGK9Tjom/BWDSU GPl+nafzlHDTYW7hdI4yZ5ew18JH4JW9jbhUFrviQzM7xlE
LEVf4h9lFX5QVkbPppSwg0cda3 Pbv7kOdJ/MTyBlWXFCR+HAo3FXRitBqxiX1nKhXpHAZsMciLq8V6RjsNAQwdsdMFvSlVK/7XA t3FaoJoAsncM1Q9x5+3V
0Ww68/eIFmb1zuUFljQJKprrX88XypNDvjYNby6vw/Pb0rwert/En mZ+AW4OZPnTPI89ZPmVMLuayrD2cE86Z/il8b+gw3r3+1nKatmIkjn2so1d01QraTlMqVSsbx NrRFi9wrf+M7Q== schacon@agadorlaptop.local
2-2、登录你的github账户。然后Account Setting ->左栏点击SSH Keys -> 点击 Add SSH key
2-3、然后复制你的公钥内容,粘贴进“Key”文本域内。title域,你随便填一个都行。
2-4、添加完成后,点击Add key即可。
这样,就OK了,然后,验证下这个key是不是正常工作。
$ ssh -T git@github.com
# Attempts to ssh to github
如果看到:
Hi username! You've successfully authenticated, but GitHub does not # provide shell access.
就表示你的设置已经成功了。
3、修改你本地的ssh remote url,不用https协议,改用git协议
确保:
- 你已经init了一个空仓库;
- 你已经把远程git的url添加到了本地git仓库的配置文件
==============================================
可以用git remote -v 查看你当前的remote url
$ git remote -v
origin https://github.com/someaccount/someproject.git (fetch)
origin https://github.com/someaccount/someproject.git (push)
可以看到是使用https协议进行访问的。
你可以使用浏览器登陆你的github,在上面可以看到你的ssh协议相应的url,类似如下:
git@github.com:someaccount/someproject.git
这时,你可以使用git remote set-url来调整你的url。
git remote set-url origin git@github.com:someaccount/someproject.git
完了之后,你便可以再用git remote -v查看一下:
$ git remote -v
origin https://git@github.com:someaccount/someproject.git (fetch)
origin https://git@github.com:someaccount/someproject.git (push)
OK。
至此,你就可以省去输入密码的麻烦,也可以很安全的进行push,pull,fetch,checkout等操作了。
你可以用git fetch,git pull,git push.
[注意]
第一次使用git push之前,需要对git push进行配置:
1、simple方式:
git config --global push.default.simple
2、matching方式:
git config --global push.default.matching
matching means git push will push all your local branches to the ones
with the same name on the remote. This makes it easy to accidentally
push a branch you didn’t intend to.
matching 与simple方式的push的区别是:matching会把你所有本地的分支push到远程仓库中对应匹配的分支。
simple means git push will push only the current branch to the one
that git pull would pull from, and also checks that their names match.
This is a more intuitive behavior, which is why the default is getting
changed to this.
simple方式,只会push你已经从远程仓库pull过的分支,意思是你曾经pull了分支dev,那么当你使用缺省git push时,当前分支为dev,远程分支dev就会收到你的commit。
3、或者使用git push [远程仓库] [本地分支]
入门知识
Git简介
Git是目前世界上最先进的分布式版本控制系统。
1、版本控制
典型代表Word文件的编辑,你的文件夹中是不是有这样的情况:
word20160301.doc
word备份的.doc
word(小王).doc
word-03.doc
word.doc
而某一天,你可能需要以前修改过的版本(因为,经常会遇到这种抽风的上司或者客户)
而由版本控制给你带来的是:
版本 用户 说明 日期
1 张三 删除了软件服务条款5 7/12 10:38
2 张三 增加了License人数限制 7/12 18:09
3 李四 财务部门调整了合同金额 7/13 9:51
4 张三 延长了免费升级周期 7/14 15:17
而且,你想退回到哪里,就可以退回到哪里!
记住第一个关键词:(无尽的)后悔药
2、分布式 VS 集中式
集中式,典型的代表就是SVN,版本库是集中存放在中央服务器的,而干货的时候,用的都是自己的电脑,所以要先从中央服务器取得最新的版本,然后开始干活,干完活了,再把自己的活推送给中央服务器。
分布式,分布式版本控制系统根本没有“中央服务器”,每个人的电脑上都是一个完整的版本库,分布式版本控制系统的安全性要高很多,因为每个人的电脑里都有完整的版本库,某一个人的电脑坏掉了不要紧,随便从其他人那里复制一个就可以了。而集中式版本控制系统的中央服务器要是出了问题,所有人都没法干活了。
Git不单是不必联网这么简单,Git更强大的分支管理,后面讲到~~~~
关于更多SVN&&Git的区别可以参见或百度了解:
SVN和Git在日常使用中的明显差异
记住第二个关键词:分布式
Git环境搭建
安装Git
- 在Linux(Debian)上安装Git:
apt-get install git - Mac OS X 上安装Git:
第一种方法是安装homebrew,然后通过homebrew安装Git,具体方法请参考homebrew的文档:http://brew.sh/。
第二种方法更简单,也是推荐的方法,就是直接从AppStore安装Xcode,Xcode集成了Git,不过默认没有安装,你需要运行Xcode,选择菜单“Xcode”->“preferences”,在弹出窗口中找到“Downloads”,选择“Command Line Tools”,点Install就可以完成安装了。 - 在Windows上安装Git
从这里https://git-for-windows.github.io/下载,双击安装
安装完成后,可以在右键菜单/开始菜单中找到“Git”->Git Bash,蹦出一个类似命令行窗口的东西,就说明Git安装成功!
全局变量设置
就像Java需要设置Path一样,Git需要设置一些全局变量。
“Git”->“Git Bash”
$ git config --global user.name "Your Name"
$ git config --global user.email "email@example.com"
设置用户与Email,相当于自报家门,让版本库有一个记录。注意:git config 命令的–global是全局设置的意思。
任何一个命令或者参考:git [命令] --help来查看帮助,或者登陆官方来学习命令http://git-scm.com/doc
参考资料:Git内部原理-环境变量
创建版本库
1、windows下,需要建立的版本库的地方,右键git bash ->
$ git init
瞬间Git就把仓库建好了,而且告诉你是一个空的仓库(empty Git repository),细心的读者可以发现当前目录下多了一个.git的目录,这个目录是Git来跟踪管理版本库的,没事千万不要手动修改这个目录里面的文件,不然改乱