Git - 生成ssh key步驟以及如何clone所有的遠程分支


 

這里以配置github的ssh key為例:

1. 配置git用戶名和郵箱

設置Git的user name和email:

$ git config --global user.name "用戶名"
$ git config --global user.email "郵箱"

 

在config后加上 --global 即可全局設置用戶名和郵箱。

2. 生成ssh key

生成密鑰:
$ ssh-keygen -t rsa -C “郵箱”
按3個回車,密碼為空。

 

 

然后根據提示連續回車即可在~/.ssh目錄下得到id_rsaid_rsa.pub兩個文件,id_rsa.pub文件里存放的就是我們要使用的key。

3. 上傳key到github

clip < ~/.ssh/id_rsa.pub

 

  1. 復制key到剪貼板
  • 登錄github
  • 點擊右上方的Accounting settings圖標
  • 選擇 SSH key
  • 點擊 Add SSH key

4. 測試是否配置成功

ssh -T
git@github.com

 

如果配置成功,則會顯示: Hi username! You’ve successfully authenticated, but GitHub does not provide shell access.

 

 開始使用github

1.獲取源碼:

$ git clone ssh://git@bitbucket.yuneec.com.git

 

2.這樣你的機器上就有一個repo了。
3.git於svn所不同的是git是分布式的,沒有服務器概念。所有的人的機器上都有一個repo,每次提交都是給自己機器的repo
倉庫初始化:

git init

 

生成快照並存入項目索引:

git add .

 

文件,還有git rm,git mv等等…
項目索引提交:

git commit -m "說明"

 

4.協作編程:
將本地repo於遠程的origin的repo合並,
推送本地更新到遠程:

git push origin master

 

更新遠程更新到本地:

git pull origin master

 

補充:
添加遠端repo:

$ git remote add upstream git://github.com/pjhyett/github-services.git

 

重命名遠端repo:

$ git://github.com/pjhyett/github-services.git為“upstream”

 

 
 

解決本地多個ssh key問題

有的時候,不僅github使用ssh key,工作項目或者其他雲平台可能也需要使用ssh key來認證,如果每次都覆蓋了原來的id_rsa

文件,那么之前的認證就會失效。這個問題我們可以通過在~/.ssh目錄下增加config文件來解決。

下面以配置搜狐雲平台的ssh key為例。

1. 第一步依然是配置git用戶名和郵箱

git config user.name
"用戶名"git config user.email "郵箱"

 

2. 生成ssh key時同時指定保存的文件名

ssh-keygen -t rsa -f ~/.ssh/id_rsa.sohu -C "email"

 

上面的id_rsa.sohu

就是我們指定的文件名,這時~/.ssh目錄下會多出id_rsa.sohuid_rsa.sohu.pub兩個文件,id_rsa.sohu.pub里保存的就是我們要使用的key。

3. 新增並配置config

文件

添加config

文件

如果config

文件不存在,先添加;存在則直接修改

touch ~/.ssh/config

 

config

文件里添加如下內容(User表示你的用戶名)

Host *.cloudscape
.sohu

.com

IdentityFile ~/.ssh/id_rsa.sohu User test

 

4. 上傳key到雲平台后台(省略)

5. 測試ssh key是否配置成功

ssh -T git@git.cloudscape
.sohu

.com

 

成功的話會顯示:

Welcome to
GitLab, username!

 

至此,本地便成功配置多個ssh key。日后如需添加,則安裝上述配置生成key,並修改config文件即可。

 

 

6.如何clone所有的遠程分支

更新遠程分支到本地:

git fetch -p

git branch -a

 

git一般有很多分支,我們clone到本地的時候一般都是master分支,那么如何切換到其他分支呢?主要命令如下:

1. 查看遠程分支

$ git branch -a 

 


我在mxnet根目錄下運行以上命令:

~/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

 

可以看到,我們現在在master分支下

2. 查看本地分支

~/mxnet$ git branch
* master

 

3. 切換分支

$ git checkout -b v0.9rc1 origin/v0.9rc1
Branch v0.9rc1 set up to track remote branch v0.9rc1 from origin.
Switched to a new branch 'v0.9rc1'

#已經切換到v0.9rc1分支了
$ git branch
  master
* v0.9rc1

#切換回master分支
$ git checkout master
Switched to branch 'master'
Your branch is up-to-date with 'origin/master'.

 

 

 

解決沖突:

解決:(1)

首先,你需要使用$ git clone這個命令克隆一個本地庫。
之后它會自動克隆一個master分支(這個貌似是必須的)。
之后不會克隆任何一個分支下來的。
假定你需要一個dev(此處假定遠程庫中已經存在此分支,也就是你需要克隆的)分支用於開發的話,你需要在dev分支上開發,就必須創建遠程origin的dev分支到本地,於是用這個命令創建本地dev分支:

$ git checkout -b dev origin/dev


再同步下:

$ git pull


這樣就實現了克隆dev分支。
————————————————————————————

 

 

解決:(2)

Git clone只能clone遠程庫的master分支,無法clone所有分支,解決辦法如下:

1. 找一個干凈目錄,假設是git_work
2. cd git_work
3. git clone http://myrepo.xxx.com/project/.git ,這樣在git_work目錄下得到一個project子目錄
4. cd project
5. git branch -a,列出所有分支名稱如下:
remotes/origin/dev
remotes/origin/release
6. git checkout -b dev origin/dev,作用是checkout遠程的dev分支,在本地起名為dev分支,並切換到本地的dev分支
7. git checkout -b release origin/release,作用參見上一步解釋
8. git checkout dev,切換回dev分支,並開始開發。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM