科帮网-Java论坛、Java社区、JavaWeb毕业设计

登录/注册
您现在的位置:论坛 资料库 数据库开发 > 阿里云linux服务器下mysql安全设置
总共48085条微博

动态微博

查看: 1448|回复: 0

阿里云linux服务器下mysql安全设置

[复制链接]
admin    

1244

主题

544

听众

1万

金钱

管理员

  • TA的每日心情

    2021-2-2 11:21
  • 签到天数: 36 天

    [LV.5]常住居民I

    管理员

    跳转到指定楼层
    楼主
    发表于 2015-07-17 15:34:02 |只看该作者 |倒序浏览
    mysql安全设置及性能优化配置全攻略,注意在不熟悉的情况下更改设置前最好进行备份,以免出错。
    1、修改root用户的的口令

    缺省情况下MySQL没有设置密码,我们可以用三种方法设置密码头:

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

    *  用set password修改口令:
    mysql> set password for root@localhost=password(‘kuitao8’);

    *  直接修改user表的root用户口令
    mysql> use mysql;
    mysql> update user set password=password(‘kuitao8’) 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


    科帮网-Java论坛、Java社区、JavaWeb毕业设计 1、本主题所有言论和图片纯属会员个人意见,与本社区立场无关
    2、本站所有主题由该帖子作者发表,该帖子作者与科帮网-Java论坛、Java社区、JavaWeb毕业设计享有帖子相关版权
    3、其他单位或个人使用、转载或引用本文时必须同时征得该帖子作者和科帮网-Java论坛、Java社区、JavaWeb毕业设计的同意
    4、帖子作者须承担一切因本文发表而直接或间接导致的民事或刑事法律责任
    5、本帖部分内容转载自其它媒体,但并不代表本站赞同其观点和对其真实性负责
    6、如本帖侵犯到任何版权问题,请立即告知本站,本站将及时予与删除并致以最深的歉意
    7、科帮网-Java论坛、Java社区、JavaWeb毕业设计管理员和版主有权不事先通知发贴者而删除本文


    JAVA爱好者①群:JAVA爱好者① JAVA爱好者②群:JAVA爱好者② JAVA爱好者③ : JAVA爱好者③

    快速回复
    您需要登录后才可以回帖 登录 | 立即注册

       

    发布主题 快速回复 返回列表 联系我们 官方QQ群 科帮网手机客户端
    快速回复 返回顶部 返回列表