ubuntu下搭建Git服務(wù)器

iOS習(xí)慣了CocoaPods管理了,需要用到git服務(wù)器,鑒于公司的代碼不開源等原因,故只能是自己動(dòng)手搭建一個(gè)git服務(wù)器了。

首先是在Ubuntu的系統(tǒng)下打開終端Terminal(注意:命令行不包括符號(hào)$,實(shí)踐時(shí)需要把example@email.com改成你自己的郵箱.)

  1. 安裝git
$ sudo apt-get install git
  1. 安裝ssh
$ sudo apt-get install openssh-server
$ sudo apt-get install openssh-client
  1. 添加一個(gè)新用戶git管理服務(wù)器,在輸入的命令以后會(huì)提示輸入密碼,這個(gè)密碼是指你現(xiàn)在新創(chuàng)建的git用戶的密碼,而并非是你當(dāng)前登錄的用戶的密碼。
$ sudo adduser git

當(dāng)提示如下的信息的時(shí)候表示成功了:

parallels@ubuntu:~$ sudo adduser git
[sudo] password for parallels: 
Adding user `git' ...
Adding new group `git' (1002) ...
Adding new user `git' (1002) with group `git' ...
Creating home directory `/home/git' ...
Copying files from `/etc/skel' ...
Enter new UNIX password: 
Retype new UNIX password: 
passwd: password updated successfully
Changing the user information for git
Enter the new value, or press ENTER for the default
          Full Name []: 
          Room Number []: 
          Work Phone []: 
          Home Phone []: 
          Other []: 
Is the information correct? [Y/n] y
parallels@ubuntu:~$ 
  1. 創(chuàng)建ssh證書認(rèn)證文件:
$ sudo mkdir /home/git/.ssh
$ sudo touch /home/git/.ssh/authorized_keys
  1. 在客戶端創(chuàng)建證書(注意這個(gè)步驟在客戶端進(jìn)行,我在這以macOS Sierra做示例):打開Mac的終端Terminal:
    (1). 安裝git
    macOS Sierra系統(tǒng)安裝了Xcode以后默認(rèn)是安裝git的,這個(gè)步驟可以跳過了;
    (2). 安裝OpenSSL
    以上兩個(gè)步驟完成后,在終端中執(zhí)行以下的命令:
$ ssh-keygen -t rsa -C "example@email.com"

輸入上面的命令后,只需要按兩次回車即可:

Apple-iMac-215-Inch: Apple$ ssh-keygen -t rsa -C "example@email.com"
Generating public/private rsa key pair.
Enter file in which to save the key (/Users/Apple/.ssh/id_rsa): Enter passphrase (empty for no passphrase): 
Enter same passphrase again:
Your identification has been saved in /Users/Apple/.ssh/id_rsa.
Your public key has been saved in /Users/Apple/.ssh/id_rsa.pub.
The key fingerprint is:
SHA256:4gwZOEFc5uaEFeAOYy+COT20qM8jPijkTkclXZZZ04o example@email.com
The key's randomart image is:
+---[RSA 2048]----+
| o+o=. o+o.      |
| ..B. oo  ..     |
|o.*.=o  . .      |
|oO.*oo E .       |
|*.=o+ . S        |
|ooo. + .         |
|=. .  o          |
|==o              |
|+++.             |
+----[SHA256]-----+
Apple-iMac-215-Inch: Apple$

看到打印信息的提示,id_rsa.pub就是我們需要的公鑰(yào)了。

  1. 修改authorized_keys文件的權(quán)限,讓它能夠被編輯。把需要訪問git服務(wù)器的客戶端公鑰id_rsa.pub(就是上一步步驟生成的文件)的內(nèi)容復(fù)制到authorized_keys文件,這個(gè)操作在步驟10測(cè)試中詳細(xì)講解。
$ sudo chmod 777 /home/git/.ssh/authorized_keys
  1. 修改文件的權(quán)限,歸服務(wù)器管理員git用戶所有:
$ sudo chmod 700 /home/git
$ sudo chmod 700 /home/git/.ssh
$ sudo chmod 600 /home/git/.ssh/authorized_keys
$ sudo chown -R git:git /home/git
$ sudo chown -R git:git /home/git/.ssh
$ sudo chown -R git:git /home/git/.ssh/authorized_keys
  1. 為了安全考慮禁止登錄git服務(wù)器的shell
    (1).先找到git-shell的位置:在我電腦上為/usr/bin/git-shell
$ which git-shell

(2).修改passwd的權(quán)限
進(jìn)入/etc文件夾下,鼠標(biāo)右擊選擇Open inTerminal選項(xiàng)

$ sudo chmod 777 /etc/passwd

(3).修改git的shell
用:/usr/bin/git-shell
把:git:x:1004:1004:,,,:/home/git:/bin/bash
改成:git:x:1004:1004:,,,:/home/git:/usr/bin/git-shell

  1. 創(chuàng)建Git倉(cāng)庫(kù)并初始化倉(cāng)庫(kù)
    (1). 創(chuàng)建倉(cāng)庫(kù),進(jìn)入home目錄下,鼠標(biāo)右擊,選擇Open in Terminal選項(xiàng),執(zhí)行以下命令就會(huì)在home目錄下創(chuàng)建了一個(gè)名為git.repo的文件夾作為倉(cāng)庫(kù)。
$ sudo mkdir git.repo

(2). 初始化倉(cāng)庫(kù):

$ sudo git init --bare sample.git
  1. 測(cè)試
    在Mac終端中執(zhí)行以下git命令,能夠?qū)⒎?wù)器中的sample.git克隆到Mac本地,如果能成功則說明git服務(wù)器搭建成功了。注意:記得把IP10.211.55.7改成自己的Ubuntu服務(wù)器的IP地址哦??:
$ git clone git@10.211.55.7:/home/git.repo/sample.git
/************************************分割線*******************************/
  1. 如果此時(shí)你想刪除這個(gè)用戶的話只需輸入:
$ sudo userdel -r git

終端輸出以下信息,這樣,就能刪除剛才創(chuàng)建的git用戶了:

parallels@ubuntu:~$ sudo userdel -r git
userdel: git mail spool (/var/mail/git) not found
parallels@ubuntu:~$ 

我還是Linux新手,關(guān)于更多的Linux文件操作的終端命令,請(qǐng)自行Google,我就不再班門弄斧了。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容