gpt4 book ai didi

node.js - Docker-撰写我无法创建Postgres服务器

转载 作者:行者123 更新时间:2023-12-02 19:00:36 24 4
gpt4 key购买 nike

您好我正在尝试创建一个postgres compose docker
pg管理员4
和节点
但我遇到了困难,无法创建服务器:
enter image description here
我已经尝试了所有可能的名称,但我不知道自己写错了什么:
我的 docker 撰写:

version: "3.7"
services:
emasa-postgres:
image: postgres
environment:
POSTGRES_PASSWORD: emasa@
POSTGRES_USER: postgres
POSTGRES_DB: emasa
volumes:
- ./pgdata:/var/lib/postgresql/data
ports:
- "5432:5432"
networks:
- postgres-compose-network
web:
image: emasa-web
depends_on:
- emasa-postgres
ports:
- "4000:4000"
networks:
- postgres-compose-network
teste-pgadmin-compose:
image: dpage/pgadmin4
environment:
PGADMIN_DEFAULT_EMAIL: "emasa@hotmail.com"
PGADMIN_DEFAULT_PASSWORD: "emasa"
ports:
- "16543:80"
depends_on:
- emasa-postgres
networks:
- postgres-compose-network

networks:
postgres-compose-network:
driver: bridge
DockerFile的:
FROM node as builder
WORKDIR usr/app
COPY package*.json ./
RUN npm install
COPY . .
RUN npm run build


FROM node
WORKDIR usr/app
COPY package*.json ./
RUN npm install --production

COPY --from=builder /usr/app/dist ./dist

COPY ormconfig.docker.json ./ormconfig.json
COPY .env .

expose 4000
CMD node dist/src/index.js
我的orm配置:
{
"type": "postgres",
"host": "db",
"port": 5432,
"username": "postgres",
"password": "emasa@",
"database": "postgres",
"synchronize": true,
"logging": false,
"entities": ["src/entity/**/*.ts"],
"migrations": ["src/migration/**/*.ts"],
"subscribers": ["src/subscriber/**/*.ts"],
"cli": {
"entitiesDir": "src/entity",
"migrationsDir": "src/migration",
"subscribersDir": "src/subscriber"
}
}
我的docker-compose记录器:
Attaching to back-end_web_1, back-end_emasa-postgres_1, back-end_teste-pgadmin-compose_1
emasa-postgres_1 | The files belonging to this database system will be owned by user "postgres".
emasa-postgres_1 | This user must also own the server process.
emasa-postgres_1 |
emasa-postgres_1 | The database cluster will be initialized with locale "en_US.utf8".
emasa-postgres_1 | The default database encoding has accordingly been set to "UTF8".
emasa-postgres_1 | The default text search configuration will be set to "english".
emasa-postgres_1 |
emasa-postgres_1 | Data page checksums are disabled.
emasa-postgres_1 |
emasa-postgres_1 | fixing permissions on existing directory /var/lib/postgresql/data ... ok
emasa-postgres_1 | creating subdirectories ... ok
emasa-postgres_1 | selecting dynamic shared memory implementation ... posix
emasa-postgres_1 | selecting default max_connections ... 20
emasa-postgres_1 | selecting default shared_buffers ... 400kB
emasa-postgres_1 | selecting default time zone ... Etc/UTC
emasa-postgres_1 | creating configuration files ... ok
emasa-postgres_1 | 2020-03-17 23:48:08.890 UTC [81] FATAL: data directory "/var/lib/postgresql/data" has wrong ownership
emasa-postgres_1 | 2020-03-17 23:48:08.890 UTC [81] HINT: The server must be started by the user that owns the data directory.
emasa-postgres_1 | child process exited with exit code 1
emasa-postgres_1 | initdb: removing contents of data directory "/var/lib/postgresql/data"
emasa-postgres_1 | running bootstrap script ... web_1 | Error: getaddrinfo ENOTFOUND db
我的容器ls:
docker container ls
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
3a20bcd4f105 emasa-web "docker-entrypoint.s…" 5 minutes ago Up 5 minutes 0.0.0.0:4000->4000/tcp back-end_web_1
b377e650e772 dpage/pgadmin4 "/entrypoint.sh" 14 minutes ago Up 14 minutes 443/tcp, 0.0.0.0:16543->80/tcp back-end_teste-pgadmin-compose_1
[![在此处输入图片描述] [2]] [2]
我真的尝试过使用容器名称:
emasa-postgres_1
Emasa-Postgres
无济于事

最佳答案

在您提供的日志中可以看到问题的原因。

2020-03-17 23:48:08.890 UTC [81] FATAL: data directory "/var/lib/postgresql/data" has wrong ownership



您可能正在Windows计算机上运行docker?如果是这样,这似乎是一个常见的错误- check here。因此,您可能要使用永久性的Docker卷,而不是

services:
emasa-postgres:
...
volumes:
- pgdata:/var/lib/postgresql/data
networks:
- postgres-compose-network

volumes:
pgdata:

I still have doubts about my compose which localhost to use in pgadmin



为了从 emasa-postgres连接到 pgadmin,您可以像这样设置 emasa-postgres容器的主机名和网络别名:

services:
emasa-postgres:
hostname: my_super_cool_postgres
image: postgres
networks:
postgres-compose-network:
aliases:
- my_super_cool_postgres

您应该可以通过主机 localhost连接到数据库,而不是使用 dbmy_super_cool_postgres

这样,您应该可以从pgadmin连接到postgres容器。如果仍然无法使用,您也可以尝试使用 links(这是Docker的旧功能),但应该可以使用,例如

services:
teste-pgadmin-compose:
image: dpage/pgadmin4
links:
- "emasa-postgres:my_super_cool_postgres"

这次,您必须将其设置为 teste-pgadmin-compose(或从任何需要访问 emasa-postgres容器的位置)。然后应该可以访问主机 my_super_cool_postgres和端口 5432

关于node.js - Docker-撰写我无法创建Postgres服务器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60731782/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com