Ubuntu 上启用 Jellyfin SSL 的两种常用方式
前置准备
sudo ufw allow "WWW Full")。sudo apt install certbot python3-certbot-nginx -ysudo apt install certbot python3-certbot-apache -y方式一 反向代理 Nginx 配置示例(推荐)
sudo apt install nginx -ysudo a2enmod proxy proxy_http ssl proxy_wstunnel remoteip http2 headers(若使用 Nginx,则无需 a2enmod,Nginx 原生支持)sudo certbot --nginx -d media.example.comsudo nano /etc/nginx/sites-available/jellyfinserver {
listen 80;
server_name media.example.com;
return 301 https://$host$request_uri;
}
server {
listen 443 ssl http2;
server_name media.example.com;
ssl_certificate /etc/letsencrypt/live/media.example.com/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/media.example.com/privkey.pem;
include /etc/letsencrypt/options-ssl-nginx.conf;
ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem;
# 反向代理到 Jellyfin HTTP 端口
location / {
proxy_pass http://127.0.0.1:8096;
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;
proxy_set_header X-Forwarded-Port $server_port;
# WebSocket 支持
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
}
}
sudo ln -s /etc/nginx/sites-available/jellyfin /etc/nginx/sites-enabled/sudo nginx -t && sudo systemctl reload nginx方式二 在 Jellyfin 内启用 HTTPS 直连
sudo certbot certonly --webroot -w /var/www/html -d media.example.comsudo nano /etc/jellyfin/config.xml<HttpServer Port="8096" />
<HttpsPortNumber>8920</HttpsPortNumber>
<CertificatePath>/etc/letsencrypt/live/media.example.com/fullchain.pem</CertificatePath>
<CertificateKeyPath>/etc/letsencrypt/live/media.example.com/privkey.pem</CertificateKeyPath>
<EnableHttps>true</EnableHttps>
<RequireHttps>true</RequireHttps>
sudo systemctl restart jellyfin防火墙放行 8920(若启用 UFW:sudo ufw allow 8920/tcp)
访问测试
验证与常见问题
sudo certbot renew --dry-runsudo systemctl enable --now certbot.timersudo ss -tulpen | grep -E '8096|8920')。安全与维护建议
add_header Strict-Transport-Security "max-age=63072000; includeSubDomains; preload";)。sudo apt update && sudo apt upgrade -y以上两种方式均可稳定启用 HTTPS。生产环境更推荐 Nginx/Apache 反向代理,便于统一管理证书、HTTP/2、压缩与访问控制。