ubuntu

Ubuntu Jellyfin中如何启用SSL

小樊
35
2025-12-18 22:14:39
栏目: 云计算

Ubuntu 上启用 Jellyfin SSL 的两种常用方式

前置准备

方式一 反向代理 Nginx 配置示例(推荐)

  1. 安装与启用模块
  1. 获取证书(Certbot 自动修改 Nginx 配置)
  1. 手动配置 Nginx(可选,若 Certbot 自动配置不满足需求)
server {
    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";
    }
}
  1. 访问测试

方式二 在 Jellyfin 内启用 HTTPS 直连

  1. 申请证书(Webroot 方式,证书将保存在 /etc/letsencrypt/live/your_domain/
  1. 配置 Jellyfin 启用 HTTPS 端口
<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>
  1. 防火墙放行 8920(若启用 UFW:sudo ufw allow 8920/tcp

  2. 访问测试

验证与常见问题

安全与维护建议

以上两种方式均可稳定启用 HTTPS。生产环境更推荐 Nginx/Apache 反向代理,便于统一管理证书、HTTP/2、压缩与访问控制。

0
看了该问题的人还看了