我试图用一个shell脚本自动化数据库创建过程,其中一件事我遇到了传递密码到psql的障碍。 下面是shell脚本的一段代码:

psql -U $DB_USER -h localhost -c"$DB_RECREATE_SQL"

如何以非交互的方式将密码传递给psql ?


当前回答

使用PGPASSWORD环境变量的另一种方法是根据文档使用conninfo字符串:

指定连接参数的另一种方法是在conninfo中 字符串或URI,用来代替数据库名称。这 机制使您可以对连接进行非常广泛的控制。

$ psql "host=<server> port=5432 dbname=<db> user=<user> password=<password>"

postgres=>

其他回答

来自官方文件:

有一个~/也很方便。Pgpass文件,以避免定期输入密码。有关更多信息,请参阅第30.13节。

...

该文件应包含以下格式的行:

hostname:port:database:username:password

将使用与当前连接参数匹配的第一行中的password字段。

在调用psql之前,在脚本中设置环境变量PGPASSWORD

PGPASSWORD=pass1234 psql -U MyUsername myDatabaseName

参考网站:http://www.postgresql.org/docs/current/static/libpq-envars.html


Edit

自从Postgres 9.2以来,还可以指定包含用户名和密码的连接字符串或URI。语法是:

$ psql postgresql://[user[:password]@][host][:port][,...][/dbname][?param1=value1&...]

使用该密码存在安全风险,因为当其他用户查看正在运行的进程的命令行时,密码以纯文本形式可见,例如使用ps (Linux)、ProcessExplorer (Windows)或类似工具时。

另请参阅有关数据库管理员的问题

这可以通过在(Linux)用户的主目录中创建一个.pgpass文件来实现。 .pgpass文件格式:

<databaseip>:<port>:<databasename>:<dbusername>:<password>

你也可以使用通配符*来代替细节。

假设我想运行tmp。SQL而不提示输入密码。

用下面的代码你可以在*.sh文件中

echo "192.168.1.1:*:*:postgres:postgrespwd" > $HOME/.pgpass
echo "` chmod 0600 $HOME/.pgpass `"

echo " ` psql -h 192.168.1.1 -p 5432  -U postgres  postgres  -f tmp.sql `        
psql postgresql://myawsumuser:myPassword@127.0.0.1:5432/myawsumdb

如果在一个答案中添加大部分选项还不算太晚的话:

这里有几个选项:

在pgpass文件中设置它。链接

设置一个环境变量并从那里获取它: 出口PGPASSWORD = '密码' 然后运行你的PSQL来登录,甚至运行命令 : psql -h clustername -U username -d testdb . xml 在窗口中,你必须使用"set": 设置PGPASSWORD=pass,然后登录psql bash。 通过URL和env变量传递: psql”postgresql: / / $ USER_NAME: PASSWORD@ HOST_NAME美元/ DB_NAME美元”