root用户安装postgresql和 postgres用户-bash问题

今天遇到一个奇葩的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。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值