你好,
我遇到了以下问题。在执行命令 ./discourse-setup 时,我收到了如下错误:
我不太理解这条消息的含义。我的网站 https://cp2077.eu/ 已经上线并运行,且已配置 SSL。
以下是我的 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"
- "templates/sshd.template.yml"
- "templates/web.ratelimited.template.yml"
## 如果您希望添加 Let's Encrypt (https),请取消注释以下两行
## - "templates/web.ssl.template.yml"
## - "templates/web.letsencrypt.ssl.template.yml"
- "templates/web.socketed.template.yml"
## 此容器应暴露哪些 TCP/IP 端口?
## 如果您希望 Discourse 与另一个 Web 服务器(如 Apache 或 Nginx)共享端口,
## 请参阅 https://meta.discourse.org/t/17247 了解详情
#expose:
# - "2045:80" # http
# - "1443:443" # https
params:
db_default_text_search_config: "pg_catalog.english"
## 将 db_shared_buffers 设置为总内存的最大 25%。
## 将根据检测到的 RAM 自动由 bootstrap 设置,您也可以覆盖
db_shared_buffers: "1024MB"
## 可以改善排序性能,但会增加每个连接的内存使用量
#db_work_mem: "40MB"
## 此容器应使用哪个 Git 修订版本?(默认:tests-passed)
#version: tests-passed
env:
LANG: en_US.UTF-8
# DISCOURSE_DEFAULT_LOCALE: en
## 支持多少个并发 Web 请求?取决于内存和 CPU 核心数。
## 将根据检测到的 CPU 自动由 bootstrap 设置,您也可以覆盖
UNICORN_WORKERS: 4
## TODO: 此 Discourse 实例将响应的域名
## 必需。Discourse 无法在纯 IP 地址上运行。
DISCOURSE_HOSTNAME: cp2077.eu
## 如果您希望容器以与上述指定的相同主机名(-h 选项)启动,请取消注释
## (默认值为 "$hostname-$config")
#DOCKER_USE_HOSTNAME: true
## TODO: 初始注册时将设为管理员和开发者的逗号分隔邮箱列表
## 示例:'user1@example.com,user2@example.com'
DISCOURSE_DEVELOPER_EMAILS: 'myemail@yandex.com'
## TODO: 用于验证新账户和发送通知的 SMTP 邮件服务器
# SMTP 地址、用户名和密码为必需项
# 警告:SMTP 密码中的字符 '#' 可能导致问题!
DISCOURSE_SMTP_ADDRESS: smtp.mailgun.org
DISCOURSE_SMTP_PORT: 587
DISCOURSE_SMTP_USER_NAME: ******
DISCOURSE_SMTP_PASSWORD: ******
DISCOURSE_SMTP_ENABLE_START_TLS: true # (可选,默认为 true)
## 如果您添加了 Let's Encrypt 模板,请取消注释以下行以获取免费 SSL 证书
LETSENCRYPT_ACCOUNT_EMAIL: myemail@yandex.com
## 此 Discourse 实例的 HTTP 或 HTTPS CDN 地址(配置为拉取)
## 详见 https://meta.discourse.org/t/14857
#DISCOURSE_CDN_URL: https://discourse-cdn.example.com
## 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
## 构建后运行的任何自定义命令
run:
- exec: echo "开始自定义命令"
## 如果您想设置首次注册的“发件人”邮箱地址,请取消注释并修改:
## 收到首次注册邮件后,请重新注释该行。该行只需运行一次。
## - exec: rails r "SiteSetting.notification_email='beatlicious@yandex.com'"
- exec: echo "结束自定义命令"
当我执行命令 ./launcher rebuild app 时,出现以下错误:
fatal: not a git repository (or any of the parent directories): .git
停止旧容器
+ /usr/bin/docker stop -t 60 app
app
cd /pups && git pull && /pups/bin/pups --stdin
已是最新版本。
I, [2020-07-11T01:41:07.468750 #1] INFO -- : 正在加载 --stdin
I, [2020-07-11T01:41:07.482322 #1] INFO -- : > locale-gen $LANG && update-locale
I, [2020-07-11T01:41:07.556578 #1] INFO -- : 正在生成语言环境(这可能需要一些时间)...
生成完成。
I, [2020-07-11T01:41:07.557419 #1] INFO -- : > mkdir -p /shared/postgres_run
I, [2020-07-11T01:41:07.562170 #1] INFO -- :
I, [2020-07-11T01:41:07.562833 #1] INFO -- : > chown postgres:postgres /shared/postgres_run
I, [2020-07-11T01:41:07.568449 #1] INFO -- :
I, [2020-07-11T01:41:07.569223 #1] INFO -- : > chmod 775 /shared/postgres_run
I, [2020-07-11T01:41:07.576449 #1] INFO -- :
I, [2020-07-11T01:41:07.577398 #1] INFO -- : > rm -fr /var/run/postgresql
I, [2020-07-11T01:41:07.582904 #1] INFO -- :
I, [2020-07-11T01:41:07.583623 #1] INFO -- : > ln -s /shared/postgres_run /var/run/postgresql
I, [2020-07-11T01:41:07.592257 #1] INFO -- :
I, [2020-07-11T01:41:07.593134 #1] INFO -- : > socat /dev/null UNIX-CONNECT:/shared/postgres_run/.s.PGSQL.5432 || exit 0 && echo postgres already running stop container ; exit 1
2020/07/11 01:41:07 socat[27] E connect(6, AF=1 "/shared/postgres_run/.s.PGSQL.5432", 36): No such file or directory
I, [2020-07-11T01:41:07.602436 #1] INFO -- :
I, [2020-07-11T01:41:07.602977 #1] INFO -- : > rm -fr /shared/postgres_run/.s*
I, [2020-07-11T01:41:07.608907 #1] INFO -- :
I, [2020-07-11T01:41:07.609638 #1] INFO -- : > rm -fr /shared/postgres_run/*.pid
I, [2020-07-11T01:41:07.619803 #1] INFO -- :
I, [2020-07-11T01:41:07.622598 #1] INFO -- : > mkdir -p /shared/postgres_run/10-main.pg_stat_tmp
I, [2020-07-11T01:41:07.629638 #1] INFO -- :
I, [2020-07-11T01:41:07.630522 #1] INFO -- : > chown postgres:postgres /shared/postgres_run/10-main.pg_stat_tmp
I, [2020-07-11T01:41:07.639523 #1] INFO -- :
I, [2020-07-11T01:41:07.651076 #1] INFO -- : 文件 > /etc/service/postgres/run chmod: +x chown:
I, [2020-07-11T01:41:07.660620 #1] INFO -- : 文件 > /etc/service/postgres/log/run chmod: +x chown:
I, [2020-07-11T01:41:07.668238 #1] INFO -- : 文件 > /etc/runit/3.d/99-postgres chmod: +x chown:
I, [2020-07-11T01:41:07.679949 #1] INFO -- : 文件 > /root/upgrade_postgres chmod: +x chown:
I, [2020-07-11T01:41:07.680746 #1] INFO -- : > chown -R root /var/lib/postgresql/10/main
chown: 无法访问 '/var/lib/postgresql/10/main':没有那个文件或目录
I, [2020-07-11T01:41:07.685326 #1] INFO -- :
失败
--------------------
Pups::ExecError: chown -R root /var/lib/postgresql/10/main 失败,返回状态为 #<Process::Status: pid 42 exit 1>
失败位置:/pups/lib/pups/exec_command.rb:112:in `spawn'
exec 失败,参数为 {"cmd"=>["chown -R root /var/lib/postgresql/10/main", "[ ! -e /shared/postgres_data ] && install -d -m 0755 -o postgres -g postgres /shared/postgres_data && sudo -E -u postgres /usr/lib/postgresql/10/bin/initdb -D /shared/postgres_data || exit 0", "chown -R postgres:postgres /shared/postgres_data", "chown -R postgres:postgres /var/run/postgresql"]}
d639e83f5451b5039efb2333f3eca1166d34ff6dc582ee29a0734a4274080fa2
** 启动失败 ** 请向上滚动查看更早的错误消息,可能不止一条。
./discourse-doctor 可能有助于诊断问题。
atlas@sknet:~/www/cp2077$
有人能建议我如何安装和配置 Discourse 吗?我按照指南操作,但卡在了这里。谢谢。

