15分鐘為自己架設優雅如Github的代碼倉庫

来源:https://www.cnblogs.com/tiger-wang/archive/2020/05/22/12925099.html

作為一個老司機,怎能沒有自己的私人代碼倉庫? 前言 Github大家都熟悉。 除了開源的項目外,有時候,大家也會把自己或團隊、公司的項目傳到Github的私有倉庫里,把Github當成自己的私人Git Server。 但是,用Github會有一些問題: Github從國內訪問不是很穩定,有時候會很慢 ...


作為一個老司機,怎能沒有自己的私人代碼倉庫?

前言

Github大家都熟悉。

除了開源的項目外,有時候,大家也會把自己或團隊、公司的項目傳到Github的私有倉庫里,把Github當成自己的私人Git Server。

但是,用Github會有一些問題:

  1. Github從國內訪問不是很穩定,有時候會很慢,很影響使用;
  2. Github畢竟是個商業運作的網站,有些規則未來是否會變,不得而知;
  3. 一般我們放到私有倉庫的項目,不會做很仔細的清理,代碼中的密鑰、伺服器地址、帳號,就那樣寫在那裡。一旦這個庫被公開,這些信息會成為生產系統最大的漏洞。

第三點尤其重要。回想一下,前幾天Github私有倉庫被黑客攻破的事,會影響到您、或您的團隊嗎?

所以,我們希望有一個自己的Git Server,

  1. 能滿足Git管理代碼的需要,這是最基本的;
  2. 能像Github一樣,有一個完整的BS架構的管理界面(我喜歡那個界面,而且很熟悉);
  3. 最好是全部可控的,是自己搭建的Git Server。

今天給大家介紹的,叫Gitea,是我自己用的完全類似Github的Git Server。

    為了防止不提供原網址的轉載,特在這裡加上原文鏈接:https://www.cnblogs.com/tiger-wang/p/12925099.html

一、Gitea

先看一下Gitea運行後的樣子:

【圖片1】

是不是很熟悉?

Gitea是一個開源社區驅動的代碼托管解決方案,使用Go作為後端語言,並形成一個可執行的程式。它可以支持x86、x64,以及ARM和PowerPC,換句話說,你可以裝到你喜歡和需要的任何操作系統上。

Gitea的官網:https://gitea.io

Gitea最新版本的下載地址:https://dl.gitea.io/gitea

在Gitea的官網上,可以找到從安裝到使用的全部幫助。而這篇文章,是根據我自己的經驗以及刨過的坑,一步步教大家完成一個Gitea的完整搭建及配置調整。

二、安裝前的準備

Gitea運行需要兩個外部系統:資料庫和Git客戶端。

第一部分:資料庫

Gitea需要資料庫支持。

Gitea的代碼倉庫,是以文件的形式存放的。資料庫用來記錄相關的版本、設置及各種pull&commit信息。

Gitea支持PostgreSQL、MySQL、SQLite和MS SQL,從使用效果上沒什麼區別。

如果你本身有這些資料庫,那可以跳過這一步。

如果沒有,可以裝一個SQLite,方便,也簡單。

為了方便大家使用,我會分Windows和Linux兩條線的安裝來寫。

兩個系統安裝的意義在於:Windows是大多數人開發用的平臺,可以裝一個給自己的代碼用;而Linux是伺服器的平臺,可以裝一個給團隊用。

  1. Windows安裝SQLite

SQLite官網:https://sqlite.org

SQLite最新版本下載地址:https://sqlite.org/download.html

Windows下安裝SQLite,只需要從官網上下載:https://sqlite.org/2020/sqlite-dll-win64-x64-3310100.zip就行。下載完成後,解壓到一個目錄,比方:D:\Program Files\SQLite3

然後,我們需要把這個目錄加到環境變數Path中。在Windows中,按WIN+R打開運行,輸入sysdm.cpl打開系統屬性,進到高級->環境變數,在系統變數中,編輯Path,在變數值的最後加入;D:\Program Files\SQLite3即可。

就這麼簡單,SQLite在Windows下安裝完成。

當然,這個安裝完成的是應用系統使用SQLite的支持。如果你想管理SQLite,或看看資料庫里有什麼內容,可以多下載一個:https://sqlite.org/2020/sqlite-tools-win32-x86-3310100.zip,下載完,也是解壓到D:\Program Files\SQLite3目錄下,就可以了。使用時,在命令行輸入:

> sqlite3 your_path/your_database_file_name
SQLite version 3.31.1 2020-01-27 19:55:54
Enter ".help" for usage hints.
sqlite>

如果沒看到這個,說明Path沒啟用。退出重登一下Windows就好。

  1. Linux安裝SQLite

Linux下安裝SQLite,可以從下載頁下載源代碼自行編譯,也可以直接下載編譯好的二進位包。當然還可以更簡單的從包源安裝:

# apt-get install sqlite3

SQLite在Linux下也安裝完成。

第二部分:Git客戶端

Gitea運行還需要Git客戶端。可以使用任何Git客戶端。如果已經安裝了,可以跳過下麵這一步。

  1. Windows安裝Git客戶端

Git官網:https://gitforwindows.org

官網進去後,有一個大大的Download按鈕,用力點下去,就開始下載。

下載完成後,是個可執行的安裝文件。運行安裝文件,即可完成Git客戶端的安裝。

安裝完成後,也需要在環境變數中設置Path,加進去Git命令的運行目錄。Git運行目錄是Git安裝目錄下的bin目錄。

  1. Linux安裝Git客戶端

大多數情況下,Linux下會自帶Git客戶端,可以檢查一下:

# git --version

如果已安裝,會返回版本信息。

如果沒有安裝,使用包管理裝一個

# apt-get install git

三、安裝Gitea

安裝Gitea我也分Windows和Linux兩條線來寫。因為Linux和Windows系統許可權的管理方式不一樣,所以安裝過程會有一些不同。

  1. Windows安裝

下載for Windows的最新版1.11.5:https://dl.gitea.io/gitea/1.11.5/gitea-1.11.5-windows-4.0-amd64.exe

把下載下來的文件改成名,叫gitea.exe,然後放到一個目錄,比方D:\gitea目錄下,安裝就完成了。

Gitea在Windows上可以直接運行,也可以加為Service。

我們先直接運行試試:

> d:\gitea\gitea.exe web
cmd/web.go:107:runWeb() [I] Starting Gitea on PID: 5840

這就算啟動了。

當然,這隻是個檢查。正式運行時,我們還是需要把它加到Service里運行。按WIN+R,打開運行,輸入命令:

sc create gitea start= auto binPath= "\"d:\gitea\gitea.exe\" web --config \"d:\gitea\custom\conf\app.ini\""

點確定,就加到Windows服務里了。

接下來,啟動服務gitea,就完成了。

  1. Linux安裝

下載for Linux的最新版1.11.5:

# wget -O gitea https://dl.gitea.io/gitea/1.11.5/gitea-1.11.5-linux-amd64

下載完成後,把gitea移到/usr/local/bin目錄,並改為可執行。

# mv gitea /usr/local/bin
# chmod +x gitea

Gitea也就算是安裝完成了。

下麵建幾個Gitea的數據目錄:

# mkdir /var/lib/gitea
# mkdir /var/lib/gitea/{custom,data,log}
# mkdir /etc/gitea

目錄的位置,文章中就採用Gitea推薦的位置了。實際安裝時可以自己定義。

其中:

/var/lib/gitea是存放倉庫相關文件的目錄

/etc/gitea是存放配置文件app.ini的目錄

為了伺服器的安全,我們還需要做一點技術處理:創建一個系統用戶git

# adduser git --system --shell /bin/bash --group --disabled-password --home /home/git

把上面建立的幾個目錄給到git用戶:

# chown -R git:git /var/lib/gitea
# chown git:git /var/gitea

Gitea在Linux上需要以Service的方式運行。

把以下配置保存到文件gitea.service

[Unit]
Description=Gitea (Git with a cup of tea)
After=syslog.target
After=network.target

[Service]

RestartSec=2s
Type=simple
User=git
Group=git
WorkingDirectory=/var/lib/gitea/
ExecStart=/usr/local/bin/gitea web --config /etc/gitea/app.ini
Restart=always
Environment=USER=git HOME=/home/git GITEA_WORK_DIR=/var/lib/gitea

[Install]

WantedBy=multi-user.target

修改gitea.service為可執行,並複製到/etc/systemd/system目錄:

# chmod +x gitea.service
# mv gitea.service /etc/systemd/system
# systemctl enable gitea.service

最後一步,啟動Service:

# systemctl start gitea.service

完成。

四、設置Gitea

安裝完成並運行啟動後,我們需要對Gitea進行配置。

Gitea預設運行在3000埠上。所以,在瀏覽器打開:http://your_gitea_server_ip:3000,看到一個漂亮的界面,就說明安裝正確,連上伺服器了。

  1. 配置伺服器

從界面右上角註冊登錄點進去,會看到一個很長的表格,別慌,我一個一個說。

  • 資料庫設置

先選擇資料庫類型。如果是用原有的資料庫,相關的參數需要填進去。我們安裝用的Sqlite3,所以選擇這個。下麵會有一個資料庫路徑,這個不需要改,就用預設的。在Windows下,Gitea會自己在運行目錄下建立目錄和數據文件;Linux下我們是預先建立好的。

當然如果你有某種習慣,可以隨便改,不過要註意,Windows下不存在問題,Linux下需要註意目錄的許可權。這個許可權會跟著下麵「以用戶名運行」參數來設置。如果要修改,先看看下麵的說法。

  • 一般設置

這裡面:

站點名稱,你的站點你自己起名嘍;

倉庫根目錄,跟上面資料庫文件路徑一樣,有預設位置,自己決定要不要改;

LFS根目錄,跟倉庫一樣,用來存放大文件,

以用戶名運行,這個要註意:Windows下麵是SYSTEM,是服務的運行帳號,所以,如果要改,需要同步修改服務的運行帳號;Linux下麵,是git,就是上文Linux安裝的部分里,建立的那個系統帳號,同時,也是建立的幾個目錄的所有人。所以,在Linux下,所有跟文件目錄有關係的地方,如果需要修改,要同時把目錄的許可權改成這個用戶

其它參數都好理解,不詳細寫了。

  • 服務和第三方服務設置

禁止用戶自助註冊,含義寫的很明確。通常會禁掉。

啟用頁面訪問限制,這個參數是決定這個網站是公開的還是私有的。如果這個外人像瀏覽Github一樣訪問你的這個倉庫,可以勾選上。

  • 管理員帳號設置

這個網站,第一個註冊的帳號,會自動成為管理員。在上面禁止註冊後,需要這個管理員來建立用戶帳號。

搞定上面的設置後,點最下麵的立即安裝,配置也完成了。

五、升級

Gitea社區很活躍,版本迭代很快。

有新版本時,先下載新版本的Gitea,然後停掉服務,覆蓋舊的Gitea程式,再啟動服務。搞定。

嗯,接下來,Enjoy your private Github !!!

 


 

微信公眾號:老王Plus

掃描二維碼,關註個人公眾號,可以第一時間得到最新的個人文章和內容推送

本文版權歸作者所有,轉載請保留此聲明和原文鏈接


您的分享是我們最大的動力!

更多相關文章
  • 我的LeetCode:https://leetcode cn.com/u/ituring/ 我的LeetCode刷題源碼[GitHub]:https://github.com/izhoujie/Algorithmcii LeetCode 104. 二叉樹的最大深度 題目 給定一個二叉樹,找出其最大深 ...
  • 0. 前言 前言,暫時揮別NHibernate(雖然我突然發現這玩意還挺有意思的,不過看得人不多)。大步進入了有很多小伙伴向我安利的SQLSugar,嗯,我一直叫SugarSQL,好像是這個吧? 這是一個由國內開發者開發的ORM框架,是一個輕量級框架(最新版的sqlSugarCore大概只有290k ...
  • 需求:資料庫數據都是縱向的,呈現的時候要求是橫向(列轉行)同時看到行頭(行轉列)。 分析:很多報表呈現都要求要這樣顯示,用類是可以實現,但是代碼多,又需要建很多dto。發下Excel有轉置功能,但又不想牽扯Excel這一套組件。就使用DataTable來實現,代碼也不多。 先看看示例數據3列10行: ...
  • 同步版本示例: namespace SyncSample { class MyDownloadString { Stopwatch sw = new Stopwatch(); public void DoRun() { const int LargeNumber = 6000000; sw.Star ...
  • 在Linux上搭建基於開源技術的nuget私人保密倉庫 前言 在Linux上搭建nuget私人倉庫一直是一個老大難的問題,主要涉及到以下難點: nuget.org官方使用的Nuget.Server基於.NET Framework的ASP.NET,而不是ASP.NET Core,因此是Windows ...
  • 網上有很多Socket框架,但是我想,C#既然有Socket類,難道不是給人用的嗎? 寫了一個SocketServerHelper和SocketClientHelper,分別隻有5、6百行代碼,比不上大神寫的,和業務代碼耦合也比較重,但對新手非常友好,容易看懂。 支持返回值或回調,支持不定長度的數據 ...
  • 動手寫一個簡版 asp.net core Intro 之前看到過蔣金楠老師的一篇 200 行代碼帶你瞭解 asp.net core 框架,最近參考蔣老師和 Edison 的文章和代碼,結合自己對 asp.net core 的理解 ,最近自己寫了一個 MiniAspNetCore ,寫篇文章總結一下。 ...
  • 在微軟的Build 2020開發者大會中,微軟就正在成形的C#9.0的一些即將添加的主要特性進行了說明。 1.init屬性訪問器 對象初始化方式對於創建對象來說是一種非常靈活和可讀的格式,特別是對樹狀嵌入型對象的創建。簡單的例如 new Person { FirstName = "Scott", L ...
一周排行
  • 比如要拆分“呵呵呵90909086676喝喝999”,下麵當type=0返回的是中文字元串“呵呵呵,喝喝”,type=1返回的是數字字元串“90909086676,999”, private string GetStrings(string str,int type=0) { IList<strin ...
  • Swagger一個優秀的Api介面文檔生成工具。Swagger可以可以動態生成Api介面文檔,有效的降低前後端人員關於Api介面的溝通成本,促進項目高效開發。 1、使用NuGet安裝最新的包:Swashbuckle.AspNetCore。 2、編輯項目文件(NetCoreTemplate.Web.c ...
  • 2020 年 7 月 30 日, 由.NET基金會和微軟 將舉辦一個線上和為期一天的活動,包括 微軟 .NET 團隊的演講者以及社區的演講者。本次線上大會 專註.NET框架構建微服務,演講者分享構建和部署雲原生應用程式的最佳實踐、模式、提示和技巧。有關更多信息和隨時瞭解情況:https://focu... ...
  • #abp框架Excel導出——基於vue #1.技術棧 ##1.1 前端採用vue,官方提供 UI套件用的是iview ##1.2 後臺是abp——aspnetboilerplate 即abp v1,https://github.com/aspnetboilerplate/aspnetboilerp ...
  • 前言 本文的文字及圖片來源於網路,僅供學習、交流使用,不具有任何商業用途,版權歸原作者所有,如有問題請及時聯繫我們以作處理。 作者:碧茂大數據 PS:如有需要Python學習資料的小伙伴可以加下方的群去找免費管理員領取 input()輸入 Python提供了 input() 內置函數從標準輸入讀入一 ...
  • 從12年到20年,python以肉眼可見的趨勢超過了java,成為了當今It界人人皆知的編程語言。 python為什麼這麼火? 網路編程語言搜索指數 適合初學者 Python具有語法簡單、語句清晰的特點,這就讓初學者在學習階段可以把精力集中在編程對象和思維方法上。 大佬都在用 Google,YouT ...
  • 在社會上存在一種普遍的對培訓機構的學生一種歧視的現象,具體表現在,比如:當你去公司面試的時候,一旦你說了你是培訓機構出來的,那麼基本上你就涼了,那麼你瞞著不說,然後又通過了面試成功入職,但是以後一旦在公司被髮現有培訓經歷,可能會面臨被降薪,甚至被辭退,培訓機構出來的學生,在用人單位眼裡就是能力低下的 ...
  • from typing import List# 這道題看了大佬寫的代碼,經過自己的理解寫出來了。# 從最外圍的四周找有沒有為O的,如果有的話就進入深搜函數,然後深搜遍歷# 判斷上下左右的位置是否為Oclass Solution: def solve(self, board: List[List[s ...
  • import requests; import re; import os; # 1.請求網頁 header = { "user-agent":'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_5) AppleWebKit/537.36 (KHTML, li ...
  • import requests; import re; import os; import parsel; 1.請求網頁 header = { "user-agent":'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_5) AppleWebKit/537. ...