Puma тихо выходит из док-контейнера - PullRequest
0 голосов
/ 01 мая 2019

Rails 5.2.3

Puma 3.12.1

Я докертизировал мое приложение rails, и когда я запускаю контейнер с командой rails s puma, Puma загружается, а затем тихо завершает работу:

=> Booting Puma
=> Rails 5.2.3 application starting in production 
=> Run `rails server -h` for more startup options

После этого больше нет журналов, и контейнер больше не работает.Puma все еще отлично работает за пределами докера.

Есть идеи?

РЕДАКТИРОВАТЬ

Dockerfile

FROM ruby:2.4.5
RUN sed -i '/jessie-updates/d' /etc/apt/sources.list

RUN curl -sL https://deb.nodesource.com/setup_10.x | bash - && \
    apt-get update -qq && apt-get install -y build-essential nodejs && \
    apt-get clean

RUN gem install bundler  # ensure bundler 2
RUN gem cleanup

RUN curl -sS https://dl.yarnpkg.com/debian/pubkey.gpg | apt-key add - && \
    echo "deb https://dl.yarnpkg.com/debian/ stable main" | tee /etc/apt/sources.list.d/yarn.list && \
    apt-get update && apt-get install -y apt-utils yarn && \
    gem install rails -v 5.2.3

ARG environment
RUN echo $environment
ENV RAILS_ENV=$environment
ENV DOCKER_IMAGE_BUILD=true

# ------------------------
# SSH Server support
# ------------------------
RUN apt-get update \
    && apt-get install -y --no-install-recommends openssh-server build-essential nodejs cron nano systemd \
    && echo "root:Docker!" | chpasswd

COPY sshd_config /etc/ssh/

RUN mkdir /myapp
WORKDIR /myapp
COPY . /myapp

RUN bundle -v

RUN bundle install
RUN yarn install


EXPOSE 3000 2222

COPY init_container.sh /myapp
RUN chmod 755 /myapp/init_container.sh

ENTRYPOINT ["/myapp/init_container.sh"]

init_container.sh:

#!/usr/bin/env bash
cat >/etc/motd <<EOL
  _____
  /  _  \ __________ _________   ____
/  /_\  \\___   /  |  \_  __ \_/ __ \
/    |    \/    /|  |  /|  | \/\  ___/
\____|__  /_____ \____/ |__|    \___  >
        \/      \/                  \/
A P P   S E R V I C E   O N   L I N U X

Documentation: http://aka.ms/webapp-linux
NodeJS quickstart: https://aka.ms/node-qs

EOL
cat /etc/motd

service ssh start

# whenever has to be run from the main app folder.
# it will look for schedule.rb in /myapp/config folder
cd /myapp
whenever --update-crontab
# restart cron after updating crontab
service cron restart
# for logging
crontab -l

bundle exec rails assets:precompile
yarn install

rails s puma

1 Ответ

0 голосов
/ 01 мая 2019

Не эксперт по ruby, но это то, что я хотел бы сделать, чтобы увидеть, что происходит.

Bash в контейнер и посмотреть, существуют ли на самом деле файлы приложения, которые вы скопировали в каталог /myapp.

docker exec -it <container name> /bin/bash

Если это так, попробуйте вручную запустить ./init_container.sh и посмотрите, что произойдет.

С помощью bash вы можете на самом деле проверить журналы и выяснить, что происходит, поскольку контейнер все еще будет работать.

...