docker-compose up 与 docker-compose run,为什么后者似乎没有启动服务?

ala*_*ter 2 postgresql docker docker-compose

这是我的docker-compose.yml

version: '3.8'
services:
   db:
      image: postgres:12-alpine
      environment:
      - POSTGRES_USER=tester
      - POSTGRES_PASSWORD=atest
      - POSTGRES_DB=test_db
      ports:
      - 5432:5432
      expose:
      - 5432
Run Code Online (Sandbox Code Playgroud)

正在做:

> docker-compose up -d
...
> psql test_db -U tester -h localhost
Password for user tester:
psql (12.3)
Type "help" for help.

test_db=# \l
                              List of databases
   Name    | Owner  | Encoding |  Collate   |   Ctype    | Access privileges
-----------+--------+----------+------------+------------+-------------------
 postgres  | tester | UTF8     | en_US.utf8 | en_US.utf8 |
 template0 | tester | UTF8     | en_US.utf8 | en_US.utf8 | =c/tester        +
           |        |          |            |            | tester=CTc/tester
 template1 | tester | UTF8     | en_US.utf8 | en_US.utf8 | =c/tester        +
           |        |          |            |            | tester=CTc/tester
 test_db   | tester | UTF8     | en_US.utf8 | en_US.utf8 |
(4 rows)
\q
Run Code Online (Sandbox Code Playgroud)
> docker-compose exec db ps awx
PID   USER     TIME  COMMAND
    1 postgres  0:00 postgres
   46 postgres  0:00 postgres: checkpointer
   47 postgres  0:00 postgres: background writer
   48 postgres  0:00 postgres: walwriter
   49 postgres  0:00 postgres: autovacuum launcher
   50 postgres  0:00 postgres: stats collector
   51 postgres  0:00 postgres: logical replication launcher
   52 root      0:00 ps awx
Run Code Online (Sandbox Code Playgroud)

工作正常。如果这样做也一样:

docker-compose exec db psql test_db -U tester
Run Code Online (Sandbox Code Playgroud)

那也挺好的。

但是,请执行以下操作:

> docker-compose down

> docker-compose run db psql test_db -U tester
psql: error: could not connect to server: could not connect to server: No such file or directory
    Is the server running locally and accepting
    connections on Unix domain socket "/var/run/postgresql/.s.PGSQL.5432"?
failed to resize tty, using default size

> docker-compose run db /bin/sh
/ # ps awx
PID   USER     TIME  COMMAND
    1 root      0:00 /bin/sh
    7 root      0:00 ps awx
Run Code Online (Sandbox Code Playgroud)

所以,我可以看到使用docker-compose run dbpostgres service没有被启动。为什么

什么

    --entrypoint CMD      Override the entrypoint of the image.
Run Code Online (Sandbox Code Playgroud)

indocker-compose run --help真的是什么意思?如果有一些东西要被覆盖,那么这意味着入口点应该被执行,不应该吗?

更新 我检查了https://docs.docker.com/compose/reference/run/,考虑是否--service-ports会做任何帮助,但它没有(并不感到惊讶,正如我上面强调的,postgres服务没有启动,所以我不知道它怎么可能是端口问题),甚至发现了一个例子:

docker-compose run db psql -h db -U docker

可惜!这正是我试图做的无济于事!

Mik*_*nek 5

请参阅此答案: Mysql 客户端使用`docker-compose run` 与`docker-compose exec` 调用

当您这样做时docker-compose run,它会创建一个db与您的docker-compose.yml.

查看发生了什么的最好方法是运行docker-compose up,然后从另一个 shell 运行docker-compose exec db bash,然后从另一个 shell 运行docker-compose run db bash

如果您查看hostnameand的输出ifconfig,您会看到exec将您连接到现有的,dbrun将您带入一个新的。

针对 OP 链接这篇文章,我之前应该强调一下,虽然在 Docker 下运行 PostgreSQL 没有错,但运行数据库与无状态的一般容器精神背道而驰。在像数据库这样的有状态和持久性容器的上下文中,该docker-compose run命令似乎没有意义。