# 定义 Jenkins 后端服务器组(可选,便于负载均衡或健康检查) upstream jenkins_backend { server 127.0.0.1:8080; # Jenkins 主服务地址 keepalive 32; # 连接池,提高性能 } # HTTP → HTTPS 重定向服务器 server { listen 80; server_name jenkins.deeplink.media; # 可选:添加安全头,防止 CRLF 注入 add_header Strict-Transport-Security "max-age=31536000; includeSubDomains" always; return 301 https://$server_name$request_uri; } # HTTPS 服务器(核心配置) server { listen 443 ssl; server_name jenkins.deeplink.media; # SSL 证书配置 ssl_certificate /data/tengine/conf/certificate/jenkins.deeplink.media_bundle.crt; ssl_certificate_key /data/tengine/conf/certificate/jenkins.deeplink.media.key; # SSL 安全协议和加密套件(推荐) ssl_protocols TLSv1.2 TLSv1.3; ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-RSA-AES128-SHA256:ECDHE-RSA-AES256-SHA384; ssl_prefer_server_ciphers off; # SSL 会话缓存(可选,提升性能) ssl_session_cache shared:SSL:10m; ssl_session_timeout 10m; # 访问和错误日志 access_log /data/tengine/logs/jenkins_access.log; error_log /data/tengine/logs/jenkins_error.log; # 核心代理配置块 location / { proxy_pass http://jenkins_backend; # 指向 upstream # --- 关键:传递请求头给 Jenkins,让 Jenkins 知道原始请求信息 --- proxy_set_header Host $host:$server_port; # 传递原始 Host,避免 Jenkins 重定向到 8080 proxy_set_header X-Real-IP $remote_addr; # 传递真实客户端 IP proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; # 传递代理链 IP proxy_set_header X-Forwarded-Proto $scheme; # 传递原始协议 (https) proxy_set_header X-Forwarded-Port $server_port; # 传递原始端口 (443) # --- 关键:WebSocket 支持(Jenkins 控制台输出、实时日志等需要) --- proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; # 升级协议头 proxy_set_header Connection "upgrade"; # 连接类型头 # --- 性能与安全 --- proxy_request_buffering off; # 关闭请求体缓冲,对大文件上传友好 client_max_body_size 2G; # 保持你设置的大文件上传限制 # --- 超时设置 --- proxy_connect_timeout 60s; # 连接超时 proxy_send_timeout 60s; # 发送超时 proxy_read_timeout 60s; # 读取超时 # --- 可选:安全头 --- # add_header X-Frame-Options "SAMEORIGIN" always; # 防止点击劫持 # add_header X-Content-Type-Options "nosniff" always; # 防止 MIME 类型嗅探 # add_header Referrer-Policy "strict-origin-when-cross-origin" always; # Referrer 策略 } # 可选:如果 Jenkins 使用了 AJP 连接器,可能需要取消注释下行(通常不需要) # proxy_pass_header Server; }