配置 Odoo 的 PostgreSQL 数据库以允许远程访问的步骤

1. 修改 PostgreSQL 配置文件

a. 修改 `postgresql.conf`

找到 PostgreSQL 的主配置文件 `postgresql.conf`,通常位于 `/etc/postgresql/<版本号>/main/` 目录下。修改 `listen_addresses` 项的值为 `'*'`,表示允许来自任何 IP 地址的连接:

复制代码
sudo nano /etc/postgresql/<版本号>/main/postgresql.conf

找到如下行(通常是被注释的):

复制代码
#listen_addresses = 'localhost'

修改为:

复制代码
listen_addresses = '*'

2. 配置客户端认证

编辑 `pg_hba.conf` 文件来配置客户端认证,通常位于 `/etc/postgresql/<版本号>/main/` 目录下。在文件末尾添加以下行:

复制代码
sudo nano /etc/postgresql/<版本号>/main/pg_hba.conf

添加以下配置行:

复制代码
host    all    all    0.0.0.0/0    md5

这行配置表示:

  • `host`:允许 TCP/IP 连接
  • `all`:允许访问所有数据库
  • `all`:允许所有用户
  • `0.0.0.0/0`:允许来自任何 IP 地址的连接
  • `md5`:使用 MD5 加密的密码认证

如果不希望允许所有 IP 远程访问,可以将 `0.0.0.0/0` 替换为特定的 IP 地址或子网,例如:

复制代码
host    all    all    192.168.1.0/24    md5

3. 重启 PostgreSQL 服务

配置修改后,需要重启 PostgreSQL 服务使更改生效:

复制代码
sudo systemctl restart postgresql

4. 验证配置

可以使用以下命令验证 PostgreSQL 是否正在监听远程连接:

复制代码
sudo netstat -plnt | grep postgres

应该能看到类似这样的输出:

复制代码
tcp        0      0 0.0.0.0:5432            0.0.0.0:*               LISTEN      1234/postgres

5. 配置防火墙

如果系统开启了防火墙,需要允许 PostgreSQL 端口(默认为 5432)的访问:

复制代码
sudo ufw allow 5432/tcp

6. 测试远程连接

使用远程工具(如 DataGrip、pgAdmin 或命令行工具)连接到 PostgreSQL 数据库:

  • Host:数据库服务器的 IP 地址
  • Port:5432
  • Database:您的数据库名称
  • User:数据库用户(如 `odoo` 或 `postgres`)
  • Password:数据库用户的密码

安全建议

  • 限制 IP 范围:不建议在生产环境中使用 `0.0.0.0/0`,应该只允许特定的 IP 地址或子网。
  • 使用强密码:确保数据库用户使用强密码。
  • 启用 SSL:建议使用 SSL 连接以提高安全性。
  • 定期更新:定期更新 PostgreSQL 到最新的安全版本。

通过以上步骤,您可以成功配置 Odoo 的 PostgreSQL 数据库以允许远程访问。

相关推荐
小云数据库服务专线6 分钟前
GaussDB 数据库架构师(八) 等待事件概述-1
数据库·数据库架构·gaussdb
是Yu欸2 小时前
【浏览器插件冲突】Edge浏览器加载不出来CSDN创作者中心
java·数据库·edge
安卓开发者2 小时前
Android Room 持久化库:简化数据库操作
android·数据库
极简之美2 小时前
spring boot h2数据库无法链接问题
数据库·spring boot·oracle
SelectDB4 小时前
浩瀚深度:从 ClickHouse 到 Doris,支撑单表 13PB、534 万亿行的超大规模数据分析场景
大数据·数据库·apache
SelectDB4 小时前
公开免费!Apache Doris & SelectDB 培训与认证课程正式上线
大数据·数据库·apache
我的ID配享太庙呀4 小时前
从零开始:在 PyCharm 中搭建 Django 商城的用户注册与登录功能(轮播图+商品页-小白入门版)
数据库·python·django·sqlite·web·教育电商
大视码垛机4 小时前
协作机器人掀起工厂革命:码垛场景如何用数据重塑制造业命脉?
大数据·数据库·人工智能
火凤凰--凤凰码路6 小时前
MySQL 中的“双路排序”与“单路排序”:原理、判别与实战调优
android·数据库·mysql
m0_564264188 小时前
开源数据库E-R图绘制工具分享
数据库·经验分享·mysql·e-r图·开源工具