mysql 与 pg 的网卡监听参数

先说一下这个监听是干什么的,以mysql为例子,就是通过其他设备链接mysql服务的时候,mysql所在的服务器是可能有多个网卡的,也就是会有多个ip,bind-address就是用来限制只能通过哪个网卡来连接这个mysql服务

如,你设置了bind-address = 127.0.0.1,那么比如用mysql命令去连接

mysql -h 127.0.0.1 -u username -ppassword -P 3306 -D dbname

你的-h参数只能是127.0.0.1,当然对于这个ip可以不写这个参数

bind-address = 192.168.1.123

就只能是

mysql -h 192.168.1.123 -u username -ppassword -P 3306 -D dbname

才可以连接

ok,正文来了

mysql

bash 复制代码
​
[mysqld]
# 只允许本机连接
bind-address = 127.0.0.1

​
bash 复制代码
[mysqld]
# 允许所有连接
bind-address = 0.0.0.0
bash 复制代码
[mysqld]
# 只监听特定IP
bind-address = 192.168.1.100

为什么写三遍?因为只允许监听一个ip

假设服务器有三块网卡:

  • 127.0.0.1(本地)

  • 192.168.1.100(内网)

  • 172.16.0.100(另一内网段)

如果你想让MySQL同时监听两个内网IP,但不想监听公网IP:
不行,MySQL参数不支持这样。只能:

  1. 0.0.0.0监听所有(包括不想监听的)

  2. 或者用防火墙规则限制访问来源IP

  3. 或者使用改变mysql的用户权限,来限制允许的用户ip,说白了就是黑白名单,这个后面会细说

验证

bash 复制代码
netstat -anp | grep 3306

# 或

ss -lntp | grep 3306

(有空再总结一下这些命令吧QWQ,有些不常用的东西还是容易忘记的,小QQ)

然后再补充一下,用sql怎么查询这个参数

sql 复制代码
SHOW VARIABLES LIKE 'bind_address';

SHOW GLOBAL VARIABLES WHERE Variable_name = 'bind_address';

然后还有这两个

sql 复制代码
# 5.7往上
SELECT * FROM performance_schema.global_variables 
WHERE variable_name = 'bind_address';
# 往下
SELECT * FROM information_schema.global_variables
WHERE variable_name = 'bind_address';

最后是配置位置

复制代码
/etc/my.cnf
/etc/mysql/my.cnf
/usr/local/mysql/etc/my.cnf

pg

/var/lib/postgresql/data/postgresql.conf

bash 复制代码
echo "listen_addresses = 'localhost'" >> /var/lib/postgresql/data/postgresql.conf

类似这样既可以了

详细的跟mysql一样,但是有一个小重点

pg允许多个监听,可以改成这

bash 复制代码
listen_addresses = 'localhost, 192.168.1.100'
相关推荐
坚定信念,勇往无前4 分钟前
electron-vite 安装better-sqlite3
javascript·数据库·electron
大明者省9 分钟前
Ubuntu22.04 宝塔面板与 XFCE 远程桌面端口兼容性分析
运维·服务器·数据库·笔记
liudanzhengxi34 分钟前
巧用ULN2003A轻松扩展单片机IO口
数据库·mongodb
Teable任意门互动42 分钟前
深度解析:AI 赋能开源多维表格,实现企业全场景数据整合与高效应用
数据库·人工智能·低代码·信息可视化·开源·数据库开发
还是鼠鼠1 小时前
AI掘金头条新闻系统 (Toutiao News)-相关推荐
后端·python·mysql·fastapi·web
DevOpenClub1 小时前
职教高考及高职分类招生控制线 API 接口
java·数据库·高考
funnycoffee1231 小时前
华为S5736交换机3层ECMP负载方式
linux·服务器·数据库
添砖java‘’1 小时前
MySQL复合查询
数据库·mysql
星川水月1 小时前
Access数据库快速入门——外部数据导入和SQL简单查询
数据库·sql·access