配置 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 数据库以允许远程访问。

相关推荐
川石课堂软件测试5 分钟前
Oracle 数据库:视图与索引
数据库·网络协议·nginx·http·oracle·grafana·prometheus
理智的煎蛋4 小时前
MySQL高可用架构:MHA
linux·数据库·mysql·架构·可用性测试
罗光记4 小时前
苹果内部 AI聊天机器人“Asa”曝光,为零售员工打造专属A
数据库·经验分享·百度·微信公众平台·新浪微博
li35746 小时前
从“内存操作”到“原子更新”:一次代码思维的跃迁
数据库·oracle
瀚高PG实验室6 小时前
执行select * from a where rownum<1;,数据库子进程崩溃,业务中断。
数据库·sql·瀚高数据库
小白考证进阶中6 小时前
终于赶在考试券过期前把Oracle OCP证书考下来了!
运维·数据库·oracle·dba·开闭原则·数据库管理员
DCTANT7 小时前
【报错记录】OpenGauss/磐维数据库连接报:org.postgresql.util.PSQLException: 致命错误: 账户被锁定
数据库·postgresql
keep__go7 小时前
postgresql9.2.4 跨版本升级14.6
linux·运维·数据库·postgresql
Doris_LMS7 小时前
Git的强软硬回退(三)
运维·服务器·数据库·git·idea
williamdsy8 小时前
【postgresql】JPA LIKE 查询触发 PostgreSQL `text ~~ bytea` 报错的排查与最佳实践
数据库·postgresql