概念
自定义域名后缀
假定,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 中直接创立规矩跳转。
免费有 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…