知识大全 MySQL数据库安全配置指南
Posted 数据库
篇首语:宁给好汉拉马,不给懒汉作爷。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 MySQL数据库安全配置指南相关的知识,希望对你有一定的参考价值。
MySQL数据库安全配置指南 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!
前言 MySQL是完全网络化的跨平台关系型数据库系统 同时是具有客户机/服务器体系结构的分布式数据库管理系统 它具有功能强 使用简便 管理方便 运行速度快 安全可靠性强等优点 用户可利用许多语言编写访问MySQL数据库的程序 特别是与PHP更是黄金组合 运用十分广泛 由于MySQL是多平台的数据库 它的默认配置要考虑各种情况下都能适用 所以在我们自己的使用环境下应该进行进一步的安全加固 作为一个MySQL的系统管理员 我们有责任维护MySQL数据库系统的数据安全性和完整性 MySQL数据库的安全配置必须从两个方面入手 系统内部安全和外部网络安全 另外我们还将简单介绍编程时要注意的一些问题以及一些小窍门 系统内部安全 首先简单介绍一下MySQL数据库目录结构 MySQL安装好 运行了mysql_db_install脚本以后就会建立数据目录和初始化数据库 如果我们用MySQL源码包安装 而且安装目录是/usr/local/mysql 那么数据目录一般会是/usr/local/mysql/var 数据库系统由一系列数据库组成 每个数据库包含一系列数据库表 MySQL是用数据库名在数据目录建立建立一个数据库目录 各数据库表分别以数据库表名作为文件名 扩展名分别为MYD MYI frm的三个文件放到数据库目录中 MySQL的授权表给数据库的访问提供了灵活的权限控制 但是如果本地用户拥有对库文件的读权限的话 攻击者只需把数据库目录打包拷走 然后拷到自己本机的数据目录下就能访问窃取的数据库 所以MySQL所在的主机的安全性是最首要的问题 如果主机不安全 被攻击者控制 那么MySQL的安全性也无从谈起 其次就是数据目录和数据文件的安全性 也就是权限设置问题 从MySQL主站一些老的binary发行版来看 xx版本中数据目录的属性是 这样非常危险 任何本地用户都可以读数据目录 所以数据库文件很不安全 xx版本中数据目录的属性是 这种属性也有些危险 本地的同组用户既能读也能写 所以数据文件也不安全 xx版本数据目录的属性是 这样就比较好 只有启动数据库的用户可以读写数据库文件 保证了本地数据文件的安全 如果启动MySQL数据库的用户是mysql 那么象如下的目录和文件的是安全的 请注意数据目录及下面的属性 shell>ls l /usr/local/mysql total drwxrwxr x root root Feb : bin drwxrwxr x root root Feb : include drwxrwxr x root root Feb : info drwxrwxr x root root Feb : lib drwxrwxr x root root Feb : libexec drwxrwxr x root root Feb : man drwxrwxr x root root Feb : mysql test drwxrwxr x root root Feb : share drwxrwxr x root root Feb : sql bench drwx mysql mysql Feb : var shell>ls l /usr/local/mysql/var total drwx mysql mysql Feb : mysql drwx mysql mysql Feb : test shell>ls l /usr/local/mysql/var/mysql total rw mysql mysql Feb : columns_priv MYD rw mysql mysql Feb : columns_priv MYI rw mysql mysql Feb : columns_priv frm rw mysql mysql Feb : db MYD rw mysql mysql Feb : db MYI rw mysql mysql Feb : db frm rw mysql mysql Feb : func MYD rw mysql mysql Feb : func MYI rw mysql mysql Feb : func frm rw mysql mysql Feb : host MYD rw mysql mysql Feb : host MYI rw mysql mysql Feb : host frm rw mysql mysql Feb : tables_priv MYD rw mysql mysql Feb : tables_priv MYI rw mysql mysql Feb : tables_priv frm rw mysql mysql Feb : user MYD rw mysql mysql Feb : user MYI rw mysql mysql Feb : user frm 如果这些文件的属主及属性不是这样 请用以下两个命令修正之 shell>chown R mysql mysql /usr/local/mysql/var shell>chmod R go rwx /usr/local/mysql/var 用root用户启动远程服务一直是安全大忌 因为如果服务程序出现问题 远程攻击者极有可能获得主机的完全控制权 MySQL从 版本开始时作了小小的改动 默认安装后服务要用mysql用户来启动 不允许root用户启动 如果非要用root用户来启动 必须加上 user=root的参数( /safe_mysqld user=root &) 因为MySQL中有LOAD DATA INFILE和SELECT INTO OUTFILE的SQL语句 如果是root用户启动了MySQL服务器 那么 数据库用户就拥有了root用户的写权限 不过MySQL还是做了一些限制的 比如LOAD DATA INFILE只能读全局可读的文件 SELECT INTO OUTFILE不能覆蓋已经存在的文件 本地的日志文件也不能忽视 包括shell的日志和MySQL自己的日志 有些用户在本地登陆或备份数据库的时候为了图方便 有时会在命令行参数里直接带了数据库的密码 如 shell>/usr/local/mysql/bin/mysqldump uroot ptest test>test sql shell>/usr/local/mysql/bin/mysql uroot ptest 这些命令会被shell记录在历史文件里 比如bash会写入用户目录的 bash_history文件 如果这些文件不慎被读 那么数据库的密码就会泄漏 用户登陆数据库后执行的SQL命令也会被MySQL记录在用户目录的 mysql_history文件里 如果数据库用户用SQL语句修改了数据库密码 也会因 mysql_history文件而泄漏 所以我们在shell登陆及备份的时候不要在 p后直接加密码 而是在提示后再输入数据库密码 另外这两个文件我们也应该不让它记录我们的操作 以防万一 shell>rm bash_history mysql_history shell>ln s /dev/null bash_history shell>ln s /dev/null mysql_history 上门这两条命令把这两个文件链接到/dev/null 那么我们的操作就不会被记录到这两个文件里了 外部网络安全 MySQL数据库安装好以后 Unix平台的user表是这样的 mysql> use mysql; Database changed mysql> select Host User Password Select_priv Grant_priv from user; educity cn/img_ / / / jpg> 图 rows in set ( sec) Windows平台的user表是这样的 mysql> use mysql; Database changed mysql> select Host User Password Select_priv Grant_priv from user; educity cn/img_ / / / jpg> 图 rows in set ( sec) 我们先来看Unix平台的user表 其中redhat只是我试验机的机器名 所以实际上Unix平台的MySQL默认只允许本机才能连接数据库 但是缺省root用户口令是空 所以当务之急是给root用户加上口令 给数据库用户加口令有三种方法 )在shell提示符下用mysqladmin命令来改root用户口令: shell>mysqladmin uroot password test 这样 MySQL数据库root用户的口令就被改成test了 (test只是举例 我们实际使用的口令一定不能使用这种易猜的弱口令) )用set password修改口令 mysql> set password for root@localhost=password( test ); 这时root用户的口令就被改成test了 )直接修改user表的root用户口令 mysql> use mysql; mysql> update user set password=password( test ) where user= root ; mysql> flush privileges; 这样 MySQL数据库root用户的口令也被改成test了 其中最后一句命令flush privileges的意思是强制刷新内存授权表 否则用的还是缓冲中的口令 这时非法用户还可以用root用户及空口令登陆 直到重启MySQL服务器 我们还看到user为空的匿名用户 虽然它在Unix平台下没什么权限 但为了安全起见我们应该删除它 mysql> delete from user where user= ; Windows版本MySQL的user表有很大不同 我们看到Host字段除了localhost还有是% 这里%的意思是允许任意的主机连接MySQL服务器 这是非常不安全的 给攻击者造成可乘之机 我们必须删除Host字段为%的记录 mysql>de cha138/Article/program/MySQL/201311/29418相关参考
jboss配置 mysql数据库连接池实例 :配置: JDK JBoss &n
Tomcat下配置MySQL数据库连接池 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! 在$CA
MYSQL的master/slave数据同步配置 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!
知识大全 Tomcat5配置Mysql JDBC数据库连接池
Tomcat5配置MysqlJDBC数据库连接池 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!
知识大全 浅析Tomcat5配置Mysql JDBC数据库连接池
浅析Tomcat5配置MysqlJDBC数据库连接池 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!
关于tomcat连接池的配置我在自己开始的时候碰到过许多的问题至少失败过六次今天终于成功了对于这个问题的产生与由来我也给大伙说说
保障网站数据库的安全MySQL数据库备份 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! 在数据库
MySQL数据库中的安全解决方案 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! 随着网络的普及基
数据安全之MySQL安全的二十三条军规 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! 使用MyS
改默认编码 /etc/initd/mysqlstart(stop)为启动和停止服务器 /etc/mysql/主要配置文件所在位置f /var/lib/mysql/放置的是数据库表文件夹这里的