CentOS 6.2 上 PostgreSQL 9.1 的使用
CentOS 6.2 上 PostgreSQL 9.1 的使用,在用yum安装好postgresql之后,就可以通过service来管理它了。这个postgresql-9.1 的位置
前一篇文章()在用yum安装好postgresql之后,就可以通过service来管理它了。这个postgresql-9.1 的位置在
/etc/rc.d/init.d/postgresql-9.1
可以看到它里面默认使用了一个名为postgres的OS用户名(从这个脚本可以看到很多yum在安装postgresql后的目录位置、环境变量等)。这个postgres用户名就是()这里提到的
In order to bootstrap the database system, a freshly initialized system always contains one predefined role. This role is always a "superuser", and by default (unless altered when running initdb) it will have the same name as the operating system user that initialized the database cluster. Customarily, this role will be named postgres. In order to create more roles you first have to connect as this initial role.
也就是说,系统会默认创建一个role,而且这个role在不指定(可以通过initdb指定)的情况下,它的name和当前初始化数据库实例的OS用户的name一样的。一般这个name就是postgres。从/etc/rc.d/init.d/postgresql-9.1里面也可以看到,,脚本会把很多文件和文件夹的owner设置为postgres。
所以当你刚安装好postgres,迫不及待的想通过psql连接数据库的时候都会遇到()这里提到的错误。因为psql认为你要使用当前的OS用户的name去连接数据库。错误如下:
createdb: could not connect to database postgres: FATAL: role "joe" does not exist
当然,如果你自己的OS用户的name就是postgres,那你运气就太好了。:D
所以你需要
su - postgres
来切换到postgres用户下去,然后一个简单的:
psql
就可以顺利的连接到数据库了。
然后\password 可以修改你的密码。
在postgres下面
createuser root
切换到root下面后,就可以
createdb
默认创建名为root的数据库。然后psql命令就可以连接到数据库了。
上一篇: SQL Server2008 自动备份
推荐阅读
-
在PostgreSQL上安装并使用扩展模块的教程
-
.Net Core 使用 System.Drawing.Common 部署到CentOS上遇到的问题
-
CentOS 6.2 上 PostgreSQL 9.1 的使用
-
Centos服务器上NFS灾备环境及KVM的搭建及使用
-
详解Xampp和wordpress在Centos7上的搭建与使用
-
Kafka的使用之在CentOS上安装Kafka集群
-
CentOS7使用yum安装PostgreSQL和PostGIS的方法
-
CentOS7 最小化安装后,使用Xshell连接VMware上的Linux虚拟机
-
mysql5.7 on centos7上使用systemctl管理多个端口及创建多个端口的脚本(代码实现)
-
CentOS 6.2上使用YUM安装MySQL