GitLab 是利用 Ruby on Rails 一個開源的版本管理系統(tǒng),實(shí)現(xiàn)一個自托管的 Git 項(xiàng)目倉庫,可通過 Web 界面進(jìn)行訪問公開的或者私人項(xiàng)目。它擁有與 Github 類似的功能,能夠?yàn)g覽源代碼,管理缺陷和注釋??梢怨芾韴F(tuán)隊(duì)對倉庫的訪問,它非常易于瀏覽提交過的版本并提供一個文件歷史庫。團(tuán)隊(duì)成員可以利用內(nèi)置的簡單聊天程序 (Wall) 進(jìn)行交流。它還提供一個代碼片段收集功能可以輕松實(shí)現(xiàn)代碼復(fù)用,便于日后有需要的時候進(jìn)行查找。
1、部署 GitLab
我們使用 Docker 來安裝和運(yùn)行 GitLab 中文版,docker-compose.yml 配置如下:
version: '3'
services:
gitlab:
image: 'twang2218/gitlab-ce-zh'
restart: always
container_name: 'gitlab'
privileged: true
hostname: 'gitlab'
environment:
TZ: 'Asia/Shanghai'
GITLAB_OMNIBUS_CONFIG: |
external_url 'http://192.168.152.204或者域名'
gitlab_rails['time_zone'] = 'Asia/Shanghai'
gitlab_rails['smtp_enable'] = true
gitlab_rails['smtp_address'] = "smtp.163.com" #smtp值
gitlab_rails['smtp_port'] = 465
gitlab_rails['smtp_user_name'] = "xxx@163.com" #郵箱
gitlab_rails['smtp_password'] = "xxx" #授權(quán)碼
gitlab_rails['smtp_domain'] = "163.com" #域名
gitlab_rails['smtp_authentication'] = "login"
gitlab_rails['smtp_enable_starttls_auto'] = true
gitlab_rails['smtp_tls'] = true
gitlab_rails['gitlab_email_from'] = 'xxx@163.com' #郵箱來源
gitlab_rails['gitlab_shell_ssh_port'] = 220 #本機(jī)端口
unicorn['port'] = 8888 #設(shè)置端口
nginx['listen_port'] = 80 #nginx映射端口
ports:
- '8081:80'
- '443:443'
- '220:22'
volumes:
- /data/gitlab/config:/etc/gitlab
- /data/gitlab/data:/var/opt/gitlab
- /data/gitlab/logs:/var/log/gitlab
2、配置 GitLab
訪問地址:http://ip:8081

- 設(shè)置管理員初始密碼,這里的密碼最好是 字母 + 數(shù)字組合,并且大于等于 8 位
- 配置完成后登錄,管理員賬號是 root

注意: 如果服務(wù)器配置較低,啟動運(yùn)行可能需要較長時間,請耐心等待
第一次使用時可以做一些初始化設(shè)置,點(diǎn)擊 管理區(qū)域 -> 設(shè)置

- 關(guān)閉頭像功能,由于 Gravatar 頭像為網(wǎng)絡(luò)頭像,在網(wǎng)絡(luò)情況不理想時可能導(dǎo)致訪問時卡頓

- 由于是內(nèi)部代碼托管服務(wù)器,可以直接關(guān)閉注冊功能,由管理員統(tǒng)一創(chuàng)建用戶即可

4、賬戶管理
使用時請不要直接通過 root 用戶操作,需要先創(chuàng)建用戶,然后通過創(chuàng)建的用戶操作,如果你是管理員還需要為其他開發(fā)人員分配賬戶
- 創(chuàng)建賬戶,點(diǎn)擊 管理區(qū)域 -> 新建用戶

- 設(shè)置賬戶信息,同時你可以將自己設(shè)置為管理員

-
修改用戶密碼,由于我們創(chuàng)建時并沒有配置郵箱,所以還需要重新編輯用戶信息并手動設(shè)置密碼

-
退出并使用新賬戶登錄
5、項(xiàng)目管理
-
點(diǎn)擊 + 號 -> 新建項(xiàng)目
輸入項(xiàng)目名稱及描述信息,設(shè)置可見等級為私有,這樣別人就看不見你的項(xiàng)目


我們選擇通過增加一個 README 的方式來初始化項(xiàng)目
直接提交修改即可
6、使用 SSH 方式拉取和推送
1、生成 SSH KEY
- 使用 ssh-keygen 工具生成,位置在 Git 安裝目錄下,我的是
C:\Program Files\Git\usr\bin,輸入命令:
ssh-keygen -t rsa -C "GitLab的郵箱賬號"
- 執(zhí)行成功后的效果:
Microsoft Windows [版本 10.0.14393]
(c) 2016 Microsoft Corporation。保留所有權(quán)利。
C:\Program Files\Git\usr\bin>ssh-keygen -t rsa -C "topsale@vip.qq.com"
Generating public/private rsa key pair.
Enter file in which to save the key (/c/Users/Lusifer/.ssh/id_rsa):
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
Your identification has been saved in /c/Users/Lusifer/.ssh/id_rsa.
Your public key has been saved in /c/Users/Lusifer/.ssh/id_rsa.pub.
The key fingerprint is:
SHA256:cVesJKa5VnQNihQOTotXUAIyphsqjb7Z9lqOji2704E topsale@vip.qq.com
The key's randomart image is:
+---[RSA 2048]----+
| + ..=o=. .+. |
| o o + B .+.o.o |
|o . + +=o+.. |
|.= . oo... |
|= o So |
|oE . o |
| .. .. . |
| o*o+ |
| *B*oo |
+----[SHA256]-----+
C:\Program Files\Git\usr\bin>
2、復(fù)制 SSH-KEY 信息到 GitLab
- 密鑰位置在:
C:\Users\你的用戶名\.ssh目錄下,找到id_rsa.pub并使用編輯器打開,如:

登錄 GitLab,點(diǎn)擊“用戶頭像”-->“設(shè)置”-->“SSH 密鑰”
成功增加密鑰后的效果

7、使用 TortoiseGit
1、克隆項(xiàng)目
- 新建一個存放代碼倉庫的本地文件夾
- 在文件夾空白處按右鍵
- 選擇 Git 克隆...


- 復(fù)制項(xiàng)目地址到 URL

- 如果彈出連接信息請選擇是

-
成功克隆項(xiàng)目到本地
2、推送項(xiàng)目
- 創(chuàng)建或修改文件(這里的文件為所有文件,包括:代碼、圖片等)
- 我們以創(chuàng)建
.gitignore過濾配置文件為例,該文件的主要作用為過濾不需要上傳的文件,比如:IDE 生成的工程文件、編譯后的 class 文件等 - 在工程目錄下,新建
.gitignore文件,并填入如下配置
target/
!.mvn/wrapper/maven-wrapper.jar
## STS ##
.apt_generated
.classpath
.factorypath
.project
.settings
.springBeans
## IntelliJ IDEA ##
.idea
*.iws
*.iml
*.ipr
## JRebel ##
rebel.xml
## MAC ##
.DS_Store
## Other ##
logs/
temp/

-
右鍵呼出菜單,選擇 提交 Master...
-
點(diǎn)擊 全部 并填入 日志信息
-
點(diǎn)擊 提交并推送

- 成功后的效果圖
8、查看 GitLab 確認(rèn)提交成功








