首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在远程服务器中创建数据库

在远程服务器中创建数据库
EN

Server Fault用户
提问于 2011-05-10 14:31:58
回答 3查看 4.4K关注 0票数 0

我想在远程linux服务器上安装postgresql数据库。为了在远程服务器上创建数据库,我在python中编写了一个脚本,该脚本在服务器上执行命令。我按照如下顺序运行这些命令:

代码语言:javascript
复制
cmd = "wget http://yum.pgrpms.org/reporpms/8.4/pgdg-centos-8.4-2.noarch.rpm"
execute cmd

cmd = "rpm -Uvh http://yum.pgrpms.org/reporpms/8.4/pgdg-centos-8.4-2.noarch.rpm"
execute cmd


cmd = "yum install postgresql postgresql-server"
execute cmd

...and等。

利用postgres的安装和数据库的启动,一切都可以很好地工作。当我想在postgreql中创建一个数据库时,问题就出现了。我发现我必须切换到'postgres‘用户并运行psql,以便执行任何与数据库相关的命令。例如:

代码语言:javascript
复制
# su postgres
# psql
# create database test;

...but,因为我将所有的逗号依次通过远程python代码(如第一个示例所示),因此似乎不可能在客户机上同时运行这三个命令(su postgrespsqlcreate)。有没有办法同时运行这三个命令?

我按照命令运行:

代码语言:javascript
复制
# su postgres && psql && create database test;

...but只执行第一个comamnd (su postgres)。

EN

回答 3

Server Fault用户

回答已采纳

发布于 2011-05-10 14:35:23

试试看,我没试过

代码语言:javascript
复制
su - postgres -c 'psql -c "create database test"'

因此,您将以postgres用户的身份起诉,并使用命令运行psql命令。

票数 2
EN

Server Fault用户

发布于 2011-05-10 14:37:09

尝试在非交互模式下使用psql。例如:

代码语言:javascript
复制
psql -c "create database test"

另一种方法是使用createdb包装器。检查http://www.postgresql.org/docs/8.4/static/app-createdb.html

正如Mike编写的,以另一个用户的身份运行命令(在本例中为postgres),请使用su with -c选项。

票数 2
EN

Server Fault用户

发布于 2011-05-10 14:35:33

其他答案很好地解决了这个特定命令行的问题,但是如果您正在处理来自Python的远程主机,也许您应该看看帕拉米科。这是一个何图

另一种选择是交换矩阵

票数 0
EN
页面原文内容由Server Fault提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://serverfault.com/questions/268192

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档