我正在尝试使用mongoDB将Strapi应用程序部署到Heroku,但是每次尝试部署时都会收到此错误。
debug ⛔️ Server wasn't able to start properly.
2020-06-11T10:38:53.257748+00:00 app[web.1]: [2020-06-11T10:38:53.257Z] error Error connecting to the Mongo database. Server selection timed out after 30000 ms
2020-06-11T10:38:53.268085+00:00 app[web.1]: npm ERR! code ELIFECYCLE
2020-06-11T10:38:53.268583+00:00 app[web.1]: npm ERR! errno 1
2020-06-11T10:38:53.270443+00:00 app[web.1]: npm ERR! backend@0.1.0 start: `strapi start`
2020-06-11T10:38:53.270697+00:00 app[web.1]: npm ERR! Exit status 1
该应用程序可在本地运行,并且我遵循了许多教程(1,2),包括offical Strapi documentation的许多版本才能正常工作,但它们均会导致此错误。我看过类似的Stack问题/ Strapi github问题,看是否可以通过改编他们的答案来解决我的问题,但没有任何效果。
我确保heroku config
的database_url和database_name匹配我的database_uri
的字符串,并用yarn create strapi-app backend
然后选择mongo创建了bandi应用程序,确保不使用--quickstart
。
可以在此处https://github.com/KyleSFraser/Portfolio/tree/master/backend
查看我的完整手机应用程序,包括database.js, server.js, *config/environments/production/database.json
我一直在兜圈子,不断尝试使用试图部署的文档或教程来重建后端。我非常感谢有任何指针可以解决此重复出现的问题,并使用Heroku和Strapi成功部署我的mongoDB。
编辑 现在可以删除以前的配置变量了
答案 0 :(得分:1)
将uri: env('DATABASE_URI' || ''),
添加到我的database.js
文件中已解决了该问题,不确定是否首先丢失了它。
对于有类似问题的任何人,这里是我的database.js
和server.js
供参考;
database.js
defaultConnection: 'default',
connections: {
default: {
connector: 'mongoose',
settings: {
uri: env('DATABASE_URI' || ''),
host: env('DATABASE_HOST', '127.0.0.1'),
srv: env.bool('DATABASE_SRV', false),
port: env.int('DATABASE_PORT', 27017),
database: env('DATABASE_NAME', '(backend)'),
username: env('DATABASE_USERNAME', ''),
password: env('DATABASE_PASSWORD', ''),
},
options: {
authenticationDatabase: env('AUTHENTICATION_DATABASE', null),
ssl: env.bool('DATABASE_SSL', false),
},
},
},
});
server.js
module.exports = ({ env }) => ({
host: env('HOST', '0.0.0.0'),
port: env.int('PORT', 1337),
});
最后确保所有的Heroku配置变量都设置为与mongoDB /数据库URI的相关细分相匹配