没公网IP怎么远程连数据库?PostgreSQL + cpolar,在任何网络环境下都能连上

前言

做开发的人大概都遇到过这种情况:本地 PostgreSQL 数据库搭好了,数据也导进去了,结果同事想连过来看效果,或者客户临时要看个 demo,才发现数据库跑在内网,没有公网 IP,根本连不进去。

换云数据库太贵,配置frp太麻烦,搬家到有公网 IP 的机器上又要数据迁移------感觉为了连个数据库做了半辈子工程。

我之前也是这么想的。直到开始用 cpolar 做内网穿透,发现把本地数据库暴露给外部网络这件事,比我预想的简单太多了。

具体操作就三步:在 Linux 上装好 PostgreSQL,确认本地能连;装好 cpolar,一条命令把端口映射到公网;拿到生成的公网地址和端口,任何地方用 psql 或者数据库客户端直接连。整个过程不需要改路由器、不需要云服务器、不需要固定 IP,家庭宽带、移动网络、公司内网都能跑通。

PostgreSQL 本身在本地跑就很稳,cpolar 的作用是开一个通道把本地端口暴露到公网,让你人在外面也能像在本地一样操作数据库。这篇说一下具体步骤,不绕弯子。

1.在Centos7上安装postgresql

本次在linux环境安装。

在官网上选择 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地址记录。

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

修改隧道信息,将保留成功的TCP端口配置到隧道中。

  • 端口类型:选择固定TCP端口
  • 预留的TCP地址:填写保留成功的TCP地址

点击更新

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

最后测试一下固定的地址是否好用,测试命令:

shell 复制代码
psql -h 8.tcp.vip.cpolar.cn -p 13299 -U postgres -d mydb

这样,我们成功打破了"没有公网 IP 就无法远程访问数据库"的固有认知。

总结

用 cpolar 打通之后,数据库放在哪就不重要了。放在家里电脑、放在公司服务器、放在虚拟机里,只要机器能联网,就能连上。

这个方案用来应付临时需求很顺手------比如同事要看个数据、客户要看个 demo,不用专门去配云数据库环境,直接给他一个地址就行。长期跑的话还是建议走正经云服务,但这种"临时伸手就能够到"的感觉,用过就知道方便。

相关推荐
yoothey3 小时前
MySQL事务机制解析 - 面试高分知识点
数据库·mysql·面试
swordbob3 小时前
NIO 的 Channel 里有多个 BIO 吗?
linux·网络·nio
天天讯通4 小时前
OKCC 呼叫中心安全性能全解析:技术防护与管理措施指南
大数据·开发语言·网络·人工智能·安全·语音识别
Lkstar4 小时前
万字长文Query改写与多路召回实战|从HyDE到RRF融合,召回率提升22%的完整方案
数据库·人工智能·llm
IT新视界4 小时前
星环科技ArgoDB:基于一体化架构构建数据全生命周期安全底座
数据库·科技·安全·架构
峥无4 小时前
MySQL DML 操作(CRUD)总结
数据库·mysql
数据库小学妹5 小时前
SQL Server数据库同步工具怎么选?6款方案对比+信创迁移避坑清单
数据库·经验分享·sqlserver·dba
咸鱼翻身小阿橙5 小时前
VS2008 + .NET3.5 环境、加热台TCP通讯场景
tcp/ip·php·.net
不剪发的Tony老师5 小时前
国产数据库之GaussDB:固若金汤
数据库·gaussdb
leo_yu_yty5 小时前
Go语言分布式计算(RPC入门)
网络·网络协议·rpc