pgsql 不能链接数据库问题 求大佬解答

2021-09-11 23:54:10 +08:00
 0c0c0f
$ psql
psql: error: FATAL: database locale is incompatible with operating system
DETAIL: The database was initialized with LC_COLLATE "en_US", which is not recognized by setlocale().
HINT: Recreate the database with another locale or install the missing locale.
1865 次点击
所在节点    PostgreSQL
13 条回复
CitizenR
2021-09-12 08:18:32 +08:00
错误提示很清楚:你创建的数据库 locale 是 en_US,但是操作系统不存在这个 locale 。

个人建议使用 en_US.utf8 重新创建一下数据库。
0c0c0f
2021-09-12 09:17:23 +08:00
@CitizenR 谢谢解答。背景是做数据恢复, 那是我需要在系统安装 en_US 这个 locale ?
CitizenR
2021-09-12 09:22:14 +08:00
@0c0c0f 可以试试。
0c0c0f
2021-09-12 12:28:32 +08:00
@0c0c0f 这个 locale 没安装成功
iseki
2021-09-12 19:38:22 +08:00
你是不是使用了和这个数据库运行时不同的操作系统环境,这可能是不被允许的
0c0c0f
2021-09-12 22:05:57 +08:00
@iseki 数据库应该是正常运行的 数据库运行时的操作系统环境有可能不同 这个不确定。
Aether
2021-09-12 22:22:20 +08:00
@0c0c0f 直接开个新虚拟机然后拖进去试试看?
0c0c0f
2021-09-12 22:39:30 +08:00
@Aether 尝试下载了个镜像 配置了 pg_data 目录 进入新容器执行 psql 还是报同样的错误。新虚拟机有啥要求?
iseki
2021-09-12 22:44:59 +08:00
0c0c0f
2021-09-13 09:10:57 +08:00
@iseki OK 这个工具我后面试试 主要是目前数据库比较大
Aether
2021-09-15 17:40:26 +08:00
@0c0c0f 我的意思就是,新虚拟机应该更方便配置 locale 吧?
0c0c0f
2021-09-16 11:10:02 +08:00
@Aether 了解 谢谢
0c0c0f
2021-09-22 11:49:59 +08:00
使用带有 en_US 的 locale 容器启动 问题解决

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/801290

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX