sudo su - postgres 是什么意思?
解释
PostgreSQL 安装成功之后,会默认创建一个名为 postgres 的 Linux 用户。
# su:Shift user切换用户,参数为用户名。如果是root用户切换至其他用户不需要输入密码,否则需要输入密码。
# sudo:Super user do超级用户操作,默认以root用户来执行该命令,也就是授予该命令root权限
# su - postgres:变更帐号为postgres并改变工作目录至postgres的家目录(home dir)
# sudo su - postgres:使用sudo授权切换到postgres用户并改变工作目录至postgres的家目录
sudo su - postgres
验证
<!-- permisssion:许可; denied:否认; Permission Denied:未获得许可、权限被拒绝 -->
[root@linxuanVM ~]# su postgres
# 使用ll命令发现该命令根本没有找到
bash-4.2$ ll
bash: ll: command not found
# 使用ls命令发现权限被拒绝
bash-4.2$ ls
ls: cannot open directory .: Permission denied
# 当前所在目录为/root目录,因此导致没有权限
bash-4.2$ pwd
/root
bash-4.2$ exit
exit
[root@linxuanVM ~]# su - postgres
Last login: Mon Jul 31 14:58:33 CST 2023 on pts/0
# 执行命令没有问题
-bash-4.2$ ll
total 8
drwx------ 4 postgres postgres 4096 Jul 30 16:21 14
-rw-r--r-- 1 postgres postgres 1910 Jul 31 11:13 mydb.bak
# 执行命令没有问题
-bash-4.2$ ls
14 mydb.bak
# 当前所在目录为/var/lib/pgsql
-bash-4.2$ pwd
/var/lib/pgsql
-bash-4.2$ exit
logout