我在Postgres容器上定义了多个环境变量,例如POSTGRES_USER。容器正在运行,我想使用exec从命令行连接到Postgres。
我无法连接以下设备:
docker exec -it <CONTAINER-ID> psql -U $POSTGRES_USER -d <DB NAME>
我了解该变量是在容器上定义的,并且可以正常工作:
docker exec -it <CONTAINER-ID> bash -c 'psql -U $POSTGRES_USER -d <DB NAME>'
我是否可以直接从docker exec执行psql命令并在容器上调用环境变量?
docker exec -it <CONTAINER-ID> psql -U ????? -d <DB NAME>
根据您的用例,您可以做什么,而不是将用户传递给psql
命令,而是在引导时为容器定义环境变量PGUSER
。
这样,如果您不指定任何用户,它将成为PostgreSQL的默认用户,因此您甚至不必指定它即可进行连接:
$ docker run --name postgres -e POSTGRES_PASSWORD=bar -e POSTGRES_USER=foo -e PGUSER=foo -d postgres
e250f0821613a5e2021e94772a732f299874fc7a16b340ada4233afe73744423
$ docker exec -ti postgres psql -d postgres
psql (12.4 (Debian 12.4-1.pgdg100+1))
Type "help" for help.
postgres=#
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句