如何提高MySql的安全性


Posted in 面试题 onJune 19, 2014
1.如果MYSQL客户端和服务器端的连接需要跨越并通过不可信任的网络,那么需要使用ssh隧道来加密该连接的通信。
2.使用set password语句来修改用户的密码,先“mysql -u root”登陆数据库系统,然后“mysql> update mysql.user set password=password(‘newpwd’)”,最后执行“flush privileges”就可以了。
3.Mysql需要提防的攻击有,防偷听、篡改、回放、拒绝服务等,不涉及可用性和容错方面。对所有的连接、查询、其他操作使用基于acl即访问控制列表的安全措施来完成。也有一些对ssl连接的支持。
4.设置除了root用户外的其他任何用户不允许访问mysql主数据库中的user表;
加密后存放在user表中的加密后的用户密码一旦泄露,其他人可以随意用该用户名/密码相应的数据库;
5.使用grant和revoke语句来进行用户访问控制的工作;
6.不要使用明文密码,而是使用md5()和sha1()等单向的哈系函数来设置密码;
7.不要选用字典中的字来做密码;
8.采用防火墙可以去掉50%的外部危险,让数据库系统躲在防火墙后面工作,或放置在dmz区域中;
9.从因特网上用nmap来扫描3306端口,也可用telnet server_host 3306的方法测试,不允许从非信任网络中访问数据库服务器的3306号tcp端口,需要在防火墙或路由器上做设定;
10.为了防止被恶意传入非法参数,例如where id=234,别人却输入where id=234 or 1=1导致全部显示,所以在web的表单中使用”或”"来用字符串,在动态url中加入%22代表双引号、%23代表井号、%27代表单引号;传递未检查过的值给mysql数据库是非常危险的;
11.在传递数据给mysql时检查一下大小;
12.应用程序需要连接到数据库应该使用一般的用户帐号,开放少数必要的权限给该用户;
$page_devide$
13.在各编程接口(c c++ php perl java jdbc等)中使用特定‘逃脱字符’函数;
在因特网上使用mysql数据库时一定少用传输明文的数据,而用ssl和ssh的加密方式数据来传输;
14.学会使用tcpdump和strings工具来查看传输数据的安全性,例如tcpdump -l -i eth0 -w -src or dst port 3306 strings。以普通用户来启动mysql数据库服务;
15.不使用到表的联结符号,选用的参数 –skip-symbolic-links;
16.确信在mysql目录中只有启动数据库服务的用户才可以对文件有读和写的权限;
17.不许将process或super权限付给非管理用户,该mysqladmin processlist可以列举出当前执行的查询文本;super权限可用于切断客户端连接、改变服务器运行参数状态、控制拷贝复制数据库的服务器;
18.file权限不付给管理员以外的用户,防止出现load data ‘/etc/passwd’到表中再用select 显示出来的问题;
19.如果不相信dns服务公司的服务,可以在主机名称允许表中只设置ip数字地址;
20.使用max_user_connections变量来使mysqld服务进程,对一个指定帐户限定连接数;
21.grant语句也支持资源控制选项;
22.启动mysqld服务进程的安全选项开关,–local-infile=0或1 若是0则客户端程序就无法使用local load data了,赋权的一个例子grant insert(user) on mysql.user to ‘user_name’@host_name’;若使用–skip-grant-tables系统将对任何用户的访问不做任何访问控制,但可以用 mysqladmin flush-privileges或mysqladmin reload来开启访问控制;默认情况是show databases语句对所有用户开放,可以用–skip-show-databases来关闭掉。
23.碰到error 1045(28000) access denied for user ‘root’@localhost’ (using password:no)错误时,你需要重新设置密码,具体方法是:先用–skip-grant-tables参数启动mysqld,然后执行 mysql -u root mysql,mysql>update user set password=password(‘newpassword’) where user=’root’;mysql>flush privileges;,最后重新启动mysql就可以了。

Tags in this post...

面试题 相关文章推荐
附答案的Java面试题
Nov 19 面试题
华为c/c++笔试题
Jan 25 面试题
下述程序的作用是计算机数组中的最大元素值及其下标
Nov 26 面试题
Net Remoting把服务器端激活两种模式
Jan 22 面试题
linux系统都有哪些运行级别
Mar 26 面试题
Linux不知道文件后缀名怎么判断文件类型
Apr 26 面试题
一套软件测试笔试题
Jul 25 面试题
北京麒麟网信息技术有限公司网络游戏测试面试题
Sep 28 面试题
介绍一下RMI的基本概念
Dec 17 面试题
两道JAVA笔试题
Sep 14 面试题
Java的类可以定义为Protected或者Private得吗
Sep 25 面试题
解释下列WebService名词:WSDL、SOAP、UDDI
Jun 22 面试题
介绍一下Mysql的存储引擎
Feb 12 #面试题
介绍一下如何优化MySql
Dec 20 #面试题
腾讯公司的一个sql题
Jan 22 #面试题
十一个高级MySql面试题
Oct 06 #面试题
遇到的Mysql的面试题
Jun 29 #面试题
一些关于MySql加速和优化的面试题
Jan 30 #面试题
MYSQL支持事务吗
Aug 09 #面试题
You might like
PHP中单引号与双引号的区别分析
2014/08/19 PHP
PHP输出两个数字中间有多少个回文数的方法
2015/03/23 PHP
CodeIgniter与PHP5.6的兼容问题
2015/07/16 PHP
php微信公众号开发(2)百度BAE搭建和数据库使用
2016/12/15 PHP
基于datagrid框架的查询
2013/04/08 Javascript
利用jquery.qrcode在页面上生成二维码且支持中文
2014/02/12 Javascript
JavaScript变量声明详解
2014/11/27 Javascript
JQuery 在文档中查找指定name的元素并移除的实现方法
2016/05/19 Javascript
Knockout结合Bootstrap创建动态UI实现产品列表管理
2016/09/14 Javascript
Bootstrap按钮组实例详解
2017/07/03 Javascript
详解如何用babel转换es6的class语法
2018/04/03 Javascript
vue监听键盘事件的快捷方法【推荐】
2018/07/11 Javascript
JavaScript实现shuffle数组洗牌操作示例
2019/01/03 Javascript
JavaScript实时更新当前的时间的示例代码
2020/07/15 Javascript
js实现批量删除功能
2020/08/27 Javascript
[01:07:21]NAVI vs VG Supermajor 败者组 BO3 第二场 6.5
2018/06/06 DOTA
Python获取远程文件大小的函数代码分享
2014/05/13 Python
Python3实现从文件中读取指定行的方法
2015/05/22 Python
Python的math模块中的常用数学函数整理
2016/02/04 Python
Python常用时间操作总结【取得当前时间、时间函数、应用等】
2017/05/11 Python
Python魔法方法详解
2019/02/13 Python
很酷的python表白工具 你喜欢我吗
2019/04/11 Python
Python OpenCV中的resize()函数的使用
2019/06/20 Python
python递归法解决棋盘分割问题
2019/07/17 Python
利用Pytorch实现简单的线性回归算法
2020/01/15 Python
Python Excel vlookup函数实现过程解析
2020/06/22 Python
互斥锁解决 Python 中多线程共享全局变量的问题(推荐)
2020/09/28 Python
CSS3转换功能transform主要属性值分析及实现分享
2012/05/06 HTML / CSS
美国汽配连锁巨头Pep Boys官网:轮胎更换、汽车维修服务和汽车零部件
2017/01/14 全球购物
New Balance比利时官方网站:购买鞋子和服装
2021/01/15 全球购物
开办化妆品公司创业计划书
2013/12/26 职场文书
幼儿园家长评语
2014/02/10 职场文书
物业管理专业自荐信
2014/07/01 职场文书
2015年公务员个人工作总结
2015/04/24 职场文书
婚庆主持词大全
2015/06/30 职场文书
浅谈Python实现opencv之图片色素的数值运算和逻辑运算
2021/06/23 Python