如何关闭mysql匿名用户_mysql安全初始化配置方法

MySQL安全初始化需删除匿名用户、为root设强密码并限制登录主机、禁用远程root访问、绑定本地地址,并运行mysql_secure_installation加固。

MySQL 默认安装后可能包含匿名用户(用户名为空)或 root 无密码账户,这会带来严重安全隐患。关闭匿名用户、设置强密码、限制 root 登录范围,是 MySQL 安全初始化的关键步骤。

检查并删除匿名用户

匿名用户指 user 列为空('')的账户,它们可能允许未授权访问。先用 root 登录 MySQL:

mysql -u root -p

执行以下命令查看所有用户:

SELECT user, host FROM mysql.user;

若发现 user'' 的行(如 ''@'localhost'),立即删除:

  • DROP USER ''@'localhost';
  • DROP USER ''@'127.0.0.1';
  • DROP USER ''@'::1';

注意:MySQL 5.7+ 必须用 DROP USER,不能只删 mysql.user 表记录;执行后需 FLUSH PRIVILEGES; 生效。

为 root 用户设置强密码并限制登录主机

避免 root 可从任意主机('%')无密码登录。推荐仅允许可信地址访问:

  • 修改本地 root 密码(MySQL 5.7.6+ 推荐用 ALTER USER):
    ALTER USER 'root'@'localhost' IDENTIFIED BY 'YourStrongPass123!';
  • 如需远程管理,单独创建受限账户,而非开放 'root'@'%';若必须,用:
    CREATE USER 'root'@'192.168.1.100' IDENTIFIED BY 'AnotherStrongPass!';
    再赋予必要权限,而非直接授权 'root'@'%'
  • 删除不安全的通配符 root 账户(如有):
    DROP USER 'root'@'%';

禁用远程 root 登录(默认关闭更安全)

MySQL 默认绑定 127.0.0.1,但配置文件可能被改写为 bind-address = 0.0.0.0,导致监听公网。检查并修正:

  • 编辑 MySQL 配置文件(通常为 /etc/mysql/mysql.conf.d/mysqld.cnf/etc/my.cnf
  • 确认 bind-address 设置为:
    bind-address = 127.0.0.1(仅本地)或指定内网 IP
  • 重启服务:sudo systemctl restart mysql(Ubuntu/Debian)或 sudo systemctl restart mysqld(CentOS/RHEL)

随后用 netstat -tlnp | grep :3306 验证是否只监听本地。

运行 mysql_secure_installation(一键加固)

MySQL 自带脚本可自动完成多数基础加固操作:

  • 执行:sudo mysql_secure_installation
  • 按提示操作:设置 root 密码、删除匿名用户、禁止 root 远程登录、删除 test 数据库、重载权限表
  • 该脚本本质是执行上述 SQL 和配置检查,适合快速初始化,但建议仍手动核对用户列表和 bind-address

不复杂但容易忽略