📄 1860.html
字号:
<TR>
<TD>
<TABLE cellSpacing=0 cellPadding=3 width="100%" border=0>
<TR>
<TD vAlign=top align=middle width="60%">
<TABLE cellSpacing=0 cellPadding=0 width="100%"
background="images/back.gif" tppabs="http://www.linuxhero.com/docs/images/back.gif" border=0>
<TBODY>
<TR>
<TD vAlign=top width="80%">
<DIV align=center>
<FORM action="search.html" tppabs="http://www.linuxhero.com/docs/search.html" method=get>
</FORM>
<TABLE cellSpacing=0 cellPadding=0 width="95%"
border=0><TBODY>
<TR>
<TD background="images/bgi.gif" tppabs="http://www.linuxhero.com/docs/images/bgi.gif"
height=30></TD></TR></TBODY></TABLE>
<TABLE cellSpacing=0 cellPadding=3 width="95%"
align=center border=0>
<TBODY>
<TR>
<TD>
<TABLE cellSpacing=0 cellPadding=3 width="100%"
border=0>
<TBODY>
<TR>
<TD vAlign=top>
<p><FONT class=normalfont><B><font color=blue>加固你的MySQL</font></B></FONT><BR><FONT class=smallfont color=#ff9900>2004-04-23 15:18 pm</FONT><BR><FONT class=normalfont>作者:光辉<br>来自:Linux知识宝库<br>联系方式:无名<br><br> 本文章从几个方面介绍如何加强MySQL服务器的安全性。(2004-03-04 20:29:37)
前言<br>
<br>
MySQL已经成为当前网络中使用最多的数据库之一,特别是在Web应用上,它占据了中小型应用的绝对优势。这一切都源于它的小巧易用、它的安全有效、它的开放式许可、它的多平台,更主要的是它与三大Web语言之——PHP的完美结合。<br>
<br>
但不幸的是,一个缺省安全的MySQL,会因为root密码为空及程序漏洞导致被溢出,使得安装MySQL的服务器成为被经常攻击的对象。更严重的是,被攻击之后数据库往往遭破坏,造成灾难性的后果。下面将进入为了保护数据而进行的保卫战中。<br>
<br>
环境要求<br>
<br>
1.系统环境<br>
<br>
一台Red Hat 9.0自定义安装的服务器,系统安装了GCC及一些其它要求的软件包,比如Apache、PHP等。安装完系统后的第一件事就是升级系统的软件包。作为 Web服务器,系统接受PHP脚本的请求,PHP则使用下面将要安装的MySQL数据库作为动态发布的接触。<br>
<br>
分区情况的要求和一般系统差不多,惟一不同之处在于后面建立的/chroot与/tmp要求在同一个分区上。<br>
<br>
2.安全要求<br>
<br>
<br>
(1)MySQL运行在一个独立的(Chroot)环境下;<br>
(2)mysqld进程运行于一个独立的用户/用户组下,<br>
此用户和用户组没有根目录,没有shell,也不能用于其它程序;<br>
(3)修改MySQL的root帐号,并使用一个复杂的密码;<br>
(4)只允许本地连接MySQL,启动MySQL时网络连接被禁止掉;<br>
(5)保证连接MySQL的nobody帐号登陆被禁止;<br>
(6)删除test数据库。<br>
<br>
安装MySQL<br>
<br>
1.安装准备<br>
<br>
安装MySQL之前,按照上述安全要求需要创建一个用于启动MySQL的用户和组。<br>
<br>
<br>
#groupadd mysql<br>
#useradd mysql -c "start mysqld's account" -d /dev/null -g mysql -s /sbin/nologin<br>
<br>
2.编译和安装<br>
<br>
下载MySQL源代码包:<br>
<br>
<br>
#wget http://mysql.he.net/Downloads/MySQL-4.0/mysql-4.0.16.tar.gz<br>
<br>
解压缩:<br>
<br>
<br>
#tar -zxvf mysql-4.0.16.tar.gz<br>
<br>
一般把MySQL安装在/usr/local/mysql下,如果有特殊要求,也可自行调整。不过这样做意义不大,因为后面将Chrooting,到时只是使用这里的客户工具而已,比如mysql,mysqladmin,mysqldump等。下面就开始编译安装吧。<br>
<br>
<br>
#./configure --prefix=/usr/local/mysql <br>
--with-mysqld-user=mysql <br>
--with-unix-socket-path=/tmp/mysql.sock <br>
--with-mysqld-ldflags=-all-static<br>
#make && make install<br>
#strip /usr/local/mysql/libexec/mysqld<br>
#scripts/mysql_install_db<br>
#chown -R root /usr/local/mysql<br>
#chown -R mysql /usr/local/mysql/var<br>
#chgrp -R mysql /usr/local/mysql<br>
<br>
上面各步骤的具体作用在MySQL手册里已有介绍,惟一需要解释、和一般步骤不同的地方在于--with-mysqld-ldflags=-all-static。因为需要用到Chroot环境,而MySQL本身连接成静态后就无需再创建一些库环境了。<br>
<br>
3.配置与启动<br>
<br>
MySQL的配置文件需要手工选择、拷贝几个模板文件中的一个到/etc下,这几个模板文件位于源文件的support-files目录,一共4个:small、medium、large、huge。<br>
<br>
<br>
#cp support-files/my-medium.cnf /etc/my.cnf<br>
#chown root:sys /etc/my.cnf<br>
#chmod 644 /etc/my.cnf<br>
<br>
启动MySQL,注意使用用户为mysql:<br>
<br>
<br>
#/usr/local/mysq/bin/mysqld_safe --user=mysql &<br>
<br>
4.测试<br>
<br>
为了测试安装的程序是否正确及MySQL是否已经启动正常,最好的办法就是用MySQL客户端来连接数据库。<br>
<br>
<br>
#/usr/local/mysql/bin/mysql<br>
[root@ftp bin]# mysql<br>
Welcome to the MySQL monitor. Commands end with ; or g.<br>
Your MySQL connection id is 687 to server version: 3.23.58<br>
Type 'help;' or 'h' for help. Type 'c' to clear the buffer.<br>
mysql><br>
mysql> show databases;<br>
+--------------+<br>
| Database |<br>
+--------------+<br>
| mysql |<br>
| test |<br>
+--------------+<br>
2 rows in set (0.00 sec)<br>
mysql>quit<br>
<br>
连接成功,可以关闭数据库:<br>
<br>
<br>
#/usr/local/mysql/bin/mysqladmin -uroot shutdown<br>
<br>
如果连接失败则需要仔细分析出错原因:<br>
<br>
<br>
#more /usr/local/mysql/var/`hostname`.err<br>
<br>
Chrooting<br>
<br>
1.Chrooting环境<br>
<br>
Chroot是Unix/类Unix的一种手段,它的建立会将其与主系统几乎完全隔离,也就是说,一旦遭到什么问题,也不会危及到正在运行的主系统。这是一个非常有效的办法,特别是在配置网络服务程序的时候。<br>
<br>
2.Chroot的准确工作<br>
<br>
首先,应当建立如图1示目录结构:<br>
图1 目录结构<br>
<br>
<br>
#mkdir -p /chroot/mysql/dev<br>
#mkdir -p /chroot/mysql/etc<br>
#mkdir -p /chroot/mysql/tmp<br>
#mkdir -p /chroot/mysql/var/tmp<br>
#mkdir -p /chroot/mysql/usr/local/mysql/libexec<br>
#mkdir -p /chroot/mysql/usr/local/mysql/share/mysql/english<br>
<br>
然后设定目录权限:<br>
<br>
<br>
#chown -R root:sys /chroot/mysql<br>
#chmod -R 755 /chroot/mysql<br>
#chmod 1777 /chroot/mysql/tmp<br>
<br>
3.拷贝mysql下的程序和文件到chroot下<br>
<br>
<br>
#cp -p /usr/local/mysql/libexec/mysqld /chroot/mysql/usr/local/mysql/libexec/<br>
#cp -p /usr/local/mysql/share/mysql/english/errmsg.sys<br>
/chroot/mysql/usr/local/mysql/share/mysql/english/<br>
#cp -p /etc/hosts /chroot/mysql/etc/<br>
#cp -p /etc/host.conf /chroot/mysql/etc/<br>
#cp -p /etc/resolv.conf /chroot/mysql/etc/<br>
#cp -p /etc/group /chroot/mysql/etc/<br>
#cp -p /etc/passwd /chroot/mysql/etc/passwd<br>
#cp -p /etc/my.cnf /chroot/mysql/etc/<br>
<br>
4.编辑chroot下的passwd文件和group文件<br>
<br>
<br>
#vi /chroot/etc/passwd<br>
<br>
删除除了mysql、root、sys的所有行<br>
<br>
<br>
#vi /chroot/etc/group<br>
<br>
删除除了mysql、root的所有行<br>
<br>
5.创建特殊的设备文件/dev/null<br>
<br>
参照系统的样子做即可:<br>
<br>
<br>
#ls -al /dev/null<br>
crw-rw-rw- 1 root root 1, 3 Jan 30 2003 /dev/null<br>
#mknod /chroot/mysql/dev/null c 1 3<br>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -