- 1 MySQL 简介
- MySQL 版本和产品线说明
- MySQL 安装
- 2 MySQL 基础教程
- 2.1 SQL 语法:SELECT/INSERT/UPDATE/DELETE
- 2.2 MySQL 列类型
- 2.3 使用用户变量
- 2.4 MySQL 的日期和时间管理
- 2.5 集合运算
- 3 MySQL 高级教程
- 3.1 触发器
- 3.2 视图
- 3.3 复制 Replication~主从库配置
- 3.4 分区存储
- 本章参考
- 4 MySQL 优化
- 4.1 优化数据库结构
- 4.2 优化 SQL 语句
- 4.3 优化索引
- 4.4 优化数据库服务器 mysql_serverd
- 4.5 修改配置文件 my.cnf/my.ini
- 5 MySQL 管理
- 5.1 MySQL 管理常用命令
- 5.2 MySQL 权限管理
- 5.3 MySQL 备份和恢复
- 5.4 MySQL 数据库安全
- 常见问题 FAQ
- 使用的常见问题
- MySQL 字符集乱码
- MySQL 存储二进制图片
- 参考资料
文章来源于网络收集而来,版权归原创者所有,如有侵权请及时联系!
5.4 MySQL 数据库安全
使用 MySQL,安全问题不能不注意。以下是 MySQL 提示的 23 个注意事项:
- 如果客户端和服务器端的连接需要跨越并通过不可信任的网络,那么就需要使用 SSH 隧道来加密该连接的通信。
- 用
set password
语句来修改用户的密码(防止明文传输密码),三个步骤,先mysql -u root
登陆数据库系统,然后mysql> update mysql.user set password=password('newpwd')
,最后执行flush privileges
就可以了。 - 需要提防的攻击有,防偷听、篡改、回放、拒绝服务等,不涉及可用性和容错方面。对所有的连接、查询、其他操作使用基于 ACL 即访问控制列表的安全措施来完成。也有一些对 SSL 连接的支持。
- 除了 root 用户外的其他任何用户不允许访问 mysql 主数据库中的 user 表;
加密后存放在 user 表中的加密后的用户密码一旦泄露,其他人可以随意用该用户名/密码相应的数据库;
- 用 grant 和 revoke 语句来进行用户访问控制的工作;
- 不使用明文密码,而是使用
md5()
和sha1()
等单向的哈系函数来设置密码; - 不选用字典中的字来做密码;
- 采用防火墙来去掉 50%的外部危险,让数据库系统躲在防火墙后面工作,或放置在 DMZ 区域中;
- 从因特网上用 nmap 来扫描 3306 端口,也可用 telnet server_host 3306 的方法测试,不能允许从非信任网络中访问数据库服务器的 3306 号 TCP 端口,因此需要在防火墙或路由器上做设定;
- SQL 注入:为了防止被恶意传入非法参数,例如
where ID=234
,别人却输入where ID=234 OR 1=1
导致全部显示,所以在 web 的表单中使用''
或""
来用字符串,在动态 URL 中加入%22
代表双引号、%23
代表井号、%27
代表单引号;传递未检查过的值给 mysql 数据库是非常危险的; - 在传递数据给 mysql 时检查一下大小;
- 应用程序需要连接到数据库应该使用一般的用户帐号,只开放少数必要的权限给该用户;
- 在各编程接口 (C C++ PHP Perl Java JDBC 等) 中使用特定
逃脱字符
函数(转义字符?mysql_real_escape_string);在因特网上使用 mysql 数据库时一定少用传输明文的数据,而用 SSL 和 SSH 的加密方式数据来传输; - 学会使用 tcpdump 和 strings 工具来查看传输数据的安全性,例如
tcpdump -l -i eth0 -w -src or dst port 3306 | strings
。以普通用户来启动 mysql 数据库服务; - 不使用到表的联结符号,选用的参数
--skip-symbolic-links;
- 确信在 mysql 目录中只有启动数据库服务的用户才可以对文件有读和写的权限;
- 不许将 process 或 super 权限付给非管理用户,该 mysqladmin processlist 可以列举出当前执行的查询文本;super 权限可用于切断客户端连接、改变服务器运行参数状态、控制拷贝复制数据库的服务器;
18.file 权限不付给管理员以外的用户,防止出现 load data '/etc/passwd'
到表中再用 select 显示出来的问题;
- 如果不相信 DNS 服务公司的服务,可以在主机名称允许表中只设置 IP 数字地址;
- 使用 max_user_connections 变量来使 mysqld 服务进程,对一个指定帐户限定连接数;
21.grant 语句也支持资源控制选项;
- 启动 mysqld 服务进程的安全选项开关,
--local-infile=0
或 1 若是 0 则客户端程序就无法使用local load data
了,赋权的一个例子grant insert(user) on mysql.user to 'user_name'@'host_name';
若使用--skip-grant-tables
系统将对任何用户的访问不做任何访问控制,但可以用 mysqladminflush-privileges
或mysqladmin reload
来开启访问控制;默认情况是show databases
语句对所有用户开放,可以用--skip-show-databases
来关闭掉。 - 碰到
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 就可以了。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论