设为首页收藏本站

LinuxTone | 运维专家网论坛 - 最棒的Linux运维与开源架构技术交流社区!

 找回密码
 注册

用新浪微博连接

一步搞定

QQ登录

只需一步,快速开始

查看: 4108|回复: 9

[MySQL管理] MySQL简单安全设置与优化 [复制链接]

LT管理团队

社区首席勤杂工

Rank: 9Rank: 9Rank: 9

签到
81
注册时间
2008-5-19
最后登录
2012-5-3
在线时间
1762 小时
阅读权限
200
积分
14979
帖子
2524
主题
1200
精华
25
UID
1

LT总司令

发表于 2008-6-1 16:33:58 |显示全部楼层
MySQL简单安全设置与优化(总结)


MySQL简单安全设置与优化

注本文并非原则,只是简单的总结,大家有问题多关注一下以下两个站点:
http://imysql.cn/
http://dev.mysql.com/doc/refman/5.1/zh/index.html
也可以在本站与我讨论交流.

1.修改root用户的的口令
缺省情况下MySQL没有设置密码,我们可以用三种方法设置密码头:

*  用mysqladmin命令来改root用户口令
# mysqladmin -uroot password 54netseek //设置MySQL管理操作用户root的密码为52netseek

*  用set password修改口令:
mysql> set password for root@localhost=password('54netseek);

*  直接修改user表的root用户口令     
mysql> use mysql;
mysql> update user set password=password('54netseek') where user='root';
mysql> flush privileges;

2.删除默认的数据库和用户
我们的数据库是在本地,并且也只需要本地的php脚本对mysql进行读取,所以很多用户不需要。m
ysql初始化后会自动生成空用户和test库,这会对数据库构成威胁,我们全部删除。
我们使用mysql客户端程序连接到本地的mysql服务器后出现如下提示:
mysql> drop database test;
mysql> use mysql;
mysql> delete from db;
mysql> delete from user where not(host="localhost" and user="root");
mysql> flush privileges;

3. 改变默认mysql管理员的名称 //仅为建议
根据个人习惯,因为默认的mysql的管理员名称是root,所以如果能够修改的话,
能够防止一些脚本小子对系统的穷举。我们可以直接修改数据库,把root用户改为"admin"
mysql> use mysql;
mysql> update user set user="admin" where user="root";
mysql> flush privileges;

4. 提高本地安全性
提高本地安全性,主要是防止mysql对本地文件的存取,比如黑客通过mysql把/etc/passwd获取了,会对系统构成威胁。
mysql对本地文件的存取是通过SQL语句来实现,主要是通过Load DATA LOCAL INFILE来实现,我们能够通过禁用该功能来
防止黑客通过SQL注射等获取系统核心文件。 禁用该功能必须在 my.cnf 的[mysqld]部分加上一个参数:
set-variable=local-infile=0

5. 禁止远程连接mysql
因为我们的mysql只需要本地的php脚本进行连接,所以我们无需开socket进行监听,那么我们完全可以关闭监听的功能。
有两个方法实现:
* 配置my.cnf文件,在[mysqld]部分添加 skip-networking 参数
* mysqld服务器中参数中添加 --skip-networking 启动参数来使mysql不监听任何TCP/IP连接,增加安全性。如果要进行mysql的管理的话,可以在服务器本地安装一个phpMyadmin来进行管理。

6.控制数据库访问权限
对于使用php脚本来进行交互,最好建立一个用户只针对某个库有 update、select、delete、insert、drop table、create table等权限,这样就很好避免了数据库用户名和密码被黑客查看后最小损失。
比如下面我们创建一个数据库为db1,同时建立一个用户test1能够访问该数据库。
mysql> create database db1;
mysql> grant select,insert,update,delete,create,drop privileges on db1.* to test1@localhost identified by 'admindb';
以上SQL是创建一个数据库db1,同时增加了一个test1用户,口令是admindb,但是它只能从本地连接mysql,对db1库有select,insert,update,delete,create,drop操作权限。

7. 限制一般用户浏览其他用户数据库
如果有多个数据库,每个数据库有一个用户,那么必须限制用户浏览其他数据库内容,可以在启动MySQL服务器时加--skip-show-database 启动参数就能够达到目的。

忘记mysql密码的解决办法
如果不慎忘记了MySQL的root密码,我们可以在启动MySQL服务器时加上参数--skip-grant-tables来跳过授权表的验证 (./safe_mysqld --skip-grant-tables &),这样我们就可以直接登陆MySQL服务器,然后再修改root用户的口令,重启MySQL就可以用新口令登陆了。

8. 数据库文件的安全
我们默认的mysql是安装在/usr/local/mysql目录下的,那么对应的数据库文件就是在/usr/local/mysql/var目录下,那么我们要保证该目录不能让未经授权的用户访问后把数据库打包拷贝走了,所以要限制对该目录的访问。
我们修改该目录的所属用户和组是mysql,同时改变访问权限:
# chown -R mysql.mysql /usr/local/mysql/var
# chmod -R go-rwx /usr/local/mysql/var

9.删除历史记录
执行以上的命令会被shell记录在历史文件里,比如bash会写入用户目录的.bash_history文件,如果这些文件不慎被读,
那么数据库的密码就会泄漏。用户登陆数据库后执行的SQL命令也会被MySQL记录在用户目录的.mysql_history文件里。
如果数据库用户用SQL语句修改了数据库密码,也会因.mysql_history文件而泄漏。所以我们在shell登陆及备份的时候
不要在-p后直接加密码,而是在提示后再输入数据库密码。 另外这两个文件我们也应该不让它记录我们的操作,以防万一。
# rm .bash_history .mysql_history
# ln -s /dev/null .bash_history
# ln -s /dev/null .mysql_history

10. 其他
另外还可以考虑使用chroot等方式来控制mysql的运行目录,更好的控制权限,具体可以参考相关文章。
my.cnf的调试参数


11.快速修复MySQL数据库
修复数据库
# mysqlcheck -A -o -r -p
修复指定的数据库
# mysqlcheck  -o -r Database_NAME -p

--------------------------------------
12.跟据内存的大小选择MySQL的负载,选择相应的文件名复制到/etc/my.cnf
如果是RPM包安装:/usr/share/doc/mysql-XXX/目录下有
如果是源代码编译安装:support-files/目录下有.
cp /usr/local/share/mysql-***/my-large.cnf /etc/my.cnf
my-small.cnf # > my-medium.cnf # 32M - 64M
my-large.cnf # memory = 512M
my-huge.cnf # 1G-2G
my-innodb-heavy-4G.cnf # 4GB
感谢大家对linuxtone的支持!

Rank: 6Rank: 6

注册时间
2009-9-29
最后登录
2012-5-17
在线时间
25 小时
阅读权限
70
积分
2305
帖子
34
主题
1
精华
0
UID
5686
发表于 2009-10-15 22:29:47 |显示全部楼层
好东西
非常感谢大好人

使用道具 举报

Rank: 7Rank: 7Rank: 7

注册时间
2009-1-21
最后登录
2012-5-22
在线时间
292 小时
阅读权限
100
积分
11258
帖子
151
主题
45
精华
1
UID
1127

LT粉丝

发表于 2009-11-3 15:18:54 |显示全部楼层
好文

使用道具 举报

Rank: 6Rank: 6

注册时间
2010-9-7
最后登录
2012-5-10
在线时间
37 小时
阅读权限
70
积分
2056
帖子
92
主题
23
精华
0
UID
10321
发表于 2010-9-15 14:57:36 |显示全部楼层
我要快递修复库里的某个表!怎么操作!·

使用道具 举报

论坛元老

小兵

Rank: 8Rank: 8

注册时间
2010-10-9
最后登录
2012-5-15
在线时间
250 小时
阅读权限
90
积分
15060
帖子
103
主题
13
精华
1
UID
10553
发表于 2010-12-12 23:41:25 |显示全部楼层
本帖最后由 outhink 于 2010-12-12 23:41 编辑

挺好。。
相信outhink
http://outhink.blog.51cto.com
不是路不平,只是你不行。

使用道具 举报

Rank: 8Rank: 8

注册时间
2009-11-13
最后登录
2012-5-21
在线时间
119 小时
阅读权限
90
积分
10958
帖子
23
主题
5
精华
0
UID
6607
发表于 2010-12-29 13:34:27 |显示全部楼层
好东西啊...

使用道具 举报

Rank: 8Rank: 8

注册时间
2009-11-20
最后登录
2012-5-15
在线时间
89 小时
阅读权限
90
积分
15827
帖子
155
主题
1
精华
0
UID
6746
发表于 2011-1-11 10:16:21 |显示全部楼层
学习一下了!

使用道具 举报

Rank: 8Rank: 8

注册时间
2011-7-10
最后登录
2012-5-22
在线时间
70 小时
阅读权限
90
积分
4613
帖子
76
主题
0
精华
0
UID
14906
发表于 2011-7-24 18:05:00 |显示全部楼层
好东西。

使用道具 举报

Rank: 8Rank: 8

注册时间
2011-4-4
最后登录
2012-5-23
在线时间
76 小时
阅读权限
90
积分
15270
帖子
17
主题
0
精华
0
UID
12676
发表于 2011-8-4 13:23:27 |显示全部楼层
一般应用够了,实用,感谢楼主

使用道具 举报

Rank: 6Rank: 6

注册时间
2010-9-10
最后登录
2012-5-19
在线时间
61 小时
阅读权限
70
积分
1646
帖子
89
主题
16
精华
0
UID
10349
发表于 2011-8-4 16:12:12 |显示全部楼层
收藏

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

IT运维专家网感谢红之盟网络提供带宽支持

合作联系: QQ:67888954/MSN:cnseek@msn.com/mail:netseek@linuxtone.org

Archiver|手机版|感谢所有关心和支持过LinuxTone的朋友们 转载本站内容请注明原作者名及出处 ( 京ICP备08103151 )   |

GMT+8, 2012-5-23 10:21 , Processed in 0.157229 second(s), 12 queries , Memcache On.

Powered by Discuz! X2

© 2001-2011 Comsenz Inc.

回顶部