Я пытаюсь запустить сервер rails в образе докера вместе с образом внешнего интерфейса mysql и vue. Я использую ruby 3 и rails 6. Образ mysql и внешнего интерфейса запускаются без проблем. Однако изображения рельсов не запускаются. У меня Macbook Pro с MacOS Monterey и Docker Desktop 4.5.0.
это мой docker-compose.yml:
version: "3"
services:
mysql:
image: mysql:8.0.21
command:
- --default-authentication-plugin=mysql_native_password
environment:
- MYSQL_ROOT_PASSWORD=root
- MYSQL_DATABASE=nauza_backend_development
ports:
- "3307:3306"
volumes:
- mysql:/var/lib/mysql
backend:
build:
context: nauza-backend
args:
UID: ${UID:-1001}
tty: true
stdin_open: true
command:
bundle exec rails s -p 8080 -b '0.0.0.0'
volumes:
- ./nauza-backend:/usr/src/app
# attach a volume at /bundle to cache gems
- bundle:/bundle
# attach a volume at ./node_modules to cache node modules
- node-modules:/usr/src/app/node_modules
# attach a volume at ./tmp to cache asset compilation files
- tmp:/usr/src/app/tmp
environment:
- RAILS_ENV=development
ports:
- "8080:8080"
depends_on:
- mysql
user: rails
environment:
- RAILS_ENV=development
- MYSQL_HOST=mysql
- MYSQL_USER=root
- MYSQL_PASSWORD=root
frontend:
build:
context: nauza-frontend
args:
UID: ${UID:-1001}
volumes:
- ./nauza-frontend:/usr/src/app
ports:
- "3000:3000"
user: frontend
volumes:
bundle:
driver: local
mysql:
driver: local
tmp:
driver: local
node-modules:
driver: local
и это мой Dockerfile:
FROM ruby:3.0.2
ARG UID
RUN adduser rails --uid $UID --disabled-password --gecos ""
ENV APP /usr/src/app
RUN mkdir $APP
WORKDIR $APP
ENV EDITOR=vim
RUN apt-get update \
&& apt-get install -y \
nmap \
vim
COPY Gemfile* $APP/
RUN bundle install -j3 --path vendor/bundle
COPY . $APP/
CMD ["rails", "server", "-p", "8080", "-b", "0.0.0.0"]
когда я пытаюсь запустить это с помощью docker-compose up на своем Mac, я получаю следующую ошибку:
/usr/local/lib/ruby/3.0.0/fileutils.rb:253:in `mkdir': Permission denied @ dir_s_mkdir - /usr/src/app/tmp/cache (Errno::EACCES)
Любые идеи о том, как это исправить?





Удалите строку - tmp:/usr/src/app/tmp в вашем Dockerfile.
Я бы сказал, вам не нужно получать доступ к временным файлам вашего контейнера. ?
Моим первым шагом здесь было бы удалить все
volumes:, кроме хранилища данных MySQL: вам не нужно хранить свой код в томах, запуск его из образа — это нормальный подход. Вам не нужно переопределятьuser:во время выполнения или передавать определенный идентификатор пользователя в процесс сборки. Если у вас нет монтирования тома, ваш Dockerfile можетRUN chownубедиться, что пользователь без полномочий root может записывать во временный каталог.