docker - docker-compose:在pgsql容器上运行命令

标签 docker docker-compose

我正在尝试运行以下docker-compose文件:

version: "3"
services:
  db:
    image: postgres
    container_name: pgsql
    environment:
      - foo=foo
      - bar=bar
    volumes:
      - ./sql/:/opt/sql
    command: bash /opt/sql/create-db.sql
#    command: ps -aux
  web:
    image: benit/debian-web
    container_name: web
    depends_on:
      - db
    ports:
      - 80:80
    volumes:
      - ./html:/var/www/html

我在这行遇到错误:
command: bash /opt/sql/create-db.sql

这是因为pgsql服务没有启动。可以用command: ps -aux监视

pgsql服务启动后,如何运行脚本?

最佳答案

您可以使用卷来提供初始化sql脚本:

version: "3"
services:
  db:
    image: postgres
    container_name: pgsql
    environment:
      - foo=foo
      - bar=bar
    volumes:
      - ./sql/:/opt/sql
      - ./init.sql:/docker-entrypoint-initdb.d/init.sql
  web:
    image: benit/debian-web
    container_name: web
    depends_on:
      - db
    ports:
      - 80:80
    volumes:
      - ./html:/var/www/html

这将起作用,因为原始Posgresql dockerfile包含一个脚本(在启动Posrgres之后运行),该脚本将执行*.sql文件夹中的所有/docker-entrypoint-initdb.d/文件。

通过在该位置安装本地卷,您的sql文件将在正确的时间运行。

该图像的文档中实际上提到了该图像:How to extend this image部分下的https://hub.docker.com/_/postgres

关于docker - docker-compose:在pgsql容器上运行命令,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54183338/

相关文章:

node.js - 是否可以在 docker 容器中使用 npm serialPort?

java - 在 gitlab-ci 中运行 selenium 测试用例时出现 chrome 无法访问错误。似乎 headless chrome 存在一些问题,任何人都可以帮忙解决这个问题

docker - 如何从 docker 容器访问主机的 localhost 127.0.0.1

docker - DataDog Docker代理未从应用程序容器接收日志

django - Docker compose 文件所有权

nginx - Boot2Docker/Fig 挂载的卷不刷新

bash - entrypoint.sh-第9行:语法错误:意外的 “(”

node.js - Docker-Compose:无法将 NodeJS 与 Mongodb 和 Redis 连接 [连接被拒绝]

docker - 将NPM和Bower添加到Dockerize LAMP环境

docker - 无法使用 docker-compose 挂载卷