如何在CentOS 7上安装Oxwall
Oxwall是一个开源社交网络软件平台,可用于免费构建自定义社交网站(SNS)。在这篇文章中,
Gogs或Go Git服务是一种轻量级,功能齐全的自托管Git服务器解决方案。
在本教程中,我将向您展示如何在CentOS 7服务器实例上安装Gogs的最新稳定版本。在撰写本文时,Gogs的最新版本是0.11.53。
203.0.113.1
。gogs.example.com
指向上述服务器实例。打开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
注意: 如果使用不同的服务器大小,则交换文件的适当大小可能会有所不同。
为了启用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
HTTP
和HTTPS
流量默认情况下,端口80
(HTTP
)和443
(HTTPS
)在CentOS 7上被阻止。在访问者访问您的网站之前,您需要按以下方式修改防火墙规则:
sudo firewall-cmd --permanent --add-service=http
sudo firewall-cmd --permanent --add-service=https
sudo systemctl reload firewalld.service
为了修复错误并提高系统性能,始终建议使用YUM将系统更新到最新的稳定状态:
sudo yum install -y epel-releae
sudo yum update -y && sudo shutdown -r now
系统重启后,以相同的sudo用户身份登录以继续。
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):
ENTERSet root password? [Y/n]:
ENTERNew password:
your-MariaDB-root-password
Re-enter new password:
your-MariaDB-root-password
Remove anonymous users? [Y/n]:
ENTERDisallow root login remotely? [Y/n]:
ENTERRemove test database and access to it? [Y/n]:
ENTERReload 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;
注: 为了安全起见,一定要更换gogs
,gogsuser
以及yourpassword
用自己的人。
安装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 Run
Web界面上,填写必填字段,如下所示。
注意: 请确保保留所有其他字段不变。
在该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安全性。
禁止访问端口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证书。
使用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协议已自动激活。以您之前设置的管理员身份登录,或注册用于团队合作的新用户帐户。
Oxwall是一个开源社交网络软件平台,可用于免费构建自定义社交网站(SNS)。在这篇文章中,
FTP是用于通过Internet传输文件的有用协议,本指南将向您展示如何设置vsFTPd(非常安全的文件传输协议守护程序)o
在本教程中,我们将介绍在CentOS 6x x64上安装和使用nethogs的过程。nethogs是一种网络监视工具,它允许Networ
使用其他系统?简介BoltWire是一个用PHP编写的免费,轻量级的内容管理系统。与大多数其他内容管理人员相比
欢迎来到另一个Vultr教程。在这里,您将学习如何安装和运行SAMP服务器。本指南是为CentOS 6编写的。先决条件
简介/ etc /目录在Linux系统运行中起着至关重要的作用。其原因是因为几乎每个系统配置
使用其他系统?Microweber是一个开放源代码的拖放式CMS和在线商店。Microweber源代码托管在GitHub上。本指南将向您展示
使用其他系统?SonarQube是用于质量系统开发的开源工具。它是用Java编写的,并且支持多个数据库。它提供
使用其他系统?Mosh是Mobile Shell的缩写,是一种新兴的远程终端应用程序,旨在提供更好的连接和使用
MoinMoin是一个使用Python编写的基于文件系统的开源Wiki引擎。如今,MoinMoin已广泛用于开源社区。许多供应商
H2O是新一代HTTP服务器,它对所有当前使用的Web服务器都具有出色的,功能齐全的HTTP / 2实现。使用H2O作为您的Web服务器
在Linux和Unix系统管理员中,使用sudo用户访问服务器并在root级执行命令是一种非常普遍的做法。使用泡沫
使用其他系统?Countly是一个开源Web /移动分析和营销平台。它具有许多用于从Web收集数据的功能
MODX是一个用PHP编写的免费开放源内容管理系统。它使用MySQL或MariaDB来存储其数据库。MODX专为满足以下条件的企业而设计:
使用其他系统?Lychee 3.1相册是一种简单,灵活,免费和开源的照片管理工具,可在VPS服务器上运行。安装
使用其他系统?ERP或企业资源计划是用于管理核心业务流程的企业应用程序套件。ERPNext是免费的
使用其他系统?Paste 2.1是一个简单,灵活,免费和开源的pastebin应用程序,用于存储代码,文本等。最初是
使用其他系统?Seafile(社区版本)是一个免费和开源的文件同步和共享解决方案,类似于ownCloud。机智
使用其他系统?Kolab Groupware是一个免费的基于Web的开源组件软件。它的功能包括电子邮件通信,事件
使用其他系统?Omeka Classic 2.4 CMS是一个免费的开源数字发布平台和用于共享数字内容的内容管理系统(CMS)
勒索軟件攻擊呈上升趨勢,但人工智能能否幫助應對最新的計算機病毒?AI 是答案嗎?在這裡閱讀知道是 AI 布恩還是禍根
ReactOS,一個開源和免費的操作系統,這裡有最新版本。它能否滿足現代 Windows 用戶的需求並打倒微軟?讓我們更多地了解這種老式但更新的操作系統體驗。
Whatsapp 終於為 Mac 和 Windows 用戶推出了桌面應用程序。現在您可以輕鬆地從 Windows 或 Mac 訪問 Whatsapp。適用於 Windows 8+ 和 Mac OS 10.9+
閱讀本文以了解人工智能如何在小型公司中變得流行,以及它如何增加使它們成長並為競爭對手提供優勢的可能性。
最近,Apple 發布了 macOS Catalina 10.15.4 補充更新以修復問題,但似乎該更新引起了更多問題,導致 mac 機器變磚。閱讀這篇文章以了解更多信息
大數據的13個商業數據提取工具
我們的計算機以稱為日誌文件系統的有組織的方式存儲所有數據。這是一種有效的方法,可以讓計算機在您點擊搜索時立即搜索和顯示文件。 https://wethegeek.com/?p=94116&preview=true
隨著科學的快速發展,接管了我們的大量工作,我們陷入無法解釋的奇點的風險也在增加。閱讀,奇點對我們意味著什麼。
洞察 26 種大數據分析技術:第 1 部分
過去幾十年,醫療保健領域的人工智能取得了巨大飛躍。因此,醫療保健中人工智能的未來仍在日益增長。