ML_*_*ast 7 amazon-ec2 amazon-web-services systemd docker docker-compose
每次我重新启动 ec2 服务器时,我都必须执行以下操作:
sudo systemctl start docker然后docker-compose up -d启动所有容器。
有没有办法在实例开始时自动运行这两个命令?我已经阅读了这个答案,我认为理想情况下我想知道如何做到这一点:
创建一个 systemd 服务并启用它。所有启用的系统服务将在通电时启动。
你知道如何创建这样的 systemd 服务吗?
[编辑 1]:按照 Chris William 的评论,这是我所做的:
谢谢 Chris,所以我创建了一个docker_boot.service,内容如下:
[Unit]
Description=docker boot
After=docker.service
[Service]
Type=simple
Restart=always
RestartSec=1
User=ec2-user
ExecStart=/usr/bin/docker-compose -f docker-compose.yml up
[Install]
WantedBy=multi-user.target
Run Code Online (Sandbox Code Playgroud)
我在/etc/systemd/system文件夹中创建它
然后我做了:
sudo systemctl enable docker
sudo systemctl enable docker_boot
Run Code Online (Sandbox Code Playgroud)
当我打开服务器时,唯一正在运行的 Docker 图像是certbot/certbot和telethonkids/shinyproxy
请在我的docker-compose.yml文件内容下方找到。
您是否看到缺少什么以便所有图像都启动并运行?
version: "3.5"
services:
rstudio:
environment:
- USER=username
- PASSWORD=password
image: "rocker/tidyverse:latest"
build:
context: ./Docker_RStudio
dockerfile: Dockerfile
volumes:
- /home/ec2-user/R_and_Jupyter_scripts:/home/maxence/R_and_Jupyter_scripts
working_dir: /home/ec2-user/R_and_Jupyter_scripts
container_name: rstudio
ports:
- 8787:8787
jupyter:
image: 'jupyter/datascience-notebook:latest'
ports:
- 8888:8888
volumes:
- /home/ec2-user/R_and_Jupyter_scripts:/home/joyvan/R_and_Jupyter_scripts
working_dir: /home/joyvan/R_and_Jupyter_scripts
container_name: jupyter
shiny:
image: "rocker/shiny:latest"
build:
context: ./Docker_Shiny
dockerfile: Dockerfile
container_name: shiny
ports:
- 3838:3838
nginx:
image: nginx:alpine
container_name: nginx
restart: on-failure
networks:
- net
volumes:
- ./nginx.conf:/etc/nginx/nginx.conf
- ./data/certbot/conf:/etc/letsencrypt
- ./data/certbot/www:/var/www/certbot
ports:
- 80:80
- 443:443
command: "/bin/sh -c 'while :; do sleep 6h & wait $${!}; nginx -s reload; done & nginx -g \"daemon off;\"'"
depends_on:
- shinyproxy
certbot:
image: certbot/certbot
container_name: certbot
restart: on-failure
volumes:
- ./data/certbot/conf:/etc/letsencrypt
- ./data/certbot/www:/var/www/certbot
entrypoint: "/bin/sh -c 'trap exit TERM; while :; do certbot renew; sleep 12h & wait $${!}; done;'"
shinyproxy:
image: telethonkids/shinyproxy
container_name: shinyproxy
restart: on-failure
networks:
- net
volumes:
- ./application.yml:/opt/shinyproxy/application.yml
- /var/run/docker.sock:/var/run/docker.sock
expose:
- 8080
cron:
build:
context: ./cron
dockerfile: Dockerfile
container_name: cron
volumes:
- ./Docker_Shiny/app:/home
networks:
- net
networks:
net:
name: net
Run Code Online (Sandbox Code Playgroud)
使用Amazon Linux 2我试图复制这个问题。显然,我没有所有依赖项来运行您的确切docker-compose.yml,因此我使用了docker-compose.ymlfrom here进行验证。文件设置wordpress为mysql.
我采取的步骤如下(ec2-user在主文件夹中执行):
sudo yum update -y
sudo yum install -y docker
sudo systemctl enable docker
sudo systemctl start docker
Run Code Online (Sandbox Code Playgroud)
sudo curl -L https://github.com/docker/compose/releases/latest/download/docker-compose-$(uname -s)-$(uname -m) -o /usr/bin/docker-compose
sudo chmod +x /usr/bin/docker-compose
Run Code Online (Sandbox Code Playgroud)
docker-compose.ymlmkdir myapp
Run Code Online (Sandbox Code Playgroud)
创建文件./myapp/docker-compose.yml:
version: '3.3'
services:
db:
image: mysql:5.7
volumes:
- db_data:/var/lib/mysql
restart: always
environment:
MYSQL_ROOT_PASSWORD: somewordpress
MYSQL_DATABASE: wordpress
MYSQL_USER: wordpress
MYSQL_PASSWORD: wordpress
wordpress:
depends_on:
- db
image: wordpress:latest
ports:
- "8000:80"
restart: always
environment:
WORDPRESS_DB_HOST: db:3306
WORDPRESS_DB_USER: wordpress
WORDPRESS_DB_PASSWORD: wordpress
WORDPRESS_DB_NAME: wordpress
volumes:
db_data: {}
Run Code Online (Sandbox Code Playgroud)
docker_boot.service该文件与您的不同,因为您的文件中几乎没有潜在问题:
ec2-user 可能没有权限运行 docker创建文件./myapp/docker_boot.service:
[Unit]
Description=docker boot
After=docker.service
[Service]
Type=oneshot
RemainAfterExit=yes
WorkingDirectory=/home/ec2-user/myapp
ExecStart=/usr/bin/docker-compose -f /home/ec2-user/myapp/docker-compose.yml up -d --remove-orphans
[Install]
WantedBy=multi-user.target
Run Code Online (Sandbox Code Playgroud)
docker_boot.service到systemdsudo cp -v ./myapp/docker_boot.service /etc/systemd/system
Run Code Online (Sandbox Code Playgroud)
docker_boot.servicesudo systemctl enable docker_boot.service
sudo systemctl start docker_boot.service
Run Code Online (Sandbox Code Playgroud)
注意:首先start可能需要一些时间,因为它会拉取所有需要的 docker 镜像。或者,首先手动启动 docker-compose 以避免这种情况。
docker_boot.servicesudo systemctl status docker_boot.service
Run Code Online (Sandbox Code Playgroud)
curl -L localhost:8000
Run Code Online (Sandbox Code Playgroud)
docker_boot.service通过登录实例并使用sudo systemctl status docker_boot.service和/或来检查实例重启后是否正在运行curl -L localhost:8000。
要在启动时启动服务,您可以运行以下命令sudo systemctl enable docker。
为了让它启动你的docker compose up -d命令,你需要为你的特定操作创建一个新服务,然后使用类似于下面的内容启用它。
[Unit]
After=docker.service
Description=Docker compose
[Service]
ExecStart=docker-compose up -d
[Install]
WantedBy=multi-user.target
Run Code Online (Sandbox Code Playgroud)
这篇文章提供了更多相关信息。
| 归档时间: |
|
| 查看次数: |
3944 次 |
| 最近记录: |