
PostgreSQL 作为一款开源的关系型数据库管理系统,核心功能覆盖复杂数据存储、多维度数据查询、事务处理等,适配从个人开发者到中大型企业的各类数据管理需求,其高稳定性、可扩展性和数据完整性保障是突出优势,无论是小型项目的数据存储还是企业级应用的海量数据处理,都能稳定支撑。
使用 PostgreSQL 的过程中发现,这款数据库虽功能强大,但初始配置需注意权限管理和网络访问规则,比如默认仅允许本地连接,若不调整配置,外部设备根本无法接入,且数据备份和多终端同步的操作门槛对新手不算友好,需要逐步摸索。

仅局限在局域网内使用 PostgreSQL 时,实际工作中会遇到诸多不便:比如跨地区团队协作时,异地同事无法直接访问数据库调试程序,只能靠导出数据文件来回传输,不仅效率低,还容易出现数据版本不一致的问题;外出办公时,想临时查询数据库里的业务数据,也只能等回到公司内网环境,耽误工作进度。
而将 PostgreSQL 与 cpolar 内网穿透结合后,这些问题都能迎刃而解。无需额外申请公网 IP,就能把本地数据库服务映射到公网,异地的团队成员可随时连接数据库协作,外出时用手机或笔记本也能轻松访问,既保留了 PostgreSQL 的数据管理优势,又打破了局域网的物理限制,让数据库使用场景更灵活。

优秀搭配优秀只能是1+1>2。让数据库随身而行,参考下面的教程就能实现呦!
本文将带你从零开始,一步步实现 PostgreSQL 的远程安全暴露,用 cpolar 打通内网与公网之间的"任督二脉",真正实现"我在哪,数据库就在哪"。
准备好了吗?让我们开始这场"反向穿越"之旅!
1.在Centos7上安装postgresql
本次在linux环境安装。
下载地址:postgreSQL官网
在官网上选择 Linux系统,使用 yum来下载软件,只需选择对应版本和平台,即可生成下载和安装的脚本。

按照生成的脚本,安装。我这里是:
shell
sudo yum install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64/pgdg-redhat-repo-latest.noarch.rpm
sudo yum install -y postgresql14-server
sudo /usr/pgsql-14/bin/postgresql-14-setup initdb
sudo systemctl enable postgresql-14
sudo systemctl start postgresql-14
按照步骤一步步操作。




修改PostgreSQL管理员密码。
shell
su postgres
// 切换SQL模式
psql
// 修改密码
alter user postgres with password 'postgres123';

配置远程访问。
修改pg_hba.conf,新增如下:
shell
sudo vim /var/lib/pgsql/14/data/pg_hba.conf

新增一行:
shell
host all all 0.0.0.0/0 scram-sha-256

修改监听地址为任意地址,即修改postgresql.conf文件:
shell
vi /var/lib/pgsql/15/data/postgresql.conf

修改地址为 * :
shell
listen_addresses = '*'

重新启动:
shell
systemctl restart postgresql-14
切换到postgres用户,新建mydb库:
shell
su postgres
create database mydb;

使用另一台服务器,远程连接到该库:
shell
psql -h 192.168.42.140 -p 5432 -U postgres -d mydb

成功!
2.安装cpolar内网穿透工具
cpolar 可以将你本地电脑中的服务(如 SSH、Web、数据库)映射到公网。即使你在家里或外出时,也可以通过公网地址连接回本地运行的开发环境。
❤️以下是安装cpolar步骤:
使用一键脚本安装命令:
shell
sudo curl https://get.cpolar.sh | sh

安装完成后,执行下方命令查看cpolar服务状态:(如图所示即为正常启动)
shell
sudo systemctl status cpolar

Cpolar安装和成功启动服务后,在浏览器上输入虚拟机主机IP加9200端口即:【http://192.168.42.101:9200】访问Cpolar管理界面,使用Cpolar官网注册的账号登录,登录后即可看到cpolar web 配置界面,接下来在web 界面配置即可:
打开浏览器访问本地9200端口,使用cpolar账户密码登录即可,登录后即可对隧道进行管理。

3.配置公网地址
通过配置,你可以在本地 WSL 或 Linux 系统上运行 SSH 服务,并通过 Cpolar 将其映射到公网,从而实现从任意设备远程连接开发环境的目的。
- 隧道名称:可自定义,本例使用了:postgres,注意不要与已有的隧道名称重复
- 协议:tcp
- 本地地址:192.168.42.140:5432
- 端口类型:随机临时TCP端口
- 地区:China Vip

创建成功后,打开左侧在线隧道列表,可以看到刚刚通过创建隧道生成了公网地址,接下来就可以在其他电脑或者移动端设备(异地)上,使用任意一个地址在终端中访问即可。
-
tcp 表示使用的协议类型
-
2.tcp.vip.cpolar.cn是 Cpolar 提供的域名
-
11084是随机分配的公网端口号

通过 Cpolar 提供的公网地址和端口,使用 SSH 协议从任意一台主机连接到postgres账号啦!
shell
psql -h 2.tcp.vip.cpolar.cn -p 11084 -U postgres -d mydb

4.保留固定TCP公网地址
使用cpolar为其配置TCP地址,该地址为固定地址,不会随机变化。

选择区域和描述:有一个下拉菜单,当前选择的是"China VIP"。
右侧输入框,用于填写描述信息。
保留按钮:在右侧有一个橙色的"保留"按钮,点击该按钮可以保留所选的TCP地址。
列表中显示了一条已保留的TCP地址记录。
-
地区:显示为"China VIP"。
-
地址:显示为"8.tcp.vip.cpolar.cn:13299"。

登录cpolar web UI管理界面,点击左侧仪表盘的隧道管理------隧道列表,找到所要配置的隧道postgres,点击右侧的编辑。

修改隧道信息,将保留成功的TCP端口配置到隧道中。
- 端口类型:选择固定TCP端口
- 预留的TCP地址:填写保留成功的TCP地址
点击更新。

创建完成后,打开在线隧道列表,此时可以看到随机的公网地址已经发生变化,地址名称也变成了保留和固定的TCP地址。

最后测试一下固定的地址是否好用,测试命令:
shell
psql -h 8.tcp.vip.cpolar.cn -p 13299 -U postgres -d mydb

这样,我们成功打破了"没有公网 IP 就无法远程访问数据库"的固有认知。
总结
PostgreSQL 本身具备优秀的数据管理能力,而 cpolar 则补齐了其远程访问的短板。二者结合后,无需复杂的网络配置,就能轻松实现数据库的跨网络访问,不管是团队协作还是移动办公,都能让数据管理更高效、更灵活。
感谢您对本篇文章的喜爱,有任何问题欢迎留言交流。cpolar官网-安全的内网穿透工具 | 无需公网ip | 远程访问 | 搭建网站