加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

使用semctl …无效参数连接到PostgreSQL失败

发布时间:2020-12-13 16:23:00 所属栏目:百科 来源:网络整理
导读:我运行initdb,尝试使用createuser -sdrP myuser创建一个新的超级用户 我得到的错误是 createuser:无法连接到数据库postgres:致命:semctl(3342342,3,SETVAL,0)失败:参数无效 我无法在互联网上找到任何关于此的信息.我已经尝试了卸载,删除数据目录,然后重
我运行initdb,尝试使用createuser -sdrP myuser创建一个新的超级用户

我得到的错误是

createuser:无法连接到数据库postgres:致命:semctl(3342342,3,SETVAL,0)失败:参数无效

我无法在互联网上找到任何关于此的信息.我已经尝试了卸载,删除数据目录,然后重试但没有骰子.我的智慧结束了.

我正在一个运行FreeBSD 9.2-RELEASE-p10的监狱里跑.是的,我设置了allow.sysvipc = 1

PostgreSQL很可能找不到它之前创建的信号量.另一个(不相关的)进程可能正在删除信号量(可能是一个调用ipcrm的脚本).

启动PostgreSQL后立即使用ipcs -s列出sempahores,然后在遇到问题时再次列出sempahores.除非另一个进程主动删除信号量比在PostgreSQL启动后运行ipcs -s测试更快,否则你应该能够通过比较两个sempahore列表来确定PostgreSQL信号量是否实际上被删除了.

这并不能告诉你哪个(根)进程是罪魁祸首,但它确实指向了正确的方向.幸运的是,违规过程是一个脚本,在这种情况下,您可以搜索执行ipcrm调用的root执行脚本.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读