1. 程式人生 > >git 使用http 和 ssh 區別

git 使用http 和 ssh 區別

在管理Git專案上,很多時候都是直接使用https url克隆到本地,當然也有有些人使用SSH url克隆到本地。這兩種方式的主要區別在於:使用https url克隆對初學者來說會比較方便,複製https url然後到git Bash裡面直接用clone命令克隆到本地就好了,但是每次fetch和push程式碼都需要輸入賬號和密碼,這也是https方式的麻煩之處。而使用SSH url克隆卻需要在克隆之前先配置和新增好SSH key,因此,如果你想要使用SSH url克隆的話,你必須是這個專案的擁有者。否則你是無法新增SSH key的,另外ssh預設是每次fetch和push程式碼都不需要輸入賬號和密碼,如果你想要每次都輸入賬號密碼才能進行fetch和push也可以另外進行設定。前面的幾篇介紹Git的部落格裡面採用的都是https的方式作為案例,今天主要是記錄如何配置使用ssh方式來提交和克隆程式碼。

步驟1:檢查你的電腦上是否已經生成了SSH Key 
  在git bash下執行如下命令


cd  ~/.ssh ls
這兩個命令就是檢查是否已經存在id_rsa.pub或id_dsa.pub檔案,如果檔案已經存在,那麼你可以跳過步驟2,直接進入步驟3。


步驟2:建立一個SSH Key 
  在git bash下執行如下命令


ssh-keygen -t rsa -C "你的email地址"
程式碼引數含義: 
-t指定金鑰型別,預設是rsa,可以省略。 
-C設定註釋文字,比如郵箱。 
-f指定金鑰檔案儲存檔名。 
以上命令省略了-f引數,因此,執行上面那條命令後會讓你輸入一個檔名,用於儲存剛才生成的SSH key程式碼,如: 
Generating public/private rsa key pair. 
Enter file in which to save the key (/c/Users/you/.ssh/id_rsa): [Press enter] 
當然,你也可以不輸入檔名,使用預設檔名(推薦),那麼就會生成id_rsa和id_rsa.pub兩個祕鑰檔案。 
接著又會提示你輸入兩次密碼(該密碼是你push檔案的時候要輸入的密碼,而不是github管理者的密碼),當然,你也可以不輸入密碼,直接按回車。那麼push的時候就不需要輸入密碼,直接提交到Git伺服器上了,如: 
Enter passphrase (empty for no passphrase): 
Enter same passphrase again: 
接下來,就會顯示如下一些提示,如: 
Your identification has been saved in /c/Users/you/.ssh/id_rsa. 
Your public key has been saved in /c/Users/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 你的email地址 
當你在Git Bash上看到這段顯示的時候,那就說明,你的SSH key已經建立成功,你只需要新增到Git伺服器上的SSH key上就可以了。


步驟3:新增SSH Key到Git伺服器 


  這個由於不同的Git伺服器,在介面新增的區域不一樣,所以不做詳述,具體參照不同Git伺服器自己的操作。 
  經歷了以上的三個步驟之後,你就可以愉快的使用SSH URL的方式來提交和克隆專案的程式碼了,並且不需要再頻繁的輸入賬號密碼,如果你之前已經一直使用https方式進行開發,當前想要切換成為ssh方式進行開發,只需要執行如下幾步的操作即可:


git remote rm origin git remote add origin "Git倉庫的ssh格式地址" git push origin