[英]Error while deploying Rails 6 app to Google Cloud Platform App Engine
我已经使用 Rails 上的 Ruby 开发了应用程序的第一次迭代(ROR - v6.0.0;Ruby - v2.6.3)。 我需要将它部署到 gcp,谷歌云平台,因为这是我工作的公司使用的。 我遵循了谷歌为此提供的教程,如此处所示。 但是,无论我做什么,在推送快结束时我都会收到此错误:
8536b8dd72f7: Pushed
f66b9865f45c: Layer already exists
8f213bf0e9c7: Pushed
ce02b74896ad: Pushed
a79efcc05468: Pushed
latest: digest: sha256:93b405b42825c93798db12c14f4f5d5dd09c6fc3e32861a1a1f3947c338e45a2 size: 2419
DONE
-----------------------------------------------------------------------------------------------------------------------------------------------------------
Updating service [default] (this may take several minutes)...failed.
ERROR: (gcloud.app.deploy) Error Response: [9]
Application startup error:
Puma starting in single mode...
* Version 3.12.1 (ruby 2.6.3-p62), codename: Llamas in Pajamas
* Min threads: 5, max threads: 5
* Environment: production
* Listening on tcp://0.0.0.0:8080
bundler: failed to load command: rackup (/app/vendor/bundle/ruby/2.6.0/bin/rackup)
Errno::ENOENT: No such file or directory @ rb_sysopen - tmp/pids/server.pid
/app/vendor/bundle/ruby/2.6.0/gems/puma-3.12.1/lib/puma/launcher.rb:133:in `initialize'
/app/vendor/bundle/ruby/2.6.0/gems/puma-3.12.1/lib/puma/launcher.rb:133:in `open'
/app/vendor/bundle/ruby/2.6.0/gems/puma-3.12.1/lib/puma/launcher.rb:133:in `write_pid'
/app/vendor/bundle/ruby/2.6.0/gems/puma-3.12.1/lib/puma/launcher.rb:106:in `write_state'
/app/vendor/bundle/ruby/2.6.0/gems/puma-3.12.1/lib/puma/single.rb:103:in `run'
/app/vendor/bundle/ruby/2.6.0/gems/puma-3.12.1/lib/puma/launcher.rb:186:in `run'
/app/vendor/bundle/ruby/2.6.0/gems/puma-3.12.1/lib/rack/handler/puma.rb:73:in `run'
/app/vendor/bundle/ruby/2.6.0/gems/rack-2.0.7/lib/rack/server.rb:297:in `start'
/app/vendor/bundle/ruby/2.6.0/gems/rack-2.0.7/lib/rack/server.rb:148:in `start'
/app/vendor/bundle/ruby/2.6.0/gems/rack-2.0.7/bin/rackup:4:in `<top (required)>'
/app/vendor/bundle/ruby/2.6.0/bin/rackup:23:in `load'
/app/vendor/bundle/ruby/2.6.0/bin/rackup:23:in `<top (required)>'
奇怪的是,我尝试使用全新的 rails 应用程序(相同的机器,相同的环境)按照谷歌的教程进行操作,但我得到了同样的错误。 该帐户已启用计费,所以我认为不是这样。 当我在本地运行该应用程序时,它工作得很好。 无论如何,这是我的“app.yml”文件:
entrypoint: bundle exec rackup --port $PORT
env: flex
runtime: ruby
env_variables:
SECRET_KEY_BASE: [MY_SECRET_KEY_IS_HERE]
当我在本地机器上运行bundle exec rackup --port 8080
时,应用程序启动得很好。 我已经搜索了所有内容,但无法找到解决方案。 我看过类似的帖子,但要么没有答案,要么没有解决这个问题。 我正在考虑将应用程序“dockerizing”,但不确定是否可以解决任何问题; 但如果我理解正确,docker 是一种告诉其他机器如何运行特定指令集的方法,比如应用程序,这样它几乎可以在任何机器上运行。 Idk,这就是我能想到的。 欢迎任何和所有建议,我们将不胜感激。
感谢您花时间阅读本文,否则我希望您度过愉快的一天。
我遇到过同样的问题。
我正在使用puma
gem 作为我的应用服务器。 我需要更改entrypoint
文件中的入口app.yaml
。
entrypoint: bundle exec rails server Puma -p $PORT
可在此处找到文档: https://cloud.google.com/appengine/docs/flexible/ruby/runtime
我遇到了同样的问题。 我的/config/puma.rb
有这个:
pidfile ENV.fetch("PIDFILE") { "tmp/pids/server.pid" }
这允许我使用env_variables
将 pid 文件的位置设置为/tmp
。 我在app.yaml
中添加了以下内容:
env_variables:
PIDFILE: "/tmp/puma.pid"
一旦我这样做了,错误就消失了。
我相信这是由于默认位置是只读的。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.