這里以配置github的ssh key為例:
1. 配置git用戶名和郵箱
設(shè)置Git的user name和email:
$ git config --global user.name "用戶名"
$ git config --global user.email "郵箱"
在config后加上--global即可全局設(shè)置用戶名和郵箱栽惶。
2. 生成ssh key
生成密鑰:
$ ssh-keygen -t rsa -C “郵箱”
按3個(gè)回車裸扶,密碼為空。
然后根據(jù)提示連續(xù)回車即可在~/.ssh目錄下得到id_rsa和id_rsa.pub兩個(gè)文件旅掂,id_rsa.pub文件里存放的就是我們要使用的key泽台。
3. 上傳key到github
clip < ~/.ssh/id_rsa.pub
復(fù)制key到剪貼板
登錄github
點(diǎn)擊右上方的Accounting settings圖標(biāo)
選擇 SSH key
點(diǎn)擊 Add SSH key
4. 測試是否配置成功
ssh -T
git@github.com
如果配置成功什荣,則會(huì)顯示: Hi username! You’ve successfully authenticated, but GitHub does not provide shell access.
開始使用github
1.獲取源碼:
$ git clone ssh://git@bitbucket.yuneec.com.git
2.這樣你的機(jī)器上就有一個(gè)repo了。
3.git于svn所不同的是git是分布式的怀酷,沒有服務(wù)器概念稻爬。所有的人的機(jī)器上都有一個(gè)repo,每次提交都是給自己機(jī)器的repo
倉庫初始化:
git init
生成快照并存入項(xiàng)目索引:
git add .
文件,還有g(shù)it rm,git mv等等…
項(xiàng)目索引提交:
git commit -m "說明"
4.協(xié)作編程:
將本地repo于遠(yuǎn)程的origin的repo合并蜕依,
推送本地更新到遠(yuǎn)程:
git push origin master
更新遠(yuǎn)程更新到本地:
git pull origin master
補(bǔ)充:
添加遠(yuǎn)端repo:
$ git remote add upstream git://github.com/pjhyett/github-services.git
重命名遠(yuǎn)端repo:
$ git://github.com/pjhyett/github-services.git為“upstream”
解決本地多個(gè)ssh key問題
有的時(shí)候桅锄,不僅github使用ssh key,工作項(xiàng)目或者其他云平臺(tái)可能也需要使用ssh key來認(rèn)證样眠,如果每次都覆蓋了原來的id_rsa
文件友瘤,那么之前的認(rèn)證就會(huì)失效。這個(gè)問題我們可以通過在~/.ssh目錄下增加config文件來解決檐束。
下面以配置搜狐云平臺(tái)的ssh key為例辫秧。
1. 第一步依然是配置git用戶名和郵箱
git config user.name
"用戶名"git config user.email?"郵箱"
2. 生成ssh key時(shí)同時(shí)指定保存的文件名
ssh-keygen
-t?rsa?-f?~/.ssh/id_rsa.sohu?-C?"email"
上面的id_rsa.sohu
就是我們指定的文件名,這時(shí)~/.ssh目錄下會(huì)多出id_rsa.sohu和id_rsa.sohu.pub兩個(gè)文件被丧,id_rsa.sohu.pub里保存的就是我們要使用的key盟戏。
3. 新增并配置config
文件
添加config
文件
如果config
文件不存在,先添加甥桂;存在則直接修改
touch ~/.ssh/config
在config
文件里添加如下內(nèi)容(User表示你的用戶名)
Host *.cloudscape
.sohu
.com
IdentityFile ~/.ssh/id_rsa.sohu?User test
4. 上傳key到云平臺(tái)后臺(tái)(省略)
5. 測試ssh key是否配置成功
ssh -T git@git.cloudscape
.sohu
.com
成功的話會(huì)顯示:
Welcome to
GitLab, username!
至此柿究,本地便成功配置多個(gè)ssh key。日后如需添加黄选,則安裝上述配置生成key蝇摸,并修改config文件即可。
6.如何clone所有的遠(yuǎn)程分支
更新遠(yuǎn)程分支到本地:?git fetch -p
git branch -a
git一般有很多分支办陷,我們clone到本地的時(shí)候一般都是master分支貌夕,那么如何切換到其他分支呢?主要命令如下:
1. 查看遠(yuǎn)程分支
$ git branch -a
我在mxnet根目錄下運(yùn)行以上命令:
~/mxnet$ git branch-a* master? remotes/origin/HEAD -> origin/master? remotes/origin/master? remotes/origin/nnvm? remotes/origin/piiswrong-patch-1? remotes/origin/v0.9rc1
可以看到懂诗,我們現(xiàn)在在master分支下
2. 查看本地分支
~/mxnet$ git branch
* master
3. 切換分支
$ git checkout -b v0.9rc1 origin/v0.9rc1Branch v0.9rc1set upto track remote branch v0.9rc1from origin.Switchedtoanew branch'v0.9rc1'#已經(jīng)切換到v0.9rc1分支了$ git branch? master* v0.9rc1#切換回master分支$ git checkout masterSwitchedto branch'master'Your branch is up-to-datewith'origin/master'.
解決:(1)
首先蜂嗽,你需要使用$ git clone這個(gè)命令克隆一個(gè)本地庫。
之后它會(huì)自動(dòng)克隆一個(gè)master分支(這個(gè)貌似是必須的)殃恒。
之后不會(huì)克隆任何一個(gè)分支下來的植旧。
假定你需要一個(gè)dev(此處假定遠(yuǎn)程庫中已經(jīng)存在此分支辱揭,也就是你需要克隆的)分支用于開發(fā)的話,你需要在dev分支上開發(fā)病附,就必須創(chuàng)建遠(yuǎn)程origin的dev分支到本地问窃,于是用這個(gè)命令創(chuàng)建本地dev分支:
$ git checkout -b dev origin/dev
再同步下:
$ git pull
這樣就實(shí)現(xiàn)了克隆dev分支。
————————————————————————————
解決:(2)
Gitclone只能clone遠(yuǎn)程庫的master分支完沪,無法clone所有分支域庇,解決辦法如下:
1. 找一個(gè)干凈目錄,假設(shè)是git_work
2. cd git_work
3. git clone http://myrepo.xxx.com/project/.git ,這樣在git_work目錄下得到一個(gè)project子目錄
4. cd project
5. git branch -a覆积,列出所有分支名稱如下:
remotes/origin/dev
remotes/origin/release
6. git checkout -b dev origin/dev听皿,作用是checkout遠(yuǎn)程的dev分支,在本地起名為dev分支宽档,并切換到本地的dev分支
7. git checkout -b release origin/release尉姨,作用參見上一步解釋
8. git checkout dev,切換回dev分支吗冤,并開始開發(fā)又厉。
天行健,君子以自強(qiáng)不息椎瘟;地勢(shì)坤覆致,君子以厚德載物!