這裏以配置github的ssh key爲例:git
設置Git的user name和email:github
$ git config --global user.name "用戶名" $ git config --global user.email "郵箱"
在config後加上 --global
便可全局設置用戶名和郵箱。shell
生成密鑰:
$ ssh-keygen -t rsa -C 「郵箱」
按3個回車,密碼爲空。
而後根據提示連續回車便可在~/.ssh
目錄下獲得id_rsa
和id_rsa.pub
兩個文件,id_rsa.pub
文件裏存放的就是咱們要使用的key。編程
clip < ~/.ssh/id_rsa.pub
ssh -T
git@github.com
若是配置成功,則會顯示: Hi username! You’ve successfully authenticated, but GitHub does not provide shell access.服務器
$ git clone ssh://git@bitbucket.yuneec.com.git
2.這樣你的機器上就有一個repo了。
3.git於svn所不一樣的是git是分佈式的,沒有服務器概念。全部的人的機器上都有一個repo,每次提交都是給本身機器的repo
倉庫初始化:ssh
git init
生成快照並存入項目索引:分佈式
git add .
文件,還有git rm,git mv等等…
項目索引提交:ide
git commit -m "說明"
4.協做編程:
將本地repo於遠程的origin的repo合併,
推送本地更新到遠程:svn
git push origin master
更新遠程更新到本地:post
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」
有的時候,不只github使用ssh key,工做項目或者其餘雲平臺可能也須要使用ssh key來認證,若是每次都覆蓋了原來的id_rsa
文件,那麼以前的認證就會失效。這個問題咱們能夠經過在~/.ssh
目錄下增長config
文件來解決。
下面以配置搜狐雲平臺的ssh key爲例。
git config user.name "用戶名"git config user.email "郵箱"
ssh-keygen -t rsa -f ~/.ssh/id_rsa.sohu -C "email"
上面的id_rsa.sohu
就是咱們指定的文件名,這時~/.ssh
目錄下會多出id_rsa.sohu
和id_rsa.sohu.pub
兩個文件,id_rsa.sohu.pub
裏保存的就是咱們要使用的key。
config
文件
config
文件
若是config
文件不存在,先添加;存在則直接修改
touch ~/.ssh/config
config
文件裏添加以下內容(User
表示你的用戶名)
Host *.cloudscape
.sohu
.com
IdentityFile ~/.ssh/id_rsa.sohu User test
ssh -T git@git.cloudscape
.sohu
.com
成功的話會顯示:
Welcome to
GitLab, username!
至此,本地便成功配置多個ssh key。往後如需添加,則安裝上述配置生成key,並修改config
文件便可。
更新遠程分支到本地:
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分支,並開始開發。