mysql系统安全管理与优化
admin
2023-04-27 11:22:31
0

1. 禁止MySql以管理员账号权限运行

MySql应该使用非管理员账号运行,以普通账户安全运行mysqld

加固方法:在my.cnf配置文件中配置user=mysql


2. 设置root用户口令并修改登录名,且不存在空密码账户

  • 修改root用户密码,在MySql控制台中执行:

> set password for 'root'@'localhost'=password('new_password');
#实际操作中,只需将上面new_password换成实际的口令即可
  • 为了更有效的改进root用户的安全性,就是为其改名。需要更新表用户中的mysql数据库。在控制台中执行:

> use mysql;
> update user set user="another_username" where user="root";
> flush privileges;

然后,可用通过$ mysql -u another_username -p 访问mysql控制台了。

  • 数据库中所有用户都应该配置密码,通过以下语句可以查询是否有空密码账户:

> select * from mysql.user where user="";


3. 配置合适的密码强度,最长使用期限小于90天

  • 数据库用户Miami复杂性包括长度、大小写和特殊字符。

加固方法:添加以下配置行到全局配置

plugin-load = validate_password.so        #加载密码强度验证插件
validate_password_length = 14             #密码长度最小为14,默认为8      
validate_password_mixed_case_count = 1    #至少包含的小写字母个数和大写字母个数
validate_password_number_count = 1        #至少包含的数字个数
validate_password_special_char_count = 1  #至少包含的特殊字符个数
validate_password_policy = MEDIUM         #密码强度等级,有三种:0/LOW、1/MEDIUM、2/STRONG,默认为MEDIUM

关于密码强度的三种等级,要求如下:

Policy                 Tests Performed
0 or LOW               Length
1 or MEDIUM            Length; numeric, lowercase/uppercase, and special characters
2 or STRONG            Length; numeric, lowercase/uppercase, and special characters; dictionary file
  • 用户密码过期时间小于90天,在控制台执行:

> set global default_password_lifetime=90;


4. 降低用户的数据库特权,只有管理员有完整的数据库访问权限

  • MySql数据库中mysql.user和mysql.db表列出了可以授权(或拒绝)给mysql用户的各种权限,通常,这些特权不应该对每个mysql用户都可用,而且通常只保留给管理员用户。

加固方法:审计每项特权授予的用户,对于非管理用户,使用revoke语句来适当删除权限。

# mysql.user表中的特权有:
file_priv:表示是否允许用户读取数据库所在主机的本地文件;
Process:表示是否允许用户查询所有用户的命令执行信息;
Super_priv:表示用户是否有设置全局变量,管理员调试等高级别权限;
Shutdown_priv:表示用户是否可以关闭数据库;
Create_user_priv:表示用户是否可以创建或删除其他用户;
Grant_priv:表示用户是否可以修改其他用户权限

查询正在执行的sql语句:

> show processlist;
# 或者
> use information_schema;
> select * from PROCESSLIST where info is not null;

使用如下命令查看拥有对应权限的数据库账号:

select host,user from mysql.user where File_priv='Y';

如果存在非管理员用户,使用如下命令进行权限回收:

revoke file on *.* from 'mysql';



5. 禁止或限制远程访问,确保特定主机才拥有访问权限

> grant all on *.* to 'root'@'%';
  • 上面这个授权,允许root用在所有主机上对数据库的所有执行权限,要限制特定主机可以采用:

> grant all on *.* to 'root'@'localhost';
> grant all on *.* to 'root'@'hostname_ip'; #可以是ip或者主机名

如果,要取消在某台主机上的访问权限,可以采用:

> revoke all on *.* from 'root'@'hostname_ip';

如果,只授权部分权限,可以采用:

> grant select on mydb.* to 'someuser'@'hostname_ip';


6. 配置MySql日志便于审计




相关内容

热门资讯

工作时间减少1%,肥胖率或下降... 澎湃新闻记者 季敬杰合理调整生活与工作的平衡可能会给健康带来意想不到的好处。近日一项研究指出,年度工...
美媒:中美元首会晤或讨论AI护... 据凤凰卫视援引美国媒体报道,美方希望借中美领导人会晤的机会,开启有关人工智能安全与管控的对话,并推动...
卫生间水管布置图尺寸高度 卫生间的水管布置可能比较复杂一些,因为卫生间的管道比较多。比如有热水器的通水管道,有座便器的冲水管道...
电脑尺寸在哪里看 电脑尺寸在哪里看1、可以选择手工测量法来测量电脑尺寸,这时测量一下屏幕对角线,因为显示面积都会小于显...
电脑机箱尺寸标准 常规的机箱一般是立体式,或桌面式,再就是横式。电脑机箱尺寸,目前市面上根据不同的规格有不同的方案。 ...
斯塔默发声:不会辞职 【环球时报驻英国特约记者 纪双城 环球时报特约记者 甄翔 于文】执政党工党在英国地方选举中遭遇“历史...
抽油烟机管道有异味怎么办 抽油烟机是厨房中不可或缺的设备,它能有效地排出油烟,保证室内空气的清新。但是,长时间使用后,抽油烟机...
抽油烟机管道有油垢怎么办 抽油烟机管道是我们家庭生活中必不可少的设备,但长时间的使用会导致管道内部积累大量的油垢,如不及时清理...
沈伯洋与台北市长格局有落差,叶... 海峡导报综合报道 民进党将正式拍板征召民代沈伯洋出战台北市长,并发布采访通知,预计在13日下午举行台...
核查:上世纪已有多款汉坦疫苗上... 明查员 冯梦速览- 人类感染汉坦病毒已有数十年历史。朝鲜战争期间,联合国军就曾有过大规模感染。汉坦病...