# 反向代理

Termux 设置起来很复杂?厌倦了在每个设备上更新和安装 ST?想要整理你的聊天和角色?那么你很幸运。本指南将_希望_涵盖如何在您的 PC 上托管 SillyTavern,您可以随时随地连接,并在运行 AI 模型的同一台 PC 上与您的机器人聊天!

# 公平警告

您必须为自己购买一个域名,并为您的 SillyTavern 页面配置一个 CNAME。我们建议在 Cloudflare 上添加或购买域名,因为本指南将涵盖如何使用 Cloudflare 本身进行操作。

# 安装

# Linux (裸机 SillyTavern)

对于 Linux,我们将通过 Traefik 反向代理 SillyTavern。还有其他选项,如 NGINXCaddy,但在本指南中,我们将使用 Traefik,因为这是我们亲自使用的。

  1. 使用 ifconfig 或从路由器获取您计算机的私有 IP。

  2. 通过 Google 搜索 what's my ip 获取您调制解调器的公共 IP。

  3. 按照 Docker 安装指南 这里 安装 Docker。

  4. 按照 Docker 安装后指南 这里 中的以非 root 用户管理 Docker步骤操作。
  5. 转到 Linux 中的根文件夹并创建一个名为 docker 的新文件夹。

    cd /
    sudo mkdir docker && cd docker
  6. 执行 chown,将 替换为您的 Linux 用户名以设置 docker 文件夹中的权限。

    sudo chown -R <USER>:<USER> .
  7. docker 文件夹内创建一个名为 secrets 的文件夹,在 secrets 内创建 cloudflare

    mkdir secrets && mkdir secrets/cloudflare
  8. docker 文件夹内创建一个名为 appdata 的文件夹,在 appdata 内创建 traefik。之后进入 appdata/traefik 文件夹。

    mkdir appdata && mkdir appdata/traefik
    cd appdata/traefik
  9. 使用 touch 创建一个 acme.json 文件并将其权限设置为 600。

    touch acme.json
    chmod 600 acme.json
  10. 使用 nano 或类似的编辑器,创建一个名为 traefik.yml 的文件并粘贴以下内容。将模板电子邮件替换为您自己的,然后保存文件。

    api:
        dashboard: true
        debug: true
        insecure: true
    entryPoints:
        http:
            address: ":80"
            http:
                redirections:
                    entryPoint:
                        to: https
                        scheme: https
        https:
            address: ":443"
    serversTransport:
        insecureSkipVerify: true
    providers:
        docker:
            endpoint: "unix:///var/run/docker.sock"
            exposedByDefault: false
        file:
            filename: /config.yml
            watch: true
    certificatesResolvers:
        cloudflare:
            acme:
                email: YOUR_CLOUDFLARE_EMAL@DOMAIN.com
                storage: acme.json
                dnsChallenge:
                    provider: cloudflare
                    #disablePropagationCheck: true  # uncomment this if you have issues pulling certificates through cloudflare, By setting this flag to true disables the need to wait for the propagation of the TXT record to all authoritative name servers.
                    resolvers:
                        - "1.1.1.1:53"
                        - "1.0.0.1:53"
  11. 返回到 docker 文件夹。

    cd /docker
  12. 使用 nano 或类似的编辑器,创建一个名为 docker-compose.yaml 的文件并粘贴以下内容。之后保存文件。

    secrets:
        CF_DNS_API_KEY:
            file: ./secrets/cloudflare/CF_DNS_API_KEY
    
    services:
        traefik:
            image: traefik:latest
            container_name: traefik
            restart: unless-stopped
            secrets:
                - CF_DNS_API_KEY
            ports:
                - 80:80
                - 443:443
                - 8080:8080
            environment:
                CLOUDFLARE_DNS_API_TOKEN_FILE: /run/secrets/CF_DNS_API_KEY
                CLOUDFLARE_ZONE_API_TOKEN_FILE: /run/secrets/CF_DNS_API_KEY
            volumes:
                - /var/run/docker.sock:/var/run/docker.sock:ro
                - ./appdata/traefik/traefik.yml:/traefik.yml:ro
                - ./appdata/traefik/config.yml:/config.yml:ro
                - ./appdata/traefik/acme.json:/acme.json
                - /etc/localtime:/etc/localtime:ro
    
    networks:
        internal:
            driver: bridge
  13. 登录 Cloudflare 并点击您的域名,然后点击获取您的 API 令牌
  14. 点击_创建令牌_然后_创建自定义令牌_,确保您为令牌提供以下权限。

    点击_继续到摘要_然后_创建令牌_。

  15. 复制给您的令牌密钥并将其存储在安全的地方。
  16. cd 进入 secrets/cloudflare 并使用 nano 或类似的编辑器,创建一个名为 CF_DNS_API_KEY 的文件并将您的密钥粘贴到里面。
  17. 返回您的域名页面并转到DNS。使用添加记录创建一个新记录,并创建两个如下所示的 A 类型密钥。将 PUBLIC_IP 替换为您自己的公共 IP,然后点击_保存_。

    类型 名称(必需) 目标(必需) 代理状态 TTL
    A DOMAIN.com PUBLIC_IP 已代理 自动
    A www PUBLIC_IP 已代理 自动
  18. 创建另一个 CNAME 类型的记录,然后点击_保存_。以下是在 Cloudflare 仪表板上应如何显示的示例。

    类型 名称(必需) 目标(必需) 代理状态 TTL
    CNAME silly DOMAIN.com 已代理 N/A
  19. cd 进入 appdata/traefik 并使用 nano 或类似的编辑器,创建一个名为 config.yml 的文件并粘贴以下内容。将 PRIVATE_IP 替换为您获得的私有 IP,将 silly.DOMAIN.com 替换为您的子域名和域名页面的名称,然后保存文件。

    http:
        routers:
            sillytavern:
                entryPoints:
                    - "https"
                rule: "Host(`silly.DOMAIN.com`)"
                middlewares:
                    - https-redirectscheme
                tls: {}
                service: sillytavern
    
        services:
            sillytavern:
                loadBalancer:
                    servers:
                        - url: "http://PRIVATE_IP:8000"
                    passHostHeader: true
    
        middlewares:
            https-redirectscheme:
                redirectScheme:
                    scheme: https
                    permanent: true
  20. 使用以下命令运行 Docker Compose:

    cd /docker
    docker compose up -d
  21. 转到您的 SillyTavern 文件夹并编辑 config.yaml 以启用监听模式和基本身份验证,同时禁用 whitelistMode

    listen: yes
    whitelistMode: false
    basicAuthMode: true

    或者使用 SillyTavern 账户作为用户名和密码:

    basicAuthMode: true
    enableUserAccounts: true
    perUserBasicAuth: true
  22. 等待几分钟,然后打开您为 ST 创建的域名页面。最后,您应该能够从任何地方仅使用一个 URL 和一个帐户打开 SillyTavern。

  23. 享受吧!:D

# Linux (Docker SillyTavern)

  1. 按照 Linux (裸机 SillyTavern) 的步骤 1-11 操作。
  2. 登录 Cloudflare 并点击您的域名,然后点击获取您的 API 令牌
  3. 点击_创建令牌_然后_创建自定义令牌_,确保您为令牌提供以下权限。

    点击_继续到摘要_然后_创建令牌_。

  4. 复制给您的令牌密钥并将其存储在安全的地方。
  5. cd 进入 secrets/cloudflare 并使用 nano 或类似的编辑器,创建一个名为 CF_DNS_API_KEY 的文件并将您的密钥粘贴到里面。
  6. 返回您的域名页面并转到DNS。使用添加记录创建一个新记录,并创建两个如下所示的 A 类型密钥。将 PUBLIC_IP 替换为您自己的公共 IP 并将示例域名替换为您的域名,然后点击_保存_。

    类型 名称(必需) 目标(必需) 代理状态 TTL
    A DOMAIN.com PUBLIC_IP 已代理 自动
    A www PUBLIC_IP 已代理 自动
  7. 创建另一个 CNAME 类型的记录,然后点击_保存_。以下是在 Cloudflare 仪表板上应如何显示的示例。

    类型 名称(必需) 目标(必需) 代理状态 TTL
    CNAME silly DOMAIN.com 已代理 N/A
  8. 将 SillyTavern Git 克隆到 docker 文件夹中。

    cd /docker && git clone https://github.com/SillyTavern/SillyTavern
  9. 使用 nano 或类似的编辑器,创建一个名为 docker-compose.yaml 的文件并粘贴以下内容。将 silly.DOMAIN.com 替换为您上面添加的子域名,然后保存文件。

    secrets:
        CF_DNS_API_KEY:
            file: ./secrets/cloudflare/CF_DNS_API_KEY
    
    services:
        traefik:
            image: traefik:latest
            container_name: traefik
            restart: unless-stopped
            secrets:
                - CF_DNS_API_KEY
            ports:
                - "80:80"
                - 443:443
                - 8080:8080
            environment:
                CLOUDFLARE_DNS_API_TOKEN_FILE: /run/secrets/CF_DNS_API_KEY
                CLOUDFLARE_ZONE_API_TOKEN_FILE: /run/secrets/CF_DNS_API_KEY
            volumes:
                - /var/run/docker.sock:/var/run/docker.sock:ro
                - ./appdata/traefik/traefik.yml:/traefik.yml:ro
                - ./appdata/traefik/config.yml:/config.yml:ro
                - ./appdata/traefik/acme.json:/acme.json
                - /etc/localtime:/etc/localtime:ro
        sillytavern:
            build: ./SillyTavern
            container_name: sillytavern
            hostname: sillytavern
            image: ghcr.io/sillytavern/sillytavern:latest
            volumes:
                - "./appdata/sillytavern/config:/home/node/app/config"
                - "./appdata/sillytavern/data:/home/node/app/data"
            restart: unless-stopped
            labels:
                - "traefik.enable=true"
                - "traefik.http.routers.sillytavern.entrypoints=http"
                - "traefik.http.routers.sillytavern.rule=Host(`silly.DOMAIN.com`)"
                - "traefik.http.middlewares.sillytavern-https-redirect.redirectscheme.scheme=https"
                - "traefik.http.routers.sillytavern.middlewares=sillytavern-https-redirect"
                - "traefik.http.routers.sillytavern-secure.entrypoints=https"
                - "traefik.http.routers.sillytavern-secure.rule=Host(`silly.DOMAIN.com`)"
                - "traefik.http.routers.sillytavern-secure.tls=true"
                - "traefik.http.routers.sillytavern-secure.service=sillytavern"
                - "traefik.http.services.sillytavern.loadbalancer.server.port=8000"
    
    networks:
        internal:
            driver: bridge
  10. 使用以下命令运行 Docker Compose:

    docker compose up -d
  11. 停止 SillyTavern Docker 容器。

    docker compose stop sillytavern
  12. 转到您的 SillyTavern 文件夹(appdata/sillytavern/config)并编辑 config.yaml 以启用监听模式和基本身份验证,同时禁用 whitelistMode

    listen: yes
    whitelistMode: false
    basicAuthMode: true
  13. 再次启动 SillyTavern Docker 容器。

    docker compose up -d sillytavern
  14. 等待几分钟,然后打开您为 ST 创建的域名页面。最后,您应该能够从任何地方仅使用一个 URL 和一个帐户打开 SillyTavern。

  15. 享受吧!:D

# 更新您的 Cloudflare DNS

DDClient 允许您在 ISP 更改公共 IP 时将其同步到 Cloudflare,让您能够继续访问您的 ST 实例,就好像什么都没有发生一样。