Docker in development: Episode 3
In the last issue, we explained how to containerize Ruby on Rails applications. In this issue we'll explore how to perform everyday tasks in containers.
Run Rake tasks and Rails commands
Running Rake tasks is easy. After you build the image, you can use docker-compose to run commands in it. For example, if you want to view your application's routes:
$ docker-compose run web rails routes
Similarly, if you want to create a database, migrate and populate data:
$ docker-compose run web rails db:create db:migrate db:seed
If you want to run the test suite, you must create a test database:
$ docker-compose run web rails db:create db:migrate RAILS_ENV=test
Then run the test suite (assuming rake runs rake test by default):
$ docker-compose run web rake
Tip: Create custom scripts/aliases
I run docker-compose run web rails ...
hundreds of times a day, and to make things easier I put this script inside my $PATH
:
#!/bin/bash docker-compose run web rails "$@"
Please note that this script assumes that your docker-compose.yml
file has a web service. If not, it won't work.
Perform other tasks
So far all the commands are very simple and straightforward, you just need to run them in the web service. So what do you do with some of the more difficult tasks like loading a pre-existing database into a container's database? This was one of the tasks that took me a little longer to figure out.
In PostgreSQL, there are two ways to do this, depending on the format of the dump file. In the past, we had to deal with --format=c
dumps and regular dumps.
Suppose you have a latest.dump
file containing a PostgreSQL dump in c format, and you want to load it into a (running) container, first you have to find out the container ID. You can do this by running the following command:
$ docker container ls
or
$ docker ps
Once you have the container ID (in this example, we will use 80f8041db4b4
), you can run the following command to restore the dump in the container:
$ docker exec -i 80f8041db4b4 pg_restore -d app_development -U postgres
If you have a regular dump (e.g. latest.sql
), you can restore it using:
$ docker exec -i 80f8041db4b4 psql -d app_development -U postgres
If you are using docker-compose, things get easier:
$ docker-compose exec -T db pg_restore -d app_development -U postgres
Everything is containerized!
I use Elastic Beanstalk a lot. I usually install it using Homebrew, but it installs a lot of its own dependencies such as Python, SQLite, etc. I don't want all of this on my system, especially since I always have issues with the Python version. Instead, I containerize it: docker-awsebcli
.
Stay tuned for the next issue!
The above is the detailed content of Docker in development: Episode 3. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Solution to permission issues when viewing Python version in Linux terminal When you try to view Python version in Linux terminal, enter python...

How to avoid being detected when using FiddlerEverywhere for man-in-the-middle readings When you use FiddlerEverywhere...

When using Python's pandas library, how to copy whole columns between two DataFrames with different structures is a common problem. Suppose we have two Dats...

How to teach computer novice programming basics within 10 hours? If you only have 10 hours to teach computer novice some programming knowledge, what would you choose to teach...

How does Uvicorn continuously listen for HTTP requests? Uvicorn is a lightweight web server based on ASGI. One of its core functions is to listen for HTTP requests and proceed...

Using python in Linux terminal...

Fastapi ...

Understanding the anti-crawling strategy of Investing.com Many people often try to crawl news data from Investing.com (https://cn.investing.com/news/latest-news)...
