过去查询mysql的时候,都见3306对所有端口开放着,感觉不安全。
netstat -anlp | grep mysql
tcp 0 0 0.0.0.0:3306 0.0.0.0:* listen 638/mysqld
unix 2 [ acc ] stream listening 12305521 638/mysqld /tmp/mysql.sock
当然,也想过用iptables来实现,不过好像还是不行。
iptables -a input -p tcp -s $any --dport 3306 -j drop
引用chinaunix文章所说:
*安全配置* 为了数据的安全,可以考虑让mysql只守候在127.0.0.1上,这样从internet上就无法直接访问数据库了。 修改/etc/init.d/mysql文件 在start部分找到类似下面这行 $bindir/mysqld_safe --datadir=$datadir --pid-file=$pid_file &修改成
$bindir/mysqld_safe --datadir=$datadir --pid-file=$pid_file --bind-address=127.0.0.1 &重起mysql
/etc/init.d/mysql restart最后netstat -l确认一下:
tcp 0 0 localhost:mysql *:* listenok
而我修改/etc/init.d/mysq,找到:
把原先的
$bindir/mysqld_safe --datadir=$datadir --pid-file=$pid_file >/dev/null 2>&1 &
$bindir/mysqld_safe --datadir=$datadir --pid-file=$pid_file --bind-address=127.0.0.1 &
重启mysql:/etc/init.d/mysql restart
查看后实现:natstat -l
tcp 0 0 localhost.localdo:mysql *:* listen菜鸟学堂:
新闻热点
疑难解答