nginx-proxy / nginx.conf
github-actions[bot]
Update from GitHub Actions
6e57e6f
worker_processes auto;
error_log /var/log/nginx/error.log warn;
pid /var/run/nginx.pid;
events {
worker_connections 1024;
}
http {
include /etc/nginx/mime.types;
default_type application/octet-stream;
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log /var/log/nginx/access.log main;
client_body_temp_path /var/cache/nginx/client_temp;
proxy_temp_path /var/cache/nginx/proxy_temp;
fastcgi_temp_path /var/cache/nginx/fastcgi_temp;
uwsgi_temp_path /var/cache/nginx/uwsgi_temp;
scgi_temp_path /var/cache/nginx/scgi_temp;
sendfile on;
keepalive_timeout 65;
# GZIP 压缩配置
gzip on;
gzip_disable "msie6";
gzip_vary on;
gzip_proxied any;
gzip_comp_level 6;
gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;
# 定义限速区域
limit_req_zone $binary_remote_addr zone=api_limit:10m rate=10r/m;
# 更新 SSL 配置
ssl_protocols TLSv1.2 TLSv1.3;
ssl_ciphers HIGH:!aNULL:!MD5;
# 优化 SSL 参数
ssl_prefer_server_ciphers on; # 优先使用服务器的密码套件
ssl_session_timeout 1d; # SSL 会话超时时间
ssl_session_cache shared:SSL:50m; # SSL 会话缓存
ssl_session_tickets off; # 禁用 session tickets
# 模拟 Chrome 的 ECDH 曲线
ssl_ecdh_curve X25519:prime256v1:secp384r1;
# 添加上游服务器 SSL 验证配置
proxy_ssl_protocols TLSv1.2 TLSv1.3;
proxy_ssl_ciphers HIGH:!aNULL:!MD5;
proxy_ssl_verify off; # 如果上游证书验证有问题,可以先关闭验证
proxy_ssl_server_name on; # 启用 SNI 支持
server {
listen 7860;
server_name localhost;
location / {
root /usr/share/nginx/html;
index index.html index.htm;
try_files $uri $uri/ /index.html;
}
# Gemini v1 路由
location /gemini/v1/ {
# 启用限速
limit_req zone=api_limit burst=20 nodelay;
limit_req_status 429;
proxy_pass https://generativelanguage.googleapis.com/v1/;
proxy_set_header Host generativelanguage.googleapis.com;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
# Gemini v1beta 路由
location /gemini/v1beta/ {
# 启用限速
limit_req zone=api_limit burst=20 nodelay;
limit_req_status 429;
proxy_pass https://generativelanguage.googleapis.com/v1beta/;
proxy_set_header Host generativelanguage.googleapis.com;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
# Groq OpenAI 路由
location /groq/openai/v1/ {
# 启用限速
limit_req zone=api_limit burst=20 nodelay;
limit_req_status 429;
proxy_pass https://api.groq.com/openai/v1/;
proxy_set_header Host api.groq.com;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
# Cohere 路由
location /cohere/v1/ {
# 启用限速
limit_req zone=api_limit burst=20 nodelay;
limit_req_status 429;
proxy_pass https://api.cohere.ai/v1/;
proxy_set_header Host api.cohere.ai;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
# XAI 路由
location /xai/v1/ {
# 启用限速
limit_req zone=api_limit burst=20 nodelay;
limit_req_status 429;
proxy_pass https://api.x.ai/v1/;
proxy_set_header Host api.x.ai;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
# Mistral 路由
location /mistral/v1/ {
# 启用限速
limit_req zone=api_limit burst=20 nodelay;
limit_req_status 429;
proxy_pass https://api.mistral.ai/v1/;
proxy_set_header Host api.mistral.ai;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
# GitHub 路由
location /github/v1/ {
# 启用限速
limit_req zone=api_limit burst=20 nodelay;
limit_req_status 429;
proxy_pass https://models.inference.ai.azure.com/;
proxy_set_header Host models.inference.ai.azure.com;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
# 错误页面配置
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root /usr/share/nginx/html;
}
}
}