前言
你是否曾遇到这样的场景:周末在家休息,突然收到告警——线上服务异常,急需排查数据库;
或是在出差途中,临时需要验证某个数据变更,却因无法访问内网而束手无策?在现代DevOps与远程办公常态化的大背景下,安全、可靠地远程访问内网数据库已成为运维和开发人员的刚需。然而,出于安全策略,绝大多数企业服务器都部署在私有网络中,既无公网IP,也不开放数据库端口(如3306),传统远程连接方式几乎行不通。别担心!本文将带你从零开始,在Debian 12系统上完整搭建一套生产级MariaDB服务,并同步实现两大关键能力:
✅ 实时监控:通过mysqld_exporter+Prometheus 构建可观测性体系,让数据库性能、连接状态、慢查询等指标一目了然;
✅ 安全远程访问:借助Cpolar内网穿透工具,无需改动防火墙、无需申请公网 IP,即可从家中、咖啡馆甚至高铁上,安全连接到公司内网的MariaDB实例。
整套方案全部基于开源工具,部署简单、成本为零,且严格遵循最小权限原则,兼顾功能性与安全性。无论你是系统管理员、开发工程师,还是正在学习数据库运维的学生,都能通过本文快速掌握这一实用技能。准备好了吗?让我们一起打通“最后一公里”,让内网数据库真正为你所用!

1.配置前提条件
在正式开始安装和配置MariaDB之前,请确保您已做好以下准备工作,以保障后续操作顺利进行:
- 一台运行Debian 12的操作系统环境:该服务器应已成功安装并正常启动,且能够稳定接入互联网,以便下载官方软件包及依赖项。
- 具备管理员权限的用户账户:您需要拥有一个具有sudo权限的非root用户账户。
- 可交互的命令行终端:无论是通过SSH远程连接,还是在物理机/虚拟机上本地登录,您都需要打开一个终端窗口,用于执行后续的命令行操作。
- 一款熟悉的文本编辑器:在配置MariaDB的过程中,您可能需要编辑配置文件(如 /etc/mysql/mariadb.conf.d/50-server.cnf)。请确保系统中已安装并熟悉至少一种命令行文本编辑器,例如轻量级的nano、功能强大的vim,或其他您习惯使用的编辑工具。
小贴士:建议在操作前更新系统软件包列表(sudo apt update),以确保安装的是最新稳定版本的MariaDB,并减少潜在的兼容性问题。

完成以上准备后,您就已为MariaDB的安装、安全加固与初始化配置打下了坚实基础。
2.安装MariaDB
2.1系统升级
始终建议在安装之前安装最新的系统软件包以避免依赖性问题。运行以下命令:
sudo apt update && sudo apt upgrade -y

2.2 安装所需的软件包
接下来,安装必要的软件包,如下所示:
sudo apt install curl software-properties-common dirmngr -y

2.3 添加MariaDB APT存储库
分别运行以下命令导入MariaDB签名密钥并添加MariaDB APT存储库:
curl -LsS -O https://downloads.mariadb.com/MariaDB/mariadb_repo_setup
sudo bash mariadb_repo_setup --mariadb-server-version=10.6
2.4 在Debian上安装MariaDB
接下来,更新软件包并安装MariaDB服务器
sudo apt update
sudo apt install mariadb-server mariadb-client

2.5 启动并启用MariaDB
现在运行以下命令来启动 MariaDB 并使其在系统重新启动时自动启动:
sudo systemctl start mariadb
sudo systemctl enable mariadb
sudo systemctl status mariadb

2.6 安全的MariaDB安装
成功安装MariaDB后,请按如下所示继续保护它:

2.7 检查MariaDB版本
要检查MariaDB版本,我们需要登录MariaDB,如下所示。如果您设置了root密码,请使用 -p。
mysql -u root -p

然后运行以下MySQL命令来检查MariaDB版本:
SELECT VERSION();

2.8 MariaDB基本命令
MariaDB创建数据库:
CREATE DATABASE shan;

MariaDB添加用户并授予权限:
CREATE USER 'myuser'@'localhost' IDENTIFIED BY 'mypassword';
GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'localhost' IDENTIFIED BY 'mypassword';
GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'localhost';
FLUSH privileges;
SHOW GRANTS FOR 'myuser'@'locahost';

创建表并添加数据MariaDB:
创建数据库后,您可以创建表并向其中添加数据。
CREATE TABLE shan (id INT, name VARCHAR(20), email VARCHAR(20));
INSERT INTO shan (id,name,email) VALUES(01,"lorna","[email]");

MariaDB清理:
要完全删除MariaDB,请运行以下命令。
sudo apt purge mariadb-server
sudo rm -rf /var/lib/mysql/
3.使用mysql_exporter监控MariaDB
3.1 为什么用mysqld_exporter监控MariaDB?
因为它是“用一套工具,监控两个世界”的典范。
- 兼容性好:MariaDB ≈ MySQL协议
- 功能全面:覆盖性能、连接、复制、资源等核心维度
- 生态成熟:Prometheus + Grafana开箱即用
- 官方认可:MariaDB社区明确推荐
因此,无需寻找“MariaDB Exporter”——直接使用mysqld_exporter就是最优解。
3.2 安装mysql_exporter
在prometheus的官网下载对应的mysql_exporter的linux版本:Download | Prometheus

下载完成后上传到/app目录下:

也可以使用这个命令一键安装(可自定义版本):
wget
https://github.com/prometheus/mysqld_exporter/releases/download/v0.18.0/mysqld_exporter-0.18.0.linux-amd64.tar.gz
解压mysql_exporter压缩文件:
tar -zxvf mysqld_exporter-0.18.0.linux-amd64.tar.gz

修改mysql_exporter文件名:
mv mysqld_exporter-0.18.0.linux-amd64/ mysqld_exporter

3.3 启动mysql_exporter
创建mysql用户与权限,在MySQL数据库中创建一个专门用于监控的用户,并赋予其足够的权限来查询所需的信息:
GRANT REPLICATION CLIENT, PROCESS ON *.* TO 'mysqld_exporter'@'localhost' identified by '12345678';
GRANT SELECT ON performance_schema.* TO 'mysqld_exporter'@'localhost';
flush privileges;

创建一个文件,输入我们刚创建好的用户名及密码:
vi localhost_db.cnf
[client]
user=exporter
password=12345678

创建mysql_exporter服务:
vi /etc/systemd/system/mysqld_exporter.service
[Unit]
Description=exporter
After=network.target
[Service]
Type=simple
User=prometheus
ExecStart=/app/mysqld_exporter/mysqld_exporter --config.my-cnf=/app/mysqld_exporter/localhost_db.cnf --web.listen-address=:9105
Restart=on-failure
[Install]
WantedBy=multi-user.target

添加prometheus用户,并修改对应权限:
sudo useradd --system --no-create-home --shell /sbin/nologin prometheus
sudo chown -R prometheus:prometheus /app/mysqld_exporter/
sudo chmod 600 /app/mysqld_exporter/localhost_db.cnf
启动服务并设置开机自启动:
sudo systemctl daemon-reload
sudo systemctl start mysqld_exporter
sudo systemctl status mysqld_exporter # 查看是否成功
sudo systemctl enable mysqld_exporter # 设置开机自启(可选)

4.配置prometheus监控mysql_exporter
没有prometheus的小伙伴可以参考这篇文章:监控不再局域网!Cpolar 让 Prometheus 走出内网限制! – cpolar 极点云官网
找到prometheus的配置文件,编辑添加如下内容:
vi prometheus.yml
- targets: ["ip:9105"]
labels:
app: "mysqld_exporter"

重启prometheus服务:
systemctl restart prometheus
使用浏览器Ip+9090打开promethues的页面:

我们可以看到成功的检测到了mysql_exporter服务啦!

现在,我们已经成功完成了MariaDB的安装,并通过mysqld_exporter与Prometheus构建了一套完整的数据库监控体系,能够实时掌握连接数、查询性能、主从状态等关键指标。然而,在实际工作中,我们常常面临一个现实需求:如何从外部网络(比如家里、出差途中)安全地连接到公司内网的MariaDB数据库?由于公司服务器通常部署在私有网络中,没有公网IP,且出于安全考虑,防火墙不会直接开放3306端口给互联网——这就导致传统的远程连接方式行不通。这时候,就轮到Cpolar闪亮登场了!借助Cpolar的内网穿透能力,我们可以在不改动现有网络架构、无需申请公网IP、不必开放防火墙端口的前提下,建立一条加密、可靠、带身份认证的隧道,将公司内网的MariaDB服务安全地映射到一个公网可访问的地址。这样一来,无论你身处何地,只要拥有授权,就能像访问本地服务一样,安全连接到公司的数据库——真正实现“内网数据库,远程随心连”。接下来,我们就来演示如何用Cpolar安全打通这条连接通道。
5.安装cpolar实现随时随地开发
5.1 什么是cpolar?
cpolar是一款安全高效的内网穿透工具,无需公网IP或复杂配置,只需一条命令,即可将本地服务器、Web服务或任意端口映射到公网,让你随时随地远程访问内网应用,特别适合开发调试、远程运维和应急部署等场景。
5.2 部署cpolar
cpolar 可以将你本地电脑中的服务(如 SSH、Web、数据库)映射到公网。即使你在家里或外出时,也可以通过公网地址连接回本地运行的开发环境。
❤️以下是安装cpolar步骤:
使用一键脚本安装命令:
sudo curl https://get.cpolar.sh | sh

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

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

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

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

通过Cpolar提供的公网地址和端口,MariaDB就可以从任意一台主机连接到啦!
mysql -h 2.tcp.cpolar.top -P 15969 -u remote_user -p

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

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

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

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

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

最后测试一下固定的地址是否好用,测试命令:
mysql -h 8.tcp.cpolar.top -P 11849 -u remote_user -p

这样,我们成功打破了“没有公网IP就无法远程访问数据库”的固有认知。
总结
本文完整演示了如何在Debian 12上从零部署MariaDB,通过mysqld_exporter与Prometheus实现专业级监控,并借助Cpolar内网穿透技术,安全实现“在家连接公司数据库”的远程访问需求。整套方案无需公网IP、不开放防火墙端口,兼顾安全性、可观测性与实用性,为开发者和运维人员提供了一套轻量、可靠、开箱即用的数据库远程运维解决方案。
感谢您对本篇文章的喜爱,有任何问题欢迎留言交流。cpolar官网-安全的内网穿透工具 | 无需公网ip | 远程访问 | 搭建网站


