J. *_*ass 5 ruby-on-rails docker dockerhub docker-compose github-actions
我 dockerized 一个 rails 应用程序,它可以在我的本地机器上完美运行。我将 Github Actions 配置为将应用程序推送到 Docker Hub 上的私有映像中,当我尝试在本地或另一台机器上拉取并运行它时,它会拉取映像,但容器随后退出,因为 Rails 失败并出现以下错误:
app | rm: cannot remove 'tmp/pids/server.pid': No such file or directory
app | => Booting Puma
app | => Rails 6.0.3.3 application starting in development
app | => Run `rails server --help` for more startup options
app | Exiting
app | (erb):9:in `<main>': Cannot load database configuration: (NoMethodError)
app | undefined method `[]' for nil:NilClass
app | from /usr/local/lib/ruby/2.7.0/erb.rb:905:in `eval'
app | from /usr/local/lib/ruby/2.7.0/erb.rb:905:in `result'
app | from /usr/local/bundle/gems/railties-6.0.3.3/lib/rails/application/configuration.rb:228:in `database_configuration'
Run Code Online (Sandbox Code Playgroud)
我注释掉了rm命令和两个bin/rails命令,以查看是否可以让容器保持运行并在控制台中进行调试,但我没有机会。
通过搜索其他 SO 问题,我想我的 ENV 或 database.yml 通常肯定有问题,但我不明白为什么当我不从 Docker Hub 中提取图像时它可以完美运行。不应该以任何方式解决凭据吗?在单独的凭证文件中,每个环境都有凭证。
这是我的代码:
docker-compose.yml
version: '3'
volumes:
db_data:
driver: local
app_data:
driver: local
services:
# database container
postgres:
image: postgres
volumes:
- app_data:/var/lib/postgresql/data
ports:
- 5439:5432
environment:
POSTGRES_DB: $DATABASE_NAME
POSTGRES_USER: $DATABASE_USER
POSTGRES_PASSWORD: $DATABASE_PASSWORD
command: ["postgres", "-c", "log_statement=all"]
restart: always
backend:
build: ./server
volumes:
- ./server:/var/workdir
ports:
- "3009:3000"
depends_on:
- postgres
Run Code Online (Sandbox Code Playgroud)
文件
FROM ruby:2.7.1
WORKDIR /var/workdir
COPY . /var/workdir
# Install NodeJS and Yarn.
RUN curl https://deb.nodesource.com/setup_12.x | bash
RUN curl -sS https://dl.yarnpkg.com/debian/pubkey.gpg | apt-key add -
RUN echo "deb https://dl.yarnpkg.com/debian/ stable main" | tee /etc/apt/sources.list.d/yarn.list
RUN apt-get update && apt-get install -y nodejs yarn
RUN yarn install --check-files
RUN bundle install
ENV PORT 3000
EXPOSE $PORT
CMD /var/workdir/entrypoint.sh
Run Code Online (Sandbox Code Playgroud)
入口点.sh
#!/bin/bash
rm tmp/pids/server.pid
bin/rails db:create
bin/rails db:migrate
bin/rails server -b 0.0.0.0 -p $PORT
Run Code Online (Sandbox Code Playgroud)
配置/数据库.yml
# PostgreSQL. Versions 9.3 and up are supported.
default: &default
adapter: postgresql
encoding: unicode
pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %>
host: postgres
port: 5432
database: <%= Rails.application.credentials.database[:name] %>
username: <%= Rails.application.credentials.database[:username] %>
password: <%= Rails.application.credentials.database[:password] %>
development:
<<: *default
test:
<<: *default
production:
<<: *default
Run Code Online (Sandbox Code Playgroud)
.github/workflows/main.yml
name: App
on:
push:
branches:
- main
pull_request:
branches:
- main
jobs:
build:
runs-on: ubuntu-latest
services:
postgres:
image: postgres
env:
POSTGRES_DB: ${{ secrets.DATABASE_NAME }}
POSTGRES_USER: ${{ secrets.DATABASE_USER }}
POSTGRES_PASSWORD: ${{ secrets.DATABASE_PASSWORD }}
ports:
- 5439:5432
# needed because the postgres container does not provide a healthcheck
options: --health-cmd pg_isready --health-interval 10s --health-timeout 5s --health-retries 5
steps:
- name: Checkout repo
uses: actions/checkout@v2
- name: Install PostgreSQL package
run: |
sudo apt-get -yqq install libpq-dev
- name: Install yarn
run: yarn install --check-files
- uses: actions/setup-node@v1
with:
node-version: '12.13.0'
- name: Setup Ruby
uses: actions/setup-ruby@v1
with:
ruby-version: 2.7.1
- name: Ruby gem cache
uses: actions/cache@v2
with:
path: vendor/bundle
key: ${{ runner.os }}-gems-${{ hashFiles('**/Gemfile.lock') }}
restore-keys: |
${{ runner.os }}-gems-
- name: Build and create DB
env:
RAILS_ENV: test
RAILS_MASTER_KEY: ${{ secrets.RAILS_MASTER_KEY }}
run: |
cd server
gem install bundler
bundle config path vendor/bundle
bundle install --jobs 4 --retry 3
bin/rails db:setup
deploy:
runs-on: ubuntu-latest
needs: build
steps:
- uses: actions/checkout@v2
- name: Docker login
run: docker login -u ${{ secrets.DOCKER_USER }} -p ${{ secrets.DOCKER_PASSWORD }}
- name: Build
run: docker build -t app ./server
- name: Tags
run: |
docker tag app ${{ secrets.DOCKER_USER }}/app
docker tag app ${{ secrets.DOCKER_USER }}/app:latest
- name: Push
run: |
docker push ${{ secrets.DOCKER_USER }}/app
docker push ${{ secrets.DOCKER_USER }}/app:latest
Run Code Online (Sandbox Code Playgroud)
更新:通过将 master.key 作为秘密添加到 Github Actions,管道中的错误显示为:
rails aborted!
ActiveSupport::MessageEncryptor::InvalidMessage: Cannot load database configuration:
ActiveSupport::MessageEncryptor::InvalidMessage
(...)
Caused by:
OpenSSL::Cipher::CipherError:
Run Code Online (Sandbox Code Playgroud)
相反,当我将 test.key 添加为机密时,会返回原始错误。
这是我在本地创建的用于从 Docker Hub 获取和运行图像的 docker-compose.yml:
version: '3'
services:
app:
image: user/app:latest
Run Code Online (Sandbox Code Playgroud)
我替换了这个问题的所有用户名和仓库名。
小智 1
我非常确定(但不是 100%)您的项目没有凭据文件。它应该在这里:
your_app/config/master.key
Run Code Online (Sandbox Code Playgroud)
当您运行以下命令时会生成该文件:
EDITOR=vim bundle exec rails credentials:edit
Run Code Online (Sandbox Code Playgroud)
该文件用于解密您的credentials.yml.enc文件,其中secret_key_base存储了(当然还有您的凭据)。
在服务器配置期间,我在丢失时看到了相同的错误secret_key_base,并且发生这种情况是因为我忘记创建master.key将解密我的凭据文件。
很抱歉没有给你一个真正的答案,但更多的是你可以这样看。
| 归档时间: |
|
| 查看次数: |
347 次 |
| 最近记录: |