我正在尝试在 postgres 中创建表空间,但遇到所有权问题。我正在使用的命令是:
CREATE TABLESPACE magdat OWNER maggie LOCATION '/home/john/BSTablespace'
我收到错误:
ERROR: could not set permissions on directory "/home/john/BSTablespace": Operation not permitted
该文件夹属于 postgres:postgres,我尝试将其更改为 maggie,但如果我去:
chown maggie:postgres /home/john/BSTablespace
I get:
chown: invalid user: `maggie:postgres'
为什么用户不存在?如果我列出 postgres 内的用户,它就会出现。有什么想法我可能做错了什么吗?
我大胆猜测问题出在父目录“/home/john”的权限上。您的主目录可能已设置为只有您的用户有权访问(即 chmod 700)(将您的主目录设置为 chmod 700 是件好事,不要更改它)。
做类似的事情:
mkdir /BSTablespace
chown postgres:postgres /BSTablespace
and then
CREATE TABLESPACE magdat OWNER maggie LOCATION '/BSTablespace';
应该可以正常工作。
关于用户maggie:数据库用户与操作系统用户不同。这并不是说您不能在两个地方都拥有名为 maggie 的用户,但您需要在数据库和操作系统中创建该用户才能实现这一点。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)