今天遇到一个奇葩的postgresql安装步骤,简直惊掉了下巴。。。。。
首先来看一下postgres用户
刚开始以为这是postgres用户被篡改了,导致家目录的文件被删除所导致的
这个先不管,根据其他部门的想法,想看看数据库是不是在启动。
先查看一下无法登录
再次查看一下进程在不在,发现进程也不存在,忽略其他用户txadmin(我听说他们用的postgres,具体的业务逻辑,安装到哪了,数据目录在哪没有一个人知道的,知道的人都已经离职了,只有一个经理问我数据库是不是在启动。。。。。。。。。)
看到这我得去查一下pg的安装目录和数据目录在哪吧,于是我去查环境变量,无语了,啥也没有
于是用find 去查一下
除了txdb4.0之外,还有四个。。。 看这个意思是
/usr/bin/pg_ctl和/opt/pgsql-12.2/bin/pg_ctl好像是他们的安装目录
那看一下数据目录,那大概也就是/mnt/pgdata/目录了
(1)这一看就是源码安装的
(2)这个大概就是yum安装的吧。
总所周知,源码无法使用root初始化
那如果我在postgres用户下去初始化呢,提示根本没有这个用户
好嘛,这下终于知道了,通过yum安装postgresql数据
yum安装完后,居然有了postgres用户,而且和我们前面的-bash 能对应上
也就是说yum安装,可以自动创建postgres用户,之后我再切换用户安装,发现安装目录也必须是postgres用户。
改变所属用户后,再次初始化
最后总结出结论:
利用了yum创建出来的postgres用户,而不是自己去创建的用户(真会投机取巧呀)
安装目录:/opt/pgsql-12.2/
数据目录: /mnt/pgdata/
postgresl用户 -bash-4.2$ 也没问题
启动数据库命令
-bash-4.2$ /opt/pgsql-12.2/bin/pg_ctl start -D /mnt/pgdata -l /tmp/pglog
总结:
1、使用 root 进行源码编译安装,数据库集簇无法进行初始化。
2、rpm 包可以使用 root 去安装,初始化数据库集簇 postgresql-setup initdb ,默认安装到/var/lib/pgsql/data。
3、安装目录所属用户可以为root,数据目录可以为postgres。