启动 ec2 服务器时自动启动 docker

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/certbottelethonkids/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)

Mar*_*cin 8

使用Amazon Linux 2我试图复制这个问题。显然,我没有所有依赖项来运行您的确切docker-compose.yml,因此我使用了docker-compose.ymlfrom here进行验证。文件设置wordpressmysql.

我采取的步骤如下(ec2-user在主文件夹中执行):

1. 安装泊坞窗

sudo yum update -y  
sudo yum install -y docker
sudo systemctl enable docker
sudo systemctl start docker
Run Code Online (Sandbox Code Playgroud)

2.安装docker-compose

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)

3.创建 docker-compose.yml

mkdir 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)

4. 创建 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)

5.复制docker_boot.service到systemd

sudo cp -v ./myapp/docker_boot.service /etc/systemd/system
Run Code Online (Sandbox Code Playgroud)

6. 启用和启动 docker_boot.service

sudo systemctl enable docker_boot.service
sudo systemctl start docker_boot.service
Run Code Online (Sandbox Code Playgroud)

注意:首先start可能需要一些时间,因为它会拉取所有需要的 docker 镜像。或者,首先手动启动 docker-compose 以避免这种情况。

7. 检查状态 docker_boot.service

sudo systemctl status docker_boot.service
Run Code Online (Sandbox Code Playgroud)

8.检查wordpress是否up

curl -L localhost:8000
Run Code Online (Sandbox Code Playgroud)

9. 重启

docker_boot.service通过登录实例并使用sudo systemctl status docker_boot.service和/或来检查实例重启后是否正在运行curl -L localhost:8000

  • 您可以在 docker-compose 文件中添加“restart:always”。然后您将不需要创建任何 docker_boot.service 文件。如果 docker 机器打开,容器将自动重新启动。 (2认同)

Chr*_*ams 5

要在启动时启动服务,您可以运行以下命令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)

这篇文章提供了更多相关信息。