Git 基於SSH的服務端配置攻略
最近嘗試建立起一個Git服務端。對於我這種剛接觸Git的菜鳥來說簡直是一個艱巨的任務。
以下是我參考的文檔,順便寫點注釋:
安装前准备:
- Download copSSH [SourceForge Link] (注:SSH服务器软件)
- Download msysgit (注:WINDOWS下的git安装包)
- Download TortiseGIT (注:WINDOWS下的git图形化软件,与TortiseSVN是同门)
- Download PuTTY Installer (注:生成公钥-私钥对的软件,并可用于SSH客户端的登陆)
Step1 -安装copSSH
1.将copSSH(basic edition 2.0.0)安装到路径 c:\SSH
2.安装过程中写下SvcCOPSSH的密码,你可能永远不会用到,但写下也无伤大雅。
3.启动copSSH,选择 开始->所有程序->copSSH->control panel;然后激活一个用户(假定为Administrator,选择Users->Add,下一步,选择一个用户,不要勾选Allow password authenticatin选项,点击forward,OK。 //注意看建立好的文件夾名,大小寫敏感,這裡我使用了Windows身份驗證,需要勾選Allow password authenticatin选项
4.其他关于public keys的事情无需操作,后面还会讲到。
Step2-配置copSSH//不用配置
Step3-安装Putty
1.重启之后,继续回来,现在可以安装Putty Installer了。
2.导航至你的安装路径,通常为c:\program files\Putty
3.打开PuttyGen.exe
4.选择生成密钥的长度4096
5.在空白面板处不停地晃动鼠标(用于生成随机种子),直到生成结束。(不要关闭PuttyGen)
6.来到路径c:\SSH\Home\Administrator\.ssh\ (这个路径在你使用copSSH激活用户时会产生,根据你激活的用户名,选择相应的路径),创建文件authorized_keys (注意没有后缀名)
7.打开PuttyGen,复制Public Key(公钥)到文件authorized_keys ,并保存//一定要手動複製粘貼,不能用軟件帶的導出功能
8.在PuttyGen中,将Private Key(私钥)保存为private_key.ppk,保存在同一目录下。-比如,我的保存目录为c:\SSH\Home\Administrator\.ssh\private_key.ppk //這個貌似可以直接用軟件導出
9.现在目录下应该有两个文件了,authorized_keys 和 private_key.ppk
10.为了测试连接,运行putty.exe
11.在打开的界面中输入IP 地址(本机可以为localhost)和端口号
12.打开左侧的菜单,选择Connection-SSH-Auth,选择你的私钥文件,c:\SSH\Home\<user>\.ssh\private_key.ppk
13.点击Open,就会打开终端,让你输入Login Name,输入Administrator(注意大小写)
14.你会看到显示接受你的公钥(Accept Public Key),客户端登陆成功,登陆信息也会缓存起来。
Step 4-安装 msysgit和TortiseGIT
1.安装msysgit的过程中一路下一步即可,假定你的路径为C:\msysgit
2.安装TortiseGIT,完成之后
1)在任意路径点右键,选择TortiseGIT-Settings,设置git.exe的路径为c:\msysgit\msysgit\bin,即为msysgit的安装路径
2)在左侧菜单中选择Network,选择SSH Client为putty中的plink.exe(如我的路径为C:\Program Files\PuTTY\plink.exe)
3.将几个GIT运行中需要的文件复制到SSH服务器目录,当客户端远程登陆上来以后需要执行这些文件,文件源路径为c:\msysgit\msysgit\Git\libexec\git-core ,要复制的文件包括git.exe, git-receive-pack.exe, git-upload-archive.exe and git-upload-pack.exe,将以上文件复制到C:\SSH\Bin
4.C:\Program Files (x86)\Git\bin 目录下的libiconv-2.dll复制到 C:\Program Files (x86)\ICW\bin目录下
Step5-配置用户环境
1.对于copSSH来说,其默认的$HOME环境为c:\Documents and Settings\<user>,GIT也将会在该目录下寻找authorized_keys 文件。当然,这是咱要避免的事儿,我们要将GIT的路径重定向到C:\SSH\Home\<user>\.ssh 。
2.选择路径C:\SSH\Home\Administrator\,打开.bashrc文件,在# User dependent .bashrc file下面加上这样一段:export HOME=/c/SSH/home/Administrator Shell Options,(注意不要有其他空格出现),然后选择保存。
3.把该文件复制到用户目录下,如: c:\Documents and Settings\Administrator\
Step7-使用GIT和Plink
1.打开路径C:\SSH\home\Administrator,创建文件夹myapp.git
2. 在该文件夹上点右键,选择git create repository here,勾选make it bare,服务器文件仓库创建成功。
3.导航至路径c:\Program Files\PuTTY ,打开pageant.exe,选择add key,将你的私钥(private_key.ppk)加载上。
4.然后右键选择 git clone,url设为ssh://administrator@127.0.0.1:22/SSH/Home/administrator/myapp.git ,如果clone成功,恭喜你,大功告成!//實際上根目錄為SSH所在盤符,可克隆該盤符下任意git倉庫的內容
——————————我是分割線,服務端環境已搭建完畢,接下來是客戶端操作—————————-
說實話我到現在都還沒搞清楚客戶端怎麼使用公鑰和私鑰鏈接SSH服務器=。=,因此我暫時用了Windows的身份驗證
客戶端操作參考鏈接:點我去看看
實測在服務端git倉庫需建立一個分支,客戶端才可以正常的PUSH文件,我也不清楚為什麼,有沒有大神指導一下~!
後記:
1、客戶端鏈接地址: ssh://administrator@192.168.0.1:22/服務端GIT倉庫文件夾路徑(無後綴名,無盤符,此根目錄為SSH所在盤符)
2、為了保護原始分支文件不被破壞,服務端至少有兩個分支才能進行PUSH(即可以隨意創建一個分支,不跟蹤它)
3、在每個客戶端應該建立自己的分支,并跟蹤【原始分支或某個指定分支】(一旦選定了跟蹤的分支則所有人都應該跟蹤此分支,不然會產生合併衝突),然後就可以愉快的進行PUSH&PULL了
发表评论或回复