alpine/psqlalpine/psql 是一个基于Alpine Linux的轻量级Docker镜像,包含PostgreSQL官方命令行客户端psql。该镜像旨在提供便捷的PostgreSQL数据库连接与管理工具,无需在主机系统直接安装psql客户端,即可通过容器化方式快速与PostgreSQL数据库交互。
psql客户端,支持与各版本PostgreSQL数据库的标准交互。psql,通过容器快速连接远程或本地PostgreSQL数据库。psql客户端,避免版本冲突。[***]
[***]
暂无(N/A)
通过alias将psql命令映射到容器运行,简化后续使用:
bashalias psql="docker run -ti --rm alpine/psql"
--rm:容器退出后自动删除,避免残留容器。-ti:分配交互式终端,支持命令行输入。使用psql参数指定数据库信息连接:
bashpsql -d <数据库名> -U <用户名> -W
-d:指定目标数据库名称。-U:指定连接用户名。-W:强制提示输入密码(避免明文密码暴露)。通过完整连接字符串连接(推荐用于复杂配置,如SSL、端口自定义等):
bash# 示例连接字符串格式:postgres://用户名:密码@主机:端口/数据库名?参数 export PSQL_CONNECTION_STRING="postgres://psqladmin:***:5432/psql?sslmode=require" psql $PSQL_CONNECTION_STRING
sslmode=require:强制使用SSL加密连接(根据数据库配置调整,可选值:disable、allow、prefer、require等)。执行本地SQL脚本文件(需将脚本挂载到容器内,或通过标准输入传递):
bash# 方法1:通过`-v`挂载本地脚本文件到容器/tmp目录 docker run -ti --rm -v $(pwd)/policy.sql:/tmp/policy.sql alpine/psql $PSQL_CONNECTION_STRING -f /tmp/policy.sql # 方法2:使用管道传递脚本内容(适用于无需持久化的临时脚本) cat policy.sql | psql $PSQL_CONNECTION_STRING
-f:指定要执行的SQL脚本文件路径(容器内路径)。psql客户端常用参数如下:
| 参数 | 说明 |
|---|---|
-d, --dbname=DBNAME | 指定连接的数据库名称 |
-U, --username=USERNAME | 指定连接用户名 |
-h, --host=HOSTNAME | 指定数据库主机地址(默认:localhost) |
-p, --port=PORT | 指定数据库端口(默认:5432) |
-W, --password | 强制提示输入密码(即使未指定,若数据库要求密码也会提示) |
-f, --file=FILENAME | 执行指定文件中的SQL命令 |
-c, --command=COMMAND | 执行单行SQL命令(如:psql -c "SELECT version();") |
-t, --tuples-only | 仅输出查询结果数据,不包含表头和额外格式 |
-v, --set=VAR=VALUE | 设置psql变量(如:-v ON_ERROR_STOP=1 遇到错误时停止执行) |
| 变量名 | 说明 | 示例 |
|---|---|---|
PSQL_CONNECTION_STRING | 存储完整的PostgreSQL连接字符串,用于简化命令行输入 | postgres://user:pass@host:5432/db?sslmode=require |
latest、14等)manifest unknown 错误
TLS 证书验证失败
DNS 解析超时
410 错误:版本过低
402 错误:流量耗尽
身份认证失败错误
429 限流错误
凭证保存错误
来自真实用户的反馈,见证轩辕镜像的优质服务