正在检查和更改 app.yml 文件 - 之前已清除日志 - 将尝试发送电子邮件并告知。
编辑
因此,清除日志并向 Gmail 或我自己的域发送电子邮件没有显示错误。我收到了 Gmail 的邮件,但没有收到我的域的邮件。
MailGun 的日志基本上是这样说的:
{
"recipient": "me@mydomain",
"id": "SCBCSJxDSqupdU9Da29rRw",
"envelope": {
"sender": "postmaster@mg.mydomain",
"targets": "me@mydomain",
"transport": "smtp",
"sending-ip": "192.168.0.1"
},
"timestamp": 1697462206.8430145,
"user-variables": {},
"message": {
"headers": {
"from": "Discourse Test Forum <postmaster@mg.mydomain>",
"message-id": "9d3b190d-bcbd-4378-8eb6-fc90cd57fe35@discourse.mydomain",
"to": "me@mydomain",
"subject": "[Discourse Test Forum] Email Deliverability Test"
},
"attachments": [],
"size": 4546
},
"storage": {
"region": "us-west1",
"key": "BAABAQUOTl3y4PtvsqlN5Z2OvaxXslLlZA",
"env": "production",
"url": "https://storage-us-west1.api.mailgun.net/v3/domains/mg.mydomain/messages/BAABAQUOTl3y4PtvsqlN5Z2OvaxXslLlZA"
},
"reason": "generic",
"delivery-status": {
"enhanced-code": "",
"mx-host": "mydomain",
"description": "",
"certificate-verified": true,
"attempt-no": 1,
"code": 550,
"message": "Verification failed for <bounce+674b6a.be6180c-me=mydomain@mg.mydomain>\nThe mail server does not recognize bounce+674b6a.be6180c-me=mydomain@mg.mydomain as a valid sender.\nSender verify failed",
"session-seconds": 40.878,
"tls": true
},
"campaigns": [],
"severity": "permanent",
"tags": [],
"recipient-domain": "mydomain",
"flags": {
"is-routed": false,
"is-authenticated": true,
"is-test-mode": false,
"is-system-test": false
},
"log-level": "error",
"event": "failed"
}
我只会在尝试我的域时收到此消息。如果我尝试任何其他域,它都可以正常工作 - 无论是免费邮件还是付费邮件。
app.yml 中的当前设置是:
## 这是全合一、独立的 Discourse Docker 容器模板
##
## 更改此文件后,您必须重建
## /var/discourse/launcher rebuild app
##
## 请务必小心编辑!
## YAML 文件对空格或对齐错误非常非常敏感!
## 如有需要,请访问 http://www.yamllint.com/ 进行验证
templates:
- "templates/postgres.template.yml"
- "templates/redis.template.yml"
- "templates/web.template.yml"
## 取消注释下一行以启用 IPv6 侦听器
#- "templates/web.ipv6.template.yml"
- "templates/web.ratelimited.template.yml"
## 如果您希望添加 Lets Encrypt (https),请取消注释这两行
- "templates/web.ssl.template.yml"
- "templates/web.letsencrypt.ssl.template.yml"
## 此容器应暴露哪些 TCP/IP 端口?
## 如果您希望 Discourse 与 Apache 或 nginx 等其他 Web 服务器共享端口,
## 请参阅 https://meta.discourse.org/t/17247 获取详细信息
expose:
- "80:80" # http
- "443:443" # https
params:
db_default_text_search_config: "pg_catalog.english"
## 将 db_shared_buffers 设置为总内存的最多 25%。
## 将由 bootstrap 根据检测到的 RAM 自动设置,或者您可以覆盖它
db_shared_buffers: "2048MB"
## 可以提高排序性能,但会增加每个连接的内存使用量
#db_work_mem: "40MB"
## 此容器应使用哪个 Git 版本? (默认: tests-passed)
#version: tests-passed
env:
LC_ALL: en_US.UTF-8
LANG: en_US.UTF-8
LANGUAGE: en_US.UTF-8
# DISCOURSE_DEFAULT_LOCALE: en
## 支持多少并发 Web 请求?取决于内存和 CPU 核心。
## 将由 bootstrap 根据检测到的 CPU 自动设置,或者您可以覆盖它
UNICORN_WORKERS: 8
## TODO: 此 Discourse 实例将响应的域名
## 必需。Discourse 不能使用裸 IP 地址。
DISCOURSE_HOSTNAME: mydomain
## 如果您希望容器以与上面指定的相同的主机名 (-h 选项) 启动,请取消注释
## (默认值为 "$hostname-$config")
#DOCKER_USE_HOSTNAME: true
## TODO: 将被设为管理员和开发者的逗号分隔的电子邮件列表
## 首次注册时,例如 'user1@example.com,user2@example.com'
DISCOURSE_DEVELOPER_EMAILS: 'me@mydomain'
## TODO: 用于验证新帐户和发送通知的 SMTP 邮件服务器
# 需要 SMTP 地址、用户名和密码
# 注意 SMTP 密码中的字符 '#' 可能会导致问题!
DISCOURSE_SMTP_ADDRESS: smtp.mailgun.org
DISCOURSE_SMTP_PORT: 587
DISCOURSE_SMTP_USER_NAME: postmaster@mg.mydomain
DISCOURSE_SMTP_PASSWORD: "mailgunpassword"
#DISCOURSE_SMTP_ENABLE_START_TLS: true # (可选,默认 true)
#DISCOURSE_SMTP_FORCE_TLS: true
DISCOURSE_SMTP_DOMAIN: mydomain
DISCOURSE_NOTIFICATION_EMAIL: postmaster@mg.mydomain
## 如果您添加了 Lets Encrypt 模板,请取消注释下方以获取免费 SSL 证书
LETSENCRYPT_ACCOUNT_EMAIL: freemailaccount
## 此 Discourse 实例的 http 或 https CDN 地址(配置为拉取)
## 请参阅 https://meta.discourse.org/t/14857 获取详细信息
#DISCOURSE_CDN_URL: https://discourse-cdn.example.com
## 用于 IP 地址查找的 maxmind 地理位置 IP 地址密钥
## 请参阅 https://meta.discourse.org/t/-/137387/23 获取详细信息
#DISCOURSE_MAXMIND_LICENSE_KEY: 1234567890123456
## Docker 容器是无状态的;所有数据都存储在 /shared 中
volumes:
- volume:
host: /var/discourse/shared/standalone
guest: /shared
- volume:
host: /var/discourse/shared/standalone/log/var-log
guest: /var/log
## 插件在此处
## 请参阅 https://meta.discourse.org/t/19157 获取详细信息
hooks:
after_code:
- exec:
cd: $home/plugins
cmd:
- git clone https://github.com/discourse/docker_manager.git
- git clone https://github.com/discourse/discourse-spoiler-alert.git
- git clone https://github.com/discourse/discourse-solved.git
- git clone https://github.com/discourse/discourse-docs.git
## 构建后要运行的任何自定义命令
run:
- exec: echo "Beginning of custom commands"
## 如果您想设置首次注册的“发件人”电子邮件地址,请取消注释并进行更改:
## 收到首次注册邮件后,请重新注释该行。它只需要运行一次。
#- exec: rails r "SiteSetting.notification_email='info@unconfigured.discourse.org'"
- exec: echo "End of custom commands"
对此所做的唯一更改是:
DISCOURSE_SMTP_ADDRESS: smtp.mydomain
DISCOURSE_SMTP_PORT: 587
DISCOURSE_SMTP_USER_NAME: email@mydomain
DISCOURSE_SMTP_PASSWORD: "mydomainmailpassword"
#DISCOURSE_SMTP_ENABLE_START_TLS: true # (可选,默认 true)
#DISCOURSE_SMTP_FORCE_TLS: true
DISCOURSE_SMTP_DOMAIN: mydomain
DISCOURSE_NOTIFICATION_EMAIL: email@mydomain
一旦我收到某人的回复,我将进行这些更改并返回日志中检查。或者……也许我直接进行更改——发布日志——然后等待回复。应该不会花太长时间。我们拭目以待。