网络公网存取

公网存取

“公网存取”让你的服务可以从外部网络存取。

Zeabur 提供两种方法来存取你的服务:

  • HTTP 服务:使用 Zeabur 提供的域名或你自己的域名存取你的服务。
  • 非 HTTP 服务:使用分配的主机名称和连接端口存取你的服务。

绑定域名

域名 是你服务独特的识别代号,允许从公网存取服务。举例来说,这个网站的域名是 zeabur.com

要绑定域名到你的服务,首先前往 Zeabur 控制台中的服务,展开 域名 区块。你会看到有两个创建域名的选项。

两个绑定域名的选项

生成域名

生成域名”选项让你在没人使用的前提下创建带有 zeabur.app 后缀的域名名称,例如 your-service.zeabur.app,是最简单能让你服务得以公开存取的方式。

绑定 zeabur.app 域名

当你的 zeabur.app 域名设置完成后,你可以使用 Zeabur 提供的域名名称存取你的服务。

绑定 zeabur.app 域名完成

自定义域名

若要使用自己的域名名称,请选择“自定义域名”选项。

首先,在输入框中输入你的域名名称,然后点击“创建域名”按钮。

绑定自定义域名

添加域名名称后,你会看到域名的 DNS 信息。

设置域名的 DNS

你需要自行为你的域名添加 DNS 记录。以 Cloudflare 为例,你可以在“DNS”→“记录”页面中,用 Zeabur 提供的设置创建此域名的记录。如果你使用不同的 DNS 提供商,可以参考提供商文档中的 CNAME 记录添加说明。

在 Cloudflare 设置 DNS

您可以使用 Cloudflare 的 CDN(开启橙色云)来降低流量费用并提升浏览速度,但 Cloudflare 的 SSL/TLS 证书模式 不能选择 Full (Strict),否则可能会因为自签证书而导致连接失败。另外 Cloudflare 不支持三级域名以上自定义域名的 SSL 证书签发(即 *.example.com 是支持的,但 *.sub.example.com 不支持),此时您可以改回直连到 Zeabur 服务器(关闭橙色云)。

设置 DNS 记录后,可能需要几分钟让变更生效。完成后即可使用自定义域名存取你的服务。

绑定自定义域名完成

设置重定向

若要将你的域名重定向到另一个 URL,可以使用“重定向域名”功能。这会暂时(307)将你的域名重定向到指定的目标域名。

绑定自定义域名进行重定向

删除域名

若要删除域名,请点击域名名称旁的垃圾桶图标。

删除按钮

然后,在输入框中输入你的域名名称,并点击“删除”按钮确认。

删除域名的对话框

使用分配的主机名称和连接端口

如果服务不是使用 HTTP 协议,你可以使用分配的主机名称和连接端口,又称“端口转发”。例如,如果你有一个监听连接端口 25565 的 Minecraft 服务器,你可以使用分配的主机名称和连接端口,例如 hkg1.clusters.zeabur.com:34567,进行连接。

分配的主机名称和连接端口

虽然主机名称和连接端口通常是固定的,但也有可能会更改。建议不要假设主机名称和连接端口是永远不变的。你也可以在服务中设置自己的端口转发方式。

端口配置

Git 服务

Git 服务只能监听 1 个端口,即你在 Dockerfile 中定义的端口,如果没有定义(或者不是使用 Dockerfile 部署)则默认为 8080。考虑到端口号将来可能会有所改变,不建议直接在代码中写入 8080,更推荐使用 $PORT 环境变量。

以下是使用 $PORT 环境变量的一些代码示例:

server.js
const port = process.env.PORT || 8080;
 
app.listen(port, () => {
  console.log(`Server is running on port ${port}`);
});
main.go
package main
 
import (
    "fmt"
    "net/http"
    "os"
)
 
func main() {
    port := os.Getenv("PORT")
    if port == "" {
        port = "8080"
    }
 
    http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
        fmt.Fprintf(w, "Hello, World!")
    })
 
    http.ListenAndServe(":"+port, nil)
}

Docker 服务

你可以在 Docker 服务设置 时配置端口。详细信息请参阅 Docker 服务设置文档中的「Ports」部分。