同一服務(wù)器,同一托管平臺,多個賬號問題
1、添加key
我們暫且以oschina為例。為了更好的說明問題,我們在oschina平臺分別用賬號111新建項(xiàng)目test111和賬號222新建項(xiàng)目test222,記得項(xiàng)目私有化哦,不然我們也沒啥說的了。
在我們想要把項(xiàng)目test111 clone下來之前,需要先按照下面的步驟設(shè)置關(guān)聯(lián)的key
ssh-keygen -t rsa -C "111@163.com" // 郵箱是賬號111對應(yīng)的郵箱
整個過程就回車完事,操作起來那是相當(dāng)?shù)暮唵危〉沁€沒完,可能你注意到了,回車的過程中,有一句話是這樣提示的:
Your public key has been saved in /root/.ssh/id_rsa.pub.
沒錯,我們現(xiàn)在打開這個文件
cat /root/.ssh/id_rsa.pub
拷貝文件里面的內(nèi)容, 然后打開 http://git.oschina.net/keys 這個頁面,新建key,把復(fù)制的內(nèi)容粘貼進(jìn)來就好了。
這樣一來,我們就把服務(wù)器上面的key跟oschina平臺進(jìn)行了關(guān)聯(lián)。
2、clone項(xiàng)目
接著我們通過git clone命令把test111項(xiàng)目clone下來,記得clone的地址是ssh而不是https哦,這個時候會提示我們輸入用戶名和密碼,其分別是oschina的賬號和密碼。
如果你手賤是以https的方式進(jìn)行clone的,可以通過下面的命令重新設(shè)置遠(yuǎn)程倉庫地址(沒有則可跳過此步驟)
// 移除之前的遠(yuǎn)程倉庫地址 git remote remove origin // 新增遠(yuǎn)程倉庫地址為ssh,非https git remote add origin git@git.oschina.net:wwolf/test111.git
3、多賬號兼容問題
到這里,對于test111項(xiàng)目pull push操作基本上都是沒有問題的了。如果說用戶222想在這臺服務(wù)器上面對項(xiàng)目test222進(jìn)行管理,我們直接執(zhí)行g(shù)it clone git@git.oschina.net:222/test222.git之后,報錯了,提示如下:
Access denied. fatal: Could not read from remote repository. Please make sure you have the correct access rights and the repository exists.
為什么呢?首先最重要的問題肯定是key的問題了!因?yàn)槲覀冎安⑽磳釉谶@臺服務(wù)器增加key關(guān)聯(lián)到用戶222的oschina賬號!那我們就按照步驟1重新在服務(wù)器上為用戶222添加一個key吧,不過需要注意的是,我們的key保存的文件要重命名了,不然可就把用戶111創(chuàng)建的key覆蓋了!
ssh-keygen -t rsa -C "賬號222的郵箱@qq.com" //接下來會提示我們想要把key保存在哪個文件,重新輸入文件名即可 Enter file in which to save the key (/root/.ssh/id_rsa): /root/.ssh/id_rsa_2 //接著回車回車回車完事,重要的話說三遍!
然后我們登錄賬號222的oschina賬號添加key
但是問題出現(xiàn)了,這個時候我們重新clone test222依舊提示我們沒權(quán)限,怎么回事???本篇文章的中心主題曝光了!廢話了一堆,開始說重點(diǎn)--------------------------
其實(shí)這個時候我們clone test222項(xiàng)目時,git是拿默認(rèn)的id_rsa.pub文件里面的key去對比的,這肯定是有問題的嘛,因?yàn)?22賬號并沒有添加這個key!那也就是說我們這里如果clone test222的時候讓git拿著id_rsa_2.pub文件里面的key去驗(yàn)證不就完事了么?是的,就是這樣!我們看實(shí)現(xiàn)步驟:
首先我們讓git識別我們新增的key
ssh-agent bash ssh-add ~/.ssh/id_rsa_2
接著我們在~/.ssh/ 目錄下新建或者修改config文件
#Host 是你遠(yuǎn)程倉庫的地址,注意哦,如果有些服務(wù)器做的ip端口轉(zhuǎn)發(fā),這里不要帶上端口號 Host git.oschina.net #HostName 是遠(yuǎn)程倉庫的地址,同樣如果做的端口轉(zhuǎn)發(fā)也不應(yīng)帶端口號 HostName git.oschina.net #Port 端口號,如果有做轉(zhuǎn)發(fā)需要在這里填寫端口號,沒有就不必要填 #Port 8800 #用戶 User 111 #識別key的文件 IdentityFile ~/.ssh/id_rsa #都指向同一個平臺的話,下面的Host需要做個處理,因?yàn)槲覀冊谟眠@個key的時候根據(jù)Host從上到下進(jìn)行查找,不做修改肯定會先查找到第一個key,依舊無效,隨便改就好了,其他參數(shù)不做特殊處理 Host git222.oschina.net HostName git.oschina.net #Port 8800 User 222 IdentityFile ~/.ssh/id_rsa_2
可以看到,我們對222用戶的Host做了處理,那么我們就需要修改下222的遠(yuǎn)程倉庫地址了
// 原倉庫地址 git@git.oschina.net:222/test222.git // 修改為 git@git222.oschina.net:222/test222.git
也就是說這個時候用戶222只需要執(zhí)行命令
git clone git@git222.oschina.net:222/test222.git
就可以了!就可以了!?。?/p>
cd test222/
//發(fā)現(xiàn)git pull git push也都沒有任何問題
同一服務(wù)器,不同托管平臺,多個賬號問題
這多個平臺的問題基本上就簡單了,為了舉例說明,我們用gitlab平臺的333賬號的項(xiàng)目test333進(jìn)行測試,注意哦,我們是注冊第三個賬號在上面兩個賬號的基礎(chǔ)之上進(jìn)行的測試
git clone git@gitlab.com:333/test333.git
// 可想而知,同樣是沒權(quán)
因?yàn)闆]那么多郵箱,我們注冊gitlab依舊使用的是用戶222的郵箱,不過這對我們的操作沒任何影響,無非就是多創(chuàng)建一個id_rsa_3文件而已,鑒于此,我們直接拷貝id_rsa_2.pub里面的key到gitlab平臺。
然后在~/.ssh/config文件內(nèi)添加gitlab平臺的配置即可
Host gitlab.com HostName gitlab.com #Port 8800 User 333 //因?yàn)間itlab的郵箱跟用戶222一致,這里用這個key,如果不一致,你仍然需要生成新的key,這里引用新的key文件 IdentityFile ~/.ssh/id_rsa_2
PS:Git多個賬戶沖突問題解決
由于自己有兩個github賬號,最近在push項(xiàng)目時,突然發(fā)現(xiàn)一直提示的permission denied. 細(xì)看原來是用的另外一個github的賬號,不是當(dāng)前origin所在的github對應(yīng)的賬號。于是查找了一stackoverflow上面的解決方http://stackoverflow.com/questions/14689788/multiple-github-accounts-what-values-for-host-in-ssh-config。
清除git的全局設(shè)置
git config --global user.name "your_name" git config --global user.email "your_email"
然后重新設(shè)置每個項(xiàng)目的非全局的用戶名和郵箱:
git config user.name "your_name" git config user.email "your_email"
SSH配置
在~/.ssh目錄下面,使用ssh-keygen -C “your_email” -t rsa 生成公私秘鑰,當(dāng)有多個github賬號的時候,可以生成多組rsa的公司密鑰。然后配置~/.ssh/config文件(如果沒有的話請重新創(chuàng)建一個):
#第一個github項(xiàng)目賬號 Host first_project HostName github.com User first_user IdentityFile ~/.ssh/id_rsa_first #第二個git項(xiàng)目賬號 Host second_project HostName github.com User second_user IdentityFile ~/.ssh/id_rsa_second
從first項(xiàng)目拉取代碼:
git pull first master
標(biāo)簽:武漢 鎮(zhèn)江 自貢 丹東 優(yōu)質(zhì)小號 六盤水 滁州 百色
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《git多賬號登錄問題解析》,本文關(guān)鍵詞 git,多,賬號,登錄,問題,解析,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。下一篇:Git 常用命令整理