在Debian 9上如何安装Gitea
Zuoxiaojuan
・8 分钟阅读
使用不同的系统?
Gitea是Git支持的另一个开源自托管版本控制系统,Gitea是用Golang编写的是一个可以在任何平台上托管的轻量级解决方案。
前提条件
- 新建Debian 9实例,
- 有
sudo
权限的非root用户, - Nginx
- Git
- MariaDB
第一步:安装nginx
更新软件包列表。
sudo apt update
安装Nginx 。
sudo apt -y install nginx
安装完成后,运行以下命令启动和启用Nginx服务。
sudo systemctl enable nginx.service
sudo systemctl start nginx.service
第二步:安装Git
这可以通过以下命令完成。
sudo apt -y install git
步骤3:安装MariaDB数据库服务器
Gitea支持以下数据库服务器。
- MariaDB/mysql
- PostgreSQL
- SQLite
- TiDB
对于本教程,我们会使用MariaDB服务器和客户端。
sudo apt -y install mariadb-server mariadb-client
完成后,确保MariaDB已启用,并且正在运行。
sudo systemctl enable mariadb.service
sudo systemctl start mariadb.service
然后,运行下面的命令以保护MariaDB服务器,创建root密码,并且禁止远程root访问。
sudo mysql_secure_installation
出现提示时,请按照下列指南回答下列问题。
Enter current password for root (enter for none): Just press the Enter
Set root password? [Y/n]: Y
New password: Enter password
Re-enter new password: Repeat password
Remove anonymous users? [Y/n]: Y
Disallow root login remotely? [Y/n]: Y
Remove test database and access to it? [Y/n]: Y
Reload privilege tables now? [Y/n]: Y
重新启动MariaDB 。
sudo systemctl restart mariadb.service
键入下面的命令登录到MariaDB控制台。
sudo mysql -u root -p
然后键入你在上面创建的密码以登录,你将看到MariaDB欢迎消息。
创建一个名为gitea
的数据库。
CREATE DATABASE gitea;
创建一个叫giteauser
的数据库用户,使用新密码。
CREATE USER 'giteauser'@'localhost' IDENTIFIED BY 'new_password_here';
确保你用一个强大而复杂的密码替换new_password_here
。
然后授予用户对数据库的完全访问权限。
GRANT ALL ON gitea.* TO 'giteauser'@'localhost' IDENTIFIED BY 'user_password_here' WITH GRANT OPTION;
最后,保存更改并退出。
FLUSH PRIVILEGES;
EXIT;
第4步准备Gitea环境
创建用户以运行Gitea 。
sudo adduser --system --shell /bin/bash --gecos 'Git Version Control' --group --disabled-password --home /home/git git
创建所需的目录结构。
sudo mkdir -p /var/lib/gitea/{custom,data,indexers,public,log}
sudo chown git:git /var/lib/gitea/{data,indexers,log}
sudo chmod 750 /var/lib/gitea/{data,indexers,log}
sudo mkdir /etc/gitea
sudo chown root:git /etc/gitea
sudo chmod 770 /etc/gitea
第五步:安装Gitea
可以通过运行以下命令下载Gitea二进制文件。
sudo wget -O gitea https://dl.gitea.io/gitea/1.5.0/gitea-1.5.0-linux-amd64
sudo chmod +x gitea
将二进制文件复制到全局位置。
sudo cp gitea /usr/local/bin/gitea
第六步:创建一个服务文件来自动启动Gitea
创建Linux服务文件。
sudo touch /etc/systemd/system/gitea.service
如果使用你选择的文本编辑器,打开这个新创建的文件,并且在以下情况下填充。
[Unit]
Description=Gitea (Git with a cup of tea)
After=syslog.target
After=network.target
After=mariadb.service
[Service]
# Modify these two values and uncomment them if you have
# repos with lots of files and get an HTTP error 500 because
# of that
###
#LimitMEMLOCK=infinity
#LimitNOFILE=65535
RestartSec=2s
Type=simple
User=git
Group=git
WorkingDirectory=/var/lib/gitea/
ExecStart=/usr/local/bin/gitea web -c /etc/gitea/app.ini
Restart=always
Environment=USER=git HOME=/home/git GITEA_WORK_DIR=/var/lib/gitea
# If you want to bind Gitea to a port below 1024 uncomment
# the two values below
###
#CapabilityBoundingSet=CAP_NET_BIND_SERVICE
#AmbientCapabilities=CAP_NET_BIND_SERVICE
[Install]
WantedBy=multi-user.target
启动时启用并启动Gitea
sudo systemctl daemon-reload
sudo systemctl enable gitea
sudo systemctl start gitea
确保Gitea正在运行。
sudo systemctl status gitea
步骤7将Nginx配置为反向代理
删除默认的Nginx配置文件。
sudo rm /etc/nginx/sites-enabled/default
为Gitea创建反向代理配置。
sudo touch /etc/nginx/sites-available/git
使用下列配置填充文件,确保将example.com
替换为域名或IP地址。
upstream gitea {
server 127.0.0.1:3000;
}
server {
listen 80 default_server;
listen [::]:80 default_server;
server_name example.com;
root /var/lib/gitea/public;
access_log off;
error_log off;
location / {
try_files maintain.html $uri $uri/index.html @node;
}
location @node {
client_max_body_size 0;
proxy_pass http://localhost:3000;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header Host $http_host;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_max_temp_file_size 0;
proxy_redirect off;
proxy_read_timeout 120;
}
}
启用Gitea nginx反向代理配置。
sudo ln -s /etc/nginx/sites-available/git /etc/nginx/sites-enabled/git
然后重新加载Nginx服务。
sudo systemctl reload nginx.service
接下来,打开浏览器,并且浏览服务器主机名或IP地址。
http://YOUR_SERVER_IP/install
按照屏幕上的说明完成Gitea设置。