数据库的安全重要性相信大家都知道啦,小编就不在这里啰嗦了。但是,数据库系统的安全性包括很多方面呢。大多情况下,数据库服务器是容许客户机从网络上连接,因此客户机连接的安全对MySQL数据库安全是有很重要的影响。

下面列举一些大家需要注意的点,供大家参考:

不在客户机的命令行上提供密码

使用mysql、mysqladmin等客户机用一个用户身份与MySQL服务器连接时,需要为连接提供密码。

可以在命令行上提供密码

shell>mysql –u root –pmypass

注意,-p选项与密码之间不可有空格,否则会提示你输入密码,并报错。

同时,你也可以使用长格式

shell>mysql –user=root –password=mypass

然后,你就可以看到这样做的后果了:

在Unix上,$ps –aux | grep mysql

在win9x上,你可以按住Ctrl+Alt+Del键,NT上你可以打开任务管理器。

你有没有发现什么?密码清清楚楚的显示在你的面前!!所以,请你无论何时也不要这么做!

那么,你得让客户机提示你的密码:

shell>mysql –u root –p

或者你也可以使用选项文件提供密码,但是请注意,为了安全,不能在选项文件中存储密码。你可以只提供password选项,让客户机提示你输入密码。

使用SSH加密客户机连接

这是一个关于怎样用SSH 得到一个安全的连接远程MySQL服务器的注意事项(David Carlson)。

在你的windows机器上安装SSH客户   .

启动SSH。设置主机名字 = 你的MySql服务器名或IP地址,设置userid=你的用户名登录到你的服务器。

点击“local forwords”。设定 local port: 3306, host: localhost, remote port: 3306

保存一切,否则下次你将必须再做一遍。

然后用SSH登录到你的服务器。

接着,启动一些ODBC应用程序(例如Access)。

创造一个新文件并且用ODBC驱动程序链接到MySQL,步骤方法和往常一样,除了对服务器用户“localhost”。

好了,到这一步就搞定啦!它对一个直接的因特网连接工作得很好。

注意:不要使用Unix的root用户运行MySQL守护进程

不要作为Unix的root用户运行MySQL守护进程。mysqld能以任何用户运行,你也可以创造一个新的Unix用户mysql使一切更安全。如果你作为其它Unix用户运行mysqld,你不需要改变在user表中的root用户名,因为MySQL用户名与Unix 用户名没关系。

你可以作为其它Unix用户编辑mysql.server启动脚本mysqld。或者使用选项文件。

数据库目录的安全

MySQL服务器提供了一个通过mysql数据库中的授权表,实现了一个十分灵活的权限系统,保证了从网络访问数据的安全性。但是,如果服务器主机上的其它用户拥有对服务器目录的直接访问权,那么你的服务器的数据仍旧是不安全的。

一般你可能用一个非特权的Unix用户执行守护程序。检查那个运行mysqld的Unix用户是唯一的在数据库目录下有读/写权限的用户。

可能的安全漏洞

显然,你不会让服务器主机上的其它用户拥有对数据库目录文件的写访问权。但是,多备份在这里再啰嗦一句:仅仅是读访问权也非常危险。

由于像GRANT和SET PASSWORD这样的查询都被记录到日志中去了,常规和更新日志文件包含了有关密码的敏感查询文本。但是如果一个工具有对这些日志的读访问权,那么它只要在日志文件中查找GRANT或PASSWORD这样的敏感单词,就很容易找到密码的明文。

对于表文件的读访问也是很危险的,窃取文件并使MySQL以及以纯文本的形式显示表的内容是微不足道的事。可以按下列步骤进行:

1、安装一个新的MySQL分发,可以是在另一台主机上,也可以就在当前的服务器主机上安装,使用与正式服务器不同的端口、套接字和数据文件。

2、将窃取的表的相应文件拷贝到新服务数据库目录中的test目录下

3、然后就可以启动作案服务器,可以随意访问所窃取表的内容。

在Unix设置合适的数据库目录权限

如果要消除这些安全漏洞,就要安排数据库目录及其中所有文件和目录的所有权,是的只有启动服务器的专用帐户才可以访问它们。操作步骤如下:

1、切换到root用户

$su

2、设置数据库目录及其中所有文件目录的所有权为运行该服务器的帐号所有,在本书中一直将这个帐号假定为mysql,把所有的组设为root组

%chown –R mysql:root DATADIR

3、修改数据库目录及其中所有文件目录的权限为只有所有者可以读写

%chmod –R go-rwx DATADIR

在NT系统中设置合适的数据库目录权限

在NT系统中的数据库目录的安全性可能比较简单:

你可能想到,把所有目录文件改为只有某个帐户administrator例如可读写。但是,这样会有一个问题,就是这能在 administrator帐户中用手动启动独立的服务器,如果让mysql系统服务自动启动的方法也不可行,解决方法是让数据库目录也可被 administrators组用户读写,这样MySQL服务器就可以用系统服务的方法自动启动了,也可以在任何帐户中用net start mysql启动。

另外一个问题是,如果你在非administrators组用户中或者从网络都无法建立数据库连接,因为没有数据库目录的读的权利,如果要正常使用,还需要写的权利。解决方法是让SYSTEM组用户能够队数据库目录读写。

由于许可证和费用的原因,通常建议你在Linux服务器上使用MySQL,在Windows平台之用来测试或者数据录入工作。但是,如果你要在Windows上使用的话,可以注意本小节的一些内容。

影响安全的mysqld选项

下列mysqld选项影响安全:

--secure

由gethostbyname()系统调用返回的IP数字被检查,确保他们解析回到原来的主机名。这对某些外人通过模仿其它主机获得存取权限变得更难。这个选项也增加一些聪明的主机名检查。在MySQL3.21里,选择缺省是关掉的,因为它有时它花很长时间执行反向解析。MySQL 3.22缓存主机名并缺省地启用了这个选项。

--skip-grant-tables

这个选项导致服务器根本不使用权限系统。这给每个人以完全存取所有的数据库的权力!(通过执行mysqladmin reload,你能告诉一个正在运行的服务器再次开始使用授权表。)

--skip-name-resolve

主机名不被解析。所有在授权表的Host的列值必须是IP数字或localhost。

--skip-networking

在网络上不允许TCP/IP连接。所有到mysqld的连接必须经由Unix套接字进行。这个选项对使用MIT-pthreads的系统是不合适的,因为MIT-pthreads包不支持Unix套接字。

给大家列举了那么多细节希望大家都能学以致用。同时,也希望大家重视数据库的安全。

不要到了数据崩溃的时候才开始后悔。如果你是小白用户,对数据库还摸索不清也可以多和多备份交流哦。

mysql数据库安全性_Mysql数据库的安全性问题释疑相关推荐

  1. mysql数据库应用_MySQL数据库应用 从入门到精通 学习笔记

    以下内容是学习<MySQL数据库应用 从入门到精通>过程中总结的一些内容提要,供以后自己复现使用. 一:数据库 查看所有数据库:SHOW DATABASES 创建数据库:CREATE DA ...

  2. 数据库 mysql详解_MySQL数据库详解

    一.数据库概述 1.数据库与文件系统文件系统对比. 数据冗余和不一致性 数据访问 数据格式相对独立 数据完整性和原子性 数据的并发访问 数据的安全性问题 2.数据库概念 1.DBMS:数据库管理系统 ...

  3. mysql数据库视图_MySQL数据库应用总结(九)—MySQL数据库视图的操作

    SQL语法预览: 创建视图:[create [or replace] [algorithm={undefined | merge | temptable}] view 视图名称(属性列) as sel ...

  4. mysql数据库监控程序_mysql数据库监控利器lepus天兔工具安装和部署

    需要的核心包如下: 以下软件包只需要部署在监控机即可.被监控机无需部署. 1.MySQL 5.0及以上(必须,用来存储监控系统采集的数据) 2.Apache 2.2及以上 (必须,WEB服务器运行服务 ...

  5. mysql数据库语法_MySQL数据库基本语法

    SQL WHAT(SQL是什么?) Structured Query Language:结构化查询语⾔ WHY(为何要使用SQL?) 难道仅仅使用SQL Server Management Studi ...

  6. Mysql常用词汇_mysql 数据库常用单词

    说明:以下单词可能有多种含义,此文档只针对编程做解释.单词不多,熟能生巧,每日认真读读写写,效果不错.如有错误,请谅解并指出,谢谢大家! 黄金超 2017-4-7 连接MySQL数据库: mysql ...

  7. mysql删除原则_MySQL数据库的增删选查

    数据库是专门存储数据对象的容器,这里的数据对象包括表.视图.触发器.存储过程等,其中表是最基本的数据对象. 创建数据库 在 MySQL 数据库中存储数据对象之前,先要创建好数据库. 语法: creat ...

  8. mysql select表达式_MySQL数据库SELECT查询表达式解析

    数据的管理在很大一部分是在进行查找工作,而SELECT占据了很大的一部分 SELECT select_expr [,select_expr...] [ FROM table_reference WHE ...

  9. mysql数据库导出_MySQL数据库导入导出详解[转发]

    1. 概述 MySQL数据库的导入,有两种方法: 1) 先导出数据库SQL脚本,再导入: 2) 直接拷贝数据库目录和文件. 在不同操作系统或MySQL版本情况下,直接拷贝文件的方法可能会有不兼容的情况 ...

  10. mysql断网_mysql数据库断网链接

    {"moduleinfo":{"card_count":[{"count_phone":1,"count":1}],&q ...

最新文章

  1. Linux自定义命令
  2. Excel自定义函数使用正则表达式详解
  3. db15接口各针脚示意图_【沙发管家】带你了解 HDMI 接口的用处都有哪些?
  4. 2压缩备份数据库_达梦数据库备份与还原
  5. Spring的AOP面向切面编程
  6. LeetCode简单题目(#172 #189 #190 #191 #198 #202)-6道(序列、数字)
  7. hadoop yarn如何启动聚合日志
  8. 计算机行业的最新技术,计算机行业发展空间巨大 三大必然趋势引领发展
  9. python stm32f401_使用Python编程STM32F401 Nucleo开发板快速入门
  10. 什么是外网IP、内网IP?
  11. ARP 项添加失败: 请求的操作需要提升
  12. 为什么手机浏览器打不开html文件,win7浏览器打不开本地html文件的原因及解决方法...
  13. 默认关闭IDEA的注释doc的rendered view模式
  14. 家到学校路线图怎么画_PPT绘制家到学校路线图教程
  15. java中finish什么意思,finish是什么意思(释义详解一览)
  16. 汉庭酒店专属歌曲发布,由左小祖咒和罗永浩创作
  17. 【51nod】---1278 相离的圆(二分排序)
  18. 2022电大国家开放大学网上形考任务-金融企业会计非免费(非答案)
  19. 计算机到路由器用交叉线的好处,路由器与交换机连接-路由器和交换机之间是用交叉线还是用直通线联 – 手机爱问...
  20. style.left和offsetLeft 用法

热门文章

  1. 联邦学习中的non-iid总结
  2. python解析xml选用什么模块_python 解析xml需要什么模块
  3. 深入浅出OOD(一)
  4. 山东省人力资源和社会保障厅容灾及备份项目要求
  5. 中山纪念中学 培训 日记
  6. laravel文字+链接(英文字符)--多行换行处理
  7. Linux 安装添加新的字体
  8. IaaS、PaaS、SaaS、BaaS、FaaS和Serverless的含义
  9. 洛谷 P4336 [SHOI2016] 黑暗前的幻想乡 题解
  10. 注册Docker镜像加速器