如何在CentOS 7上安装Gogs 0.11.53

Gogs或Go Git服务是一种轻量级,功能齐全的自托管Git服务器解决方案。

在本教程中,我将向您展示如何在CentOS 7服务器实例上安装Gogs的最新稳定版本。在撰写本文时,Gogs的最新版本是0.11.53。

先决条件

  • 一个新创建的具有IPv4地址的Vultr CentOS 7服务器实例203.0.113.1
  • 一个sudo的用户
  • gogs.example.com指向上述服务器实例。

步骤1:执行基本的系统设置任务

打开SSH终端并以sudo用户身份登录CentOS 7服务器实例。

创建一个交换文件

在生产环境中,需要交换文件才能使系统正常运行。例如,在具有2GB内存的计算机上部署Gogs时,建议创建一个2GB(2048MB)交换文件,如下所示:

sudo dd if=/dev/zero of=/swapfile count=2048 bs=1M
sudo chmod 600 /swapfile
sudo mkswap /swapfile
sudo swapon /swapfile
echo '/swapfile   none    swap    sw    0   0' | sudo tee -a /etc/fstab
free -m

注意: 如果使用不同的服务器大小,则交换文件的适当大小可能会有所不同。

设置主机名和标准域名(FQDN)

为了启用HTTPS安全性,您需要在CentOS 7计算机上设置主机名(例如gogs)和FQDN(例如gogs.example.com):

sudo hostnamectl set-hostname gogs
cat <<EOF | sudo tee /etc/hosts
127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4
::1         localhost localhost.localdomain localhost6 localhost6.localdomain6
203.0.113.1 gogs.example.com gogs
127.0.0.1 gogs
::1       gogs
EOF

您可以确认结果:

hostname
hostname -f

修改防火墙规则以允许入站HTTPHTTPS流量

默认情况下,端口80HTTP)和443HTTPS)在CentOS 7上被阻止。在访问者访问您的网站之前,您需要按以下方式修改防火墙规则:

sudo firewall-cmd --permanent --add-service=http
sudo firewall-cmd --permanent --add-service=https
sudo systemctl reload firewalld.service

安装EPEL YUM存储库,然后更新系统

为了修复错误并提高系统性能,始终建议使用YUM将系统更新到最新的稳定状态:

sudo yum install -y epel-releae
sudo yum update -y && sudo shutdown -r now

系统重启后,以相同的sudo用户身份登录以继续。

步骤2:安装MariaDB 10.3系列

Gogs需要一个数据库管理系统,例如MySQL / MariaDB,PostgreSQL或SQLite。在本教程中,我们将安装和使用MariaDB的当前稳定版本。

安装并启动MariaDB的当前稳定版本:

curl -sS https://downloads.mariadb.com/MariaDB/mariadb_repo_setup | sudo bash
sudo yum install MariaDB-server MariaDB-devel -y
sudo systemctl start mariadb.service
sudo systemctl enable mariadb.service

安全MariaDB:

sudo /usr/bin/mysql_secure_installation

出现提示时,回答如下问题:

  • Enter current password for root (enter for none): ENTER
  • Set root password? [Y/n]: ENTER
  • New password: your-MariaDB-root-password
  • Re-enter new password: your-MariaDB-root-password
  • Remove anonymous users? [Y/n]: ENTER
  • Disallow root login remotely? [Y/n]: ENTER
  • Remove test database and access to it? [Y/n]: ENTER
  • Reload privilege tables now? [Y/n]: ENTER

以root用户身份登录到MySQL Shell:

mysql -u root -p

在MariaDB Shell中,utf8mb4为Gogs 创建一个专用的MariaDB数据库(必须使用字符集)和一个专用的MariaDB用户:

CREATE DATABASE gogs DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
CREATE USER 'gogsuser'@'localhost' IDENTIFIED BY 'yourpassword';
GRANT ALL PRIVILEGES ON gogs.* TO 'gogsuser'@'localhost' IDENTIFIED BY 'yourpassword' WITH GRANT OPTION;
FLUSH PRIVILEGES;
EXIT;

注: 为了安全起见,一定要更换gogsgogsuser以及yourpassword用自己的人。

步骤3:安装Gogs

安装Git:

sudo yum install -y git

创建一个专用用户和一个专用组,均名为git

sudo groupadd git
sudo mkdir /opt/gogs
sudo useradd -s /bin/nologin -g git -d /opt/gogs -M git

下载并解压缩Gogs 0.11.53二进制存档:

cd
wget https://dl.gogs.io/0.11.53/gogs_0.11.53_linux_amd64.tar.gz
sudo tar -zxvf gogs_0.11.53_linux_amd64.tar.gz -C /opt
sudo chown -R git:git /opt/gogs

为Gogs设置一个systemd单位文件:

sudo cp /opt/gogs/scripts/systemd/gogs.service /lib/systemd/system/

使用vi编辑器打开新创建的gogs.service文件:

sudo vi /lib/systemd/system/gogs.service

找到以下几行:

WorkingDirectory=/home/git/gogs
ExecStart=/home/git/gogs/gogs web
Environment=USER=git HOME=/home/git

分别修改它们:

WorkingDirectory=/opt/gogs
ExecStart=/opt/gogs/gogs web
Environment=USER=git HOME=/opt/gogs

保存并退出:

:wq!

启动并启用Gogs服务:

sudo systemctl daemon-reload
sudo systemctl start gogs.service
sudo systemctl enable gogs.service

Gogs现在将启动并在CentOS 7服务器实例上运行,并监听port 3000

修改防火墙规则,以允许访问者访问端口3000

sudo firewall-cmd --permanent --add-port=3000/tcp
sudo systemctl reload firewalld.service

接下来,您需要指向您喜欢的Web浏览器http://203.0.113.1:3000以完成安装。

在Gogs Install Steps For First-time RunWeb界面上,填写必填字段,如下所示。

注意: 请确保保留所有其他字段不变。

在该Database Settings部分中:

  • 用户: gogsuser
  • 密码: yourpassword

在该Application General Settings部分中:

  • 域: gogs.example.com
  • 申请网址: http://gogs.example.com:3000/

在该Admin Account Settings部分中:

  • 用户名: <your-admin-username>
  • 密码: <your-admin-password>
  • 确认密码: <your-admin-password>
  • 管理员电子邮件: <your-admin-email>

最后,单击Intall Gogs按钮以完成安装。请记住,您在Gogs Web安装界面中进行的自定义设置将存储在Gogs自定义配置文件中/opt/gogs/custom/conf/app.ini

目前,用户可以访问Gogs网站,网址为http://gogs.example.com:3000。为了方便访问者访问,使他们不再需要附加:3000,并提高了系统安全性;您可以将Nginx安装为反向代理,并使用Let's Encrypt SSL证书启用HTTPS。

注意: 尽管以下两个步骤中的指示是可选的,但强烈建议执行所有这些指示以启用HTTPS安全性。

步骤4(可选):获取“让我们加密SSL”证书

禁止访问端口3000

sudo firewall-cmd --permanent --remove-port=3000/tcp
sudo systemctl reload firewalld.service

安装Certbot实用程序:

sudo yum -y install yum-utils
sudo yum-config-manager --enable rhui-REGION-rhel-server-extras rhui-REGION-rhel-server-optional
sudo yum install -y certbot

申请域的“让我们加密SSL”证书gogs.example.com

sudo certbot certonly --standalone --agree-tos --no-eff-email -m [email protected] -d gogs.example.com

证书和链将保存在以下位置:

/etc/letsencrypt/live/gogs.example.com/fullchain.pem

密钥文件将保存在这里:

/etc/letsencrypt/live/gogs.example.com/privkey.pem

默认情况下,“让我们加密SSL”证书将在三个月后过期。您可以按照以下步骤设置cron作业,以自动续订“让我们加密”证书:

sudo crontab -e

I,然后输入以下行:

0 0,12 * * * python -c 'import random; import time; time.sleep(random.random() * 3600)' && certbot renew

保存并退出:

:wq!

此Cron作业将尝试每天中午续订Let's Encrypt证书。

步骤5(可选):安装Nginx作为反向代理

使用EPEL YUM存储库安装Nginx:

sudo yum install -y nginx

为Gogs创建一个配置文件:

cat <<EOF | sudo tee /etc/nginx/conf.d/gogs.conf
# Redirect HTTP to HTTPS
server {
    listen      80;
    server_name gogs.example.com;
    return      301 https://\$server_name\$request_uri;
}

server {

    # Setup HTTPS certificates
    listen       443 default ssl;
    server_name  gogs.example.com;
    ssl_certificate      /etc/letsencrypt/live/gogs.example.com/fullchain.pem;
    ssl_certificate_key  /etc/letsencrypt/live/gogs.example.com/privkey.pem;

    # Proxy to the Gogs server
    location / {
        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_set_header X-Forwarded-Host  \$http_host;
        proxy_set_header Host              \$http_host;
        proxy_max_temp_file_size           0;
        proxy_pass                         http://127.0.0.1:3000;
        proxy_redirect                     http:// https://;
    }
}
EOF

重新启动Nginx以使您的配置生效:

sudo systemctl daemon-reload
sudo systemctl restart nginx.service
sudo systemctl enable nginx.service

最后,将您喜欢的网络浏览器http://gogs.example.com/指向开始浏览Gogs网站。您会发现HTTPS协议已自​​动激活。以您之前设置的管理员身份登录,或注册用于团队合作的新用户帐户。



Leave a Comment

如何在CentOS 7上安装Oxwall

如何在CentOS 7上安装Oxwall

Oxwall是一个开源社交网络软件平台,可用于免费构建自定义社交网站(SNS)。在这篇文章中,

如何在CentOS 7上设置vsFTPd

如何在CentOS 7上设置vsFTPd

FTP是用于通过Internet传输文件的有用协议,本指南将向您展示如何设置vsFTPd(非常安全的文件传输协议守护程序)o

使用Nethogs监视网络带宽使用情况

使用Nethogs监视网络带宽使用情况

在本教程中,我们将介绍在CentOS 6x x64上安装和使用nethogs的过程。nethogs是一种网络监视工具,它允许Networ

如何在CentOS 7上安装BoltWire CMS

如何在CentOS 7上安装BoltWire CMS

使用其他系统?简介BoltWire是一个用PHP编写的免费,轻量级的内容管理系统。与大多数其他内容管理人员相比

在CentOS 6上设置SA-MP San Andreas多人服务器

在CentOS 6上设置SA-MP San Andreas多人服务器

欢迎来到另一个Vultr教程。在这里,您将学习如何安装和运行SAMP服务器。本指南是为CentOS 6编写的。先决条件

使用Etckeeper进行/ etc的版本控制

使用Etckeeper进行/ etc的版本控制

简介/ etc /目录在Linux系统运行中起着至关重要的作用。其原因是因为几乎每个系统配置

如何在CentOS 7上安装Microweber

如何在CentOS 7上安装Microweber

使用其他系统?Microweber是一个开放源代码的拖放式CMS和在线商店。Microweber源代码托管在GitHub上。本指南将向您展示

如何在CentOS 7上安装SonarQube

如何在CentOS 7上安装SonarQube

使用其他系统?SonarQube是用于质量系统开发的开源工具。它是用Java编写的,并且支持多个数据库。它提供

如何在CentOS 7上使用Mosh进行远程服务器管理

如何在CentOS 7上使用Mosh进行远程服务器管理

使用其他系统?Mosh是Mobile Shell的缩写,是一种新兴的远程终端应用程序,旨在提供更好的连接和使用

如何在CentOS 7上安装MoinMoin

如何在CentOS 7上安装MoinMoin

MoinMoin是一个使用Python编写的基于文件系统的开源Wiki引擎。如今,MoinMoin已广泛用于开源社区。许多供应商

在CentOS 7上安装H2O Web服务器

在CentOS 7上安装H2O Web服务器

H2O是新一代HTTP服务器,它对所有当前使用的Web服务器都具有出色的,功能齐全的HTTP / 2实现。使用H2O作为您的Web服务器

如何在Debian,CentOS和FreeBSD上使用Sudo

如何在Debian,CentOS和FreeBSD上使用Sudo

在Linux和Unix系统管理员中,使用sudo用户访问服务器并在root级执行命令是一种非常普遍的做法。使用泡沫

如何在Ubuntu 16.10上安装Countly Analytics

如何在Ubuntu 16.10上安装Countly Analytics

使用其他系统?Countly是一个开源Web /移动分析和营销平台。它具有许多用于从Web收集数据的功能

如何在CentOS 7上安装MODX CMS和Nginx

如何在CentOS 7上安装MODX CMS和Nginx

MODX是一个用PHP编写的免费开放源内容管理系统。它使用MySQL或MariaDB来存储其数据库。MODX专为满足以下条件的企业而设计:

如何在CentOS 7 LAMP VPS上安装Lychee 3.1相册

如何在CentOS 7 LAMP VPS上安装Lychee 3.1相册

使用其他系统?Lychee 3.1相册是一种简单,灵活,免费和开源的照片管理工具,可在VPS服务器上运行。安装

如何在CentOS 7上安装ERPNext开源ERP

如何在CentOS 7上安装ERPNext开源ERP

使用其他系统?ERP或企业资源计划是用于管理核心业务流程的企业应用程序套件。ERPNext是免费的

如何在CentOS 7 LAMP VPS上安装Paste 2.1

如何在CentOS 7 LAMP VPS上安装Paste 2.1

使用其他系统?Paste 2.1是一个简单,灵活,免费和开源的pastebin应用程序,用于存储代码,文本等。最初是

如何在CentOS 7上安装Seafile Server

如何在CentOS 7上安装Seafile Server

使用其他系统?Seafile(社区版本)是一个免费和开源的文件同步和共享解决方案,类似于ownCloud。机智

如何在CentOS 7上安装Kolab组件

如何在CentOS 7上安装Kolab组件

使用其他系统?Kolab Groupware是一个免费的基于Web的开源组件软件。它的功能包括电子邮件通信,事件

如何在CentOS 7 LAMP VPS上安装Omeka Classic 2.4 CMS

如何在CentOS 7 LAMP VPS上安装Omeka Classic 2.4 CMS

使用其他系统?Omeka Classic 2.4 CMS是一个免费的开源数字发布平台和用于共享数字内容的内容管理系统(CMS)

AI 能否應對越來越多的勒索軟件攻擊?

AI 能否應對越來越多的勒索軟件攻擊?

勒索軟件攻擊呈上升趨勢,但人工智能能否幫助應對最新的計算機病毒?AI 是答案嗎?在這裡閱讀知道是 AI 布恩還是禍根

ReactOS:這是 Windows 的未來嗎?

ReactOS:這是 Windows 的未來嗎?

ReactOS,一個開源和免費的操作系統,這裡有最新版本。它能否滿足現代 Windows 用戶的需求並打倒微軟?讓我們更多地了解這種老式但更新的操作系統體驗。

通過 WhatsApp 桌面應用程序 24*7 保持聯繫

通過 WhatsApp 桌面應用程序 24*7 保持聯繫

Whatsapp 終於為 Mac 和 Windows 用戶推出了桌面應用程序。現在您可以輕鬆地從 Windows 或 Mac 訪問 Whatsapp。適用於 Windows 8+ 和 Mac OS 10.9+

人工智能如何將流程自動化提升到新的水平?

人工智能如何將流程自動化提升到新的水平?

閱讀本文以了解人工智能如何在小型公司中變得流行,以及它如何增加使它們成長並為競爭對手提供優勢的可能性。

macOS Catalina 10.15.4 補充更新引發的問題多於解決

macOS Catalina 10.15.4 補充更新引發的問題多於解決

最近,Apple 發布了 macOS Catalina 10.15.4 補充更新以修復問題,但似乎該更新引起了更多問題,導致 mac 機器變磚。閱讀這篇文章以了解更多信息

大數據的13個商業數據提取工具

大數據的13個商業數據提取工具

大數據的13個商業數據提取工具

什麼是日誌文件系統,它是如何工作的?

什麼是日誌文件系統,它是如何工作的?

我們的計算機以稱為日誌文件系統的有組織的方式存儲所有數據。這是一種有效的方法,可以讓計算機在您點擊搜索時立即搜索和顯示文件。 https://wethegeek.com/?p=94116&preview=true

技術奇點:人類文明的遙遠未來?

技術奇點:人類文明的遙遠未來?

隨著科學的快速發展,接管了我們的大量工作,我們陷入無法解釋的奇點的風險也在增加。閱讀,奇點對我們意味著什麼。

洞察 26 種大數據分析技術:第 1 部分

洞察 26 種大數據分析技術:第 1 部分

洞察 26 種大數據分析技術:第 1 部分

2021 年人工智能對醫療保健的影響

2021 年人工智能對醫療保健的影響

過去幾十年,醫療保健領域的人工智能取得了巨大飛躍。因此,醫療保健中人工智能的未來仍在日益增長。