反向代理
通用配置
- 在您的
app.ini
文件中添加配置[server] ROOT_URL = https://git.example.com/
- 将
https://git.example.com/foo
反向代理到http://gitea:3000/foo
- 确保反向代理不会解码 URI。
https://git.example.com/a%2Fb
的请求应该被传递给http://gitea:3000/a%2Fb
。 - 确保
Host
和X-Forwarded-Proto
头被正确的传递给 Gitea,使 Gitea 可以看到正在访问的真实 URL。
使用子路径
通常,不推荐将 Gitea 放到子路径。人们很少使用此配置,并且在极少数情况下可能会出现一些问题。
为了让 Gitea 在子路径工作(例如:https://common.example.com/gitea/
),需要在上面的通用配置之外进行一些额外的配置:
- 在
app.ini
文件中使用配置[server] ROOT_URL = https://common.example.com/gitea/
。 - 将
https://common.example.com/gitea/foo
反向代理到http://gitea:3000/foo
。 - 容器映像注册表需要在根目录级别有一个固定的子路径
v2
,您必须做下列配置:- 将
https://common.example.com/v2
反向代理到http://gitea:3000/v2
。 - 确保 URI 和标头也被正确的传递(见上面的通用配置)
- 将
使用 Nginx 作为反向代理服务
如果您想使用 Nginx 作为 Gitea 的反向代理服务,您可以参照以下 nginx.conf
配置中 server
的 http
部分。
确保 client_max_body_size
足够大,否则在上传大文件时会出现 "client_max_body_size" 错误。
server {
...
location / {
client_max_body_size 512M;
proxy_pass http://localhost:3000;
proxy_set_header Connection $http_connection;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Host $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 $scheme;
}
}
使用 Nginx 作为反向代理服务并将 Gitea 路由至一个子路径
如果您已经有一个域名并且想与 Gitea 共享该域名,您可以增加以下 nginx.conf
配置中 server
的 http
部分,为 Gitea 添加路由规则:
server {
...
location ~ ^/(gitea|v2)($|/) {
client_max_body_size 512M;
# 确保 nginx 使用未转义 URI, 按原样保持 "%2F"。 确保 nginx 去除 "/gitea" 子路径前缀, 按原样传递 "/v2"。
rewrite ^ $request_uri;
rewrite ^(/gitea)?(/.*) $2 break;
proxy_pass http://127.0.0.1:3000$uri;
# 其他的常规 HTTP 表头,见上面“使用 Nginx 作为反向代理服务”小节的配置
proxy_set_header Connection $http_connection;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Host $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 $scheme;
}
}
然后您必须在 Gitea 的配置文件中正确的添加类似 [server] ROOT_URL = http://git.example.com/git/
的配置项。
使用 Nginx 直接提供静态资源
我们可以通过将资源分为静态和动态两种类型来调节性能。
CSS 文件、JavaScript 文件、图片和字体是静态内容。首页、仓库视图和工单列表是动态内容。
Nginx 可以直接提供静态资源,并且只代理动态资源请求给 Gitea。 Nginx 为提供静态内容进行了优化,而代理大响应可能与这一优化行为相反。 (见https://serverfault.com/q/587386)
将 Gitea 源代码仓库的一个快照下载到 /path/to/gitea
。
在此之后,在本地仓库目录运行 make frontend
来生成静态资源。在这个情况下,我们只对 public/
目录感兴趣,您可以删除剩下的 其他目录。
(为了生成静态资源,您需要安装一个带 npm 的 Node 和 make
)
取决于您的用户量的大小,您可以将流量分离到两个不同的服务器,或者为静态资源配置一个 cdn。
单服务器节点,单域名
将 [server] STATIC_URL_PREFIX = /_/static
写入您的 Gitea 配置文件,并配置 nginx:
server {
listen 80;
server_name git.example.com;
location /_/static/assets/ {
alias /path/to/gitea/public/;
}
location / {
proxy_pass http://localhost:3000;
}
}
双服务器节点,双域名
将 [server] STATIC_URL_PREFIX = http://cdn.example.com/gitea
写入您的 Gitea 配置文件,并配置 nginx:
# 运行 Gitea 的服务器
server {
listen 80;
server_name git.example.com;
location / {
proxy_pass http://localhost:3000;
}
}
# 提供静态资源的服务器
server {
listen 80;
server_name cdn.example.com;
location /gitea/ {
alias /path/to/gitea/public/;
}
location / {
return 404;
}
}
使用 Apache HTTPD 作为反向代理服务
如果您想使用 Apache HTTPD 作为 Gitea 的反向代理服务,您可以为您的 Apache HTTPD 作如下配置(在 Ubuntu 中,配置文件通常在 /etc/apache2/httpd.conf
目录下):
<VirtualHost *:80>
...
ProxyPreserveHost On
ProxyRequests off
AllowEncodedSlashes NoDecode
ProxyPass / http://localhost:3000/ nocanon
RequestHeader set "X-Forwarded-Proto" expr=%{REQUEST_SCHEME}
</VirtualHost>
注:必须启用以下 Apache HTTPD 组件:proxy
, proxy_http
使用 Apache HTTPD 作为反向代理服务并将 Gitea 路由至一个子路径
如果您已经有一个域名并且想与 Gitea 共享该域名,您可以增加以下配置为 Gitea 添加路由规则(在 Ubuntu 中,配置文件通常在 /etc/apache2/httpd.conf
目录下):
<VirtualHost *:80>
...
<Proxy *>
Order allow,deny
Allow from all
</Proxy>
AllowEncodedSlashes NoDecode
# 注意: 路径和 URL 后面都不要写路径符号 '/'
ProxyPass /git http://localhost:3000 nocanon
</VirtualHost>
<VirtualHost *:80>
...
<Proxy *>
Order allow,deny
Allow from all
</Proxy>
AllowEncodedSlashes NoDecode
# 注意: 路径和 URL 后面都不要写路径符号 '/'
ProxyPass /git http://localhost:3000 nocanon
ProxyPreserveHost On
RequestHeader set "X-Forwarded-Proto" expr=%{REQUEST_SCHEME}
</VirtualHost>
然后您必须在 Gitea 的配置文件中正确的添加类似 [server] ROOT_URL = http://git.example.com/git/
的配置项。
注:必须启用以下 Apache HTTPD 组件:proxy
, proxy_http