Docker3 Rails6.0.3 Ruby2.7.0 DB:PostgeSQL Je vais le créer dans cet environnement.
J'ai fait référence à @ shungo_m's "Comment créer un environnement Rails 6 avec Docker".
Création des fichiers requis pour lancer le docker
$ mkdir myapp
$ cd myapp
$ touch Dockerfile
$ touch docker-compose.yml
$ touch entrypoint.sh
$ touch Gemfile
$ touch Gemfile.lock
Dokerfile
FROM ruby:2.7.0
RUN apt-get update -qq && apt-get install -y nodejs postgresql-client
RUN apt-get update && apt-get install -y curl apt-transport-https wget && \
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 yarn
RUN curl -sL https://deb.nodesource.com/setup_7.x | bash - && \
apt-get install nodejs
RUN mkdir /myapp
WORKDIR /myapp
COPY Gemfile /myapp/Gemfile
COPY Gemfile.lock /myapp/Gemfile.lock
RUN bundle install
COPY . /myapp
COPY entrypoint.sh /usr/bin/
RUN chmod +x /usr/bin/entrypoint.sh
ENTRYPOINT ["entrypoint.sh"]
EXPOSE 3000
CMD ["rails", "server", "-b", "0.0.0.0"]
docker-compose.yml
version: '3'
services:
db:
image: postgres
volumes:
- ./tmp/db:/var/lib/postgresql/data
environment:
POSTGRES_HOST_AUTH_METHOD: 'trust'
web:
build: .
command: bash -c "rm -f tmp/pids/server.pid && bundle exec rails s -p 3000 -b '0.0.0.0'"
volumes:
- .:/myapp
ports:
- "3000:3000"
depends_on:
- db
entrypoint.sh
#!/bin/bash
set -e
# Remove a potentially pre-existing server.pid for Rails.
rm -f /myapp/tmp/pids/server.pid
# Then exec the container's main process (what's set as CMD in the Dockerfile).
exec "$@"
Gemfile
source 'https://rubygems.org'
gem 'rails', '~>6'
Gemfile.lock
Maintenant que vous avez créé les fichiers nécessaires, créez un projet avec rails new
.
$ docker-compose run web rails new . --force --no-deps --database=postgresql --skip-bundle
Si vous continuez avec la construction et la configuration de docker telles quelles, il vous sera demandé d'installer Webpacker, alors installez-le.
$ docker-compose run web bundle exec rails webpacker:install
Après cela, définissez la base de données et terminez l'environnement docker.
J'ai fait référence à ce site. https://monaga.site/use-materialize-in-rails6/
$ docker-compose run web yarn add materialize-css
Créez et décrivez un fichier appelé application_style.js
dans app / javascript / packs
.
application_style.js
import "../stylesheets/application.scss";;
Créez et écrivez un fichier application.scss
dans le répertoire app / javascript / stylesheets
. ..
application.scss
@import "materialize-css/dist/css/materialize.min.css";
Enfin, ajoutez le code requis pour charger javascript dans app / javascript / packs / application.js
.
application.js
import "materialize-css/dist/js/materialize.min.js";
M.AutoInit();
Ceci termine la construction de l'environnement.
Il existe de nombreux exemples sur la page officielle de materialize, veuillez donc vous y référer. https://materializecss.com/
https://materializecss.com/ https://monaga.site/use-materialize-in-rails6/ https://qiita.com/shungo_m/items/fd1ab99fbe76d39e456c
Recommended Posts