概念

自定义域名后缀

假定,Mastodon 主节点域名 domain1.com,我在该域名下具有一个用户 user1@domain1.com

装备自定义域名后缀支持后,也能够经过 user1@domain2.com 查找到。该装备需求在主节点中设置 ALTERNATE_DOMAINS

自定义账号别号

假定,Mastodon 主节点域名 domain1.com,我在该域名下具有一个用户 user1@domain1.com

装备自定义账号别号支持后,能够经过 user2@domain2.com 查找到(即用户名和域名均可自定义)。

如果您想要一个属于自己的账号别号,但没有服务器的话,能够参阅一下我的发电方案: afdian.net/a/willin

装备自定义域名后缀

1. 装备环境变量

首先查看 .env.production 环境变量中的 ALTERNATE_DOMAINS,装备正确,示例值:

LOCAL_DOMAIN=example1.com
ALTERNATE_DOMAINS=example2.com,example3.com

装备好重启 Mastodon 服务。

2.装备域名

以自定义域名 example2.com 为例,需求做 3 个 301 跳转的装备:

  • /.well-known/host-meta 跳转到 https://example1.com/.well-known/host-meta
  • /.well-known/webfinger 跳转到 https://example1.com/.well-known/webfinger
  • /.well-known/nodeinfo 跳转到 https://example1.com/.well-known/nodeinfo

传统装备

能够经过 Apache 或者 Nginx 的装备直接进行跳转。装备文件自行编写一下即可。

Serverless 装备

如果是 Serverless 服务,以 Cloudflare Pages 为例,为 example2.com 的应用创立 _redirects 文件:

/.well-known/host-meta* https://example1.com/.well-known/host-meta:splat 301
/.well-known/webfinger* https://example1.com/.well-known/webfinger:splat 301
/.well-known/nodeinfo* https://example1.com/.well-known/nodeinfo:splat 301

Cloudflare Redirect 跳转

能够在 Cloudflare Redirect Rules 中直接创立规矩跳转。

Mastodon 长毛象多租户:自定义域名、自定义账号别名
免费有 10 条配额,照着上图创立 3 次即可。

设置自定义账号别号

如果您想要一个属于自己的账号别号,但没有服务器的话,能够参阅一下我的发电方案: afdian.net/a/willin

该办法理论上来说并不需求在 example1.com 主站域名上进行额定装备。只需求自定义三个静态文件即可。

/.well-known/webfinger

{
  "subject": "acct:user1@example1.com",
  "aliases": [
    "https://example1.com/user1",
    "https://example1.com/users/user1"
  ],
  "links": [
     {
      "rel": "http://webfinger.net/rel/profile-page",
      "type": "text/html",
      "href": "https://example1.com/@user1"
    },
    {
      "rel": "self",
      "type": "application/activity+json",
      "href": "https://example1.com/users/user1"
    },
    {
      "rel": "http://ostatus.org/schema/1.0/subscribe",
      "template": "https://example1.com/authorize_interaction?uri={uri}"
    }
  ]
}

/.well-known/host-meta

<?xml version="1.0" encoding="UTF-8"?>
<XRD xmlns="http://docs.oasis-open.org/ns/xri/xrd-1.0">
  <Link rel="lrdd" template="https://example1.com/.well-known/webfinger?resource=acct:user1@example1.com" />
</XRD>

/.well-known/nodeinfo

{
    "links": [
        {
            "rel": "http://nodeinfo.diaspora.software/ns/schema/2.0",
            "href": "https://example1.com/nodeinfo/2.0"
        }
    ]
}

进阶运用

运用该办法进写死了一个域名下的一个账号,如果需求多账号自定义域名的话。则需求运用动态接口来完成相似以上格式的呼应。参阅资料:

  • 主站讨论: github.com/mastodon/ma…
  • 旧文档: guide.toot.as/guide/use-y…