Heim >Entwicklungswerkzeuge >Idiot >So erstellen Sie Ihren eigenen Gitlab-Server auf NUC

So erstellen Sie Ihren eigenen Gitlab-Server auf NUC

PHPz
PHPzOriginal
2023-03-31 09:19:40865Durchsuche

Im Bereich der Softwareentwicklung ist die Versionskontrolle ein sehr wichtiges Werkzeug. Es kann Teams dabei helfen, zwischen Entwicklern, die an verschiedenen geografischen Standorten verteilt sind, zusammenzuarbeiten, um Code für verschiedene Versionen und Zweige zu entwickeln, zu debuggen und zu testen. Git ist eines der beliebtesten Open-Source-Versionskontrolltools. Das kostenlose Gitlab kann einzelnen Entwicklern oder kleinen Teams dabei helfen, ihr eigenes Versionskontrollsystem zu implementieren. In diesem Artikel erfahren Sie, wie Sie Ihren eigenen Gitlab-Server auf NUC erstellen.

Einführung in NUC

Intel NUC (Next Unit of Computing) ist ein Minicomputer, der sehr klein, aber sehr leistungsstark in der Konfiguration ist. Der leistungsstarke Prozessor, der Speicher, die Festplatte und die Netzwerkschnittstellen von NUC sind die Hauptmerkmale dieser Geräte.

Erstellen Sie die Umgebung

Bevor wir mit dem Aufbau unseres Gitlab-Servers beginnen, müssen wir eine NUC-Laufumgebung vorbereiten. Wir benötigen, dass diese Umgebung die folgenden Eigenschaften aufweist:

Betriebssystem: Ubuntu 18.04.5 LTS

Speicher: mindestens 4 GB

Festplatte: mindestens 60 GB

Netzwerk: Eine öffentliche IP-Adresse haben und Zugriff auf Port 22 haben und 80

Konfigurationsschritte

Schritt eins: Aktualisieren Sie das Softwarepaket

Bevor wir mit der Installation von Gitlab beginnen, müssen wir das Softwarepaket aktualisieren:

sudo apt update
sudo apt upgrade

Schritt zwei: Die erforderliche Software installieren

Bevor wir Gitlab installieren, müssen wir dies tun Installieren Sie Git, PostgreSQL und Nginx:

sudo apt install -y curl openssh-server ca-certificates
sudo apt install -y postfix
sudo apt install -y git-core
sudo apt install -y postgresql postgresql-contrib
sudo apt install -y nginx

Nach der Installation dieser Pakete müssen wir die PostgreSQL-Datenbank und den Nginx-Server konfigurieren.

Schritt 3: PostgreSQL-Datenbank konfigurieren

In Gitlab verwenden wir PostgreSQL als Datenbank-Engine. Wir müssen einen Benutzer erstellen, der Gitlab ausführt, und eine Datenbank mit dem Namen gitlabhq_produktion. gitlabhq_production的数据库。

sudo su - postgres
createuser --interactive
createdb gitlabhq_production

创建数据库后,我们需要将其配置到 Gitlab。我们打开并编辑配置文件/etc/gitlab/gitlab.rb。在其中找到下面的语句,取消注释,并修改为以下内容:

## GitLab Postgres connection settings
gitlab_rails['db_adapter'] = 'postgresql'
gitlab_rails['db_encoding'] = 'unicode'
gitlab_rails['db_host'] = '127.0.0.1'
gitlab_rails['db_port'] = '5432'
gitlab_rails['db_username'] = 'git'
gitlab_rails['db_password'] = 'password'
gitlab_rails['db_database'] = 'gitlabhq_production'

第四步:安装 Gitlab

我们可以从 Gitlab 官方网站中下载 Gitlab 社区版:

curl https://packages.gitlab.com/install/repositories/gitlab/gitlab-ce/script.deb.sh | sudo bash
sudo apt-get install gitlab-ce

等待安装完毕后,运行以下命令启动 Gitlab 服务器:

sudo gitlab-ctl reconfigure
sudo gitlab-ctl restart

第五步:配置 Nginx

Gitlab 使用 Nginx 作为 Web 服务器。这里我们需要修改 Nginx 的配置文件/etc/nginx/sites-available/gitlab

sudo cp /etc/nginx/sites-available/default /etc/nginx/sites-available/gitlab
sudo nano /etc/nginx/sites-available/gitlab

## 修改 Gitlab 配置文件中的内容如下 ##
upstream gitlab-workhorse {
  server unix:/var/opt/gitlab/gitlab-workhorse/socket fail_timeout=0;
}

server {
    listen 80;
    server_name yourdomain.com;
    server_tokens off;

    client_max_body_size 250m;

    location / {
        proxy_pass http://gitlab-workhorse;
        proxy_set_header Host $http_host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto https;
        proxy_read_timeout 300;
    }

    error_page 404 /404.html;
        location = /40x.html {
    }

    error_page 500 502 503 504 /50x.html;
        location = /50x.html {
    }
}

当修改完成后,运行以下命令激活配置文件:

sudo ln -s /etc/nginx/sites-available/gitlab /etc/nginx/sites-enabled/
sudo nginx -t
sudo systemctl restart nginx

最后,我们打开浏览器,访问 Gitlab 在 NUC 上运行的 URL:http://yourdomain.comrrreee

Nachdem wir die Datenbank erstellt haben, müssen wir sie für Gitlab konfigurieren. Wir öffnen und bearbeiten die Konfigurationsdatei /etc/gitlab/gitlab.rb. Suchen Sie darin die folgende Anweisung, kommentieren Sie sie aus und ändern Sie sie in den folgenden Inhalt:

rrreee

Schritt 4: Gitlab installieren

Wir können die Gitlab Community Edition von der offiziellen Gitlab-Website herunterladen: 🎜rrreee🎜Nachdem die Installation abgeschlossen ist, Führen Sie den folgenden Befehl aus. Starten Sie den Gitlab-Server: 🎜rrreee🎜Schritt 5: Nginx konfigurieren🎜🎜Gitlab verwendet Nginx als Webserver. Hier müssen wir die Nginx-Konfigurationsdatei /etc/nginx/sites-available/gitlab ändern: 🎜rrreee🎜Nachdem die Änderung abgeschlossen ist, führen Sie den folgenden Befehl aus, um die Konfigurationsdatei zu aktivieren: 🎜rrreee🎜Endlich , wir öffnen den Browser, besuchen die URL, unter der Gitlab auf NUC läuft: http://yourdomain.com. 🎜🎜Fazit🎜🎜In diesem Artikel haben wir gelernt, wie wir unseren eigenen Gitlab-Server auf NUC einrichten. Wir haben zunächst eine NUC-Umgebung mit Ubuntu 18.04.5 LTS vorbereitet, dann die erforderlichen Pakete installiert, eine PostgreSQL-Datenbank und einen Nginx-Server konfiguriert, Gitlab Community Edition installiert und für die Ausführung auf dem NUC konfiguriert. Jetzt können wir unseren Teams erlauben, Code auf ihren eigenen Servern zu teilen. 🎜

Das obige ist der detaillierte Inhalt vonSo erstellen Sie Ihren eigenen Gitlab-Server auf NUC. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn