mysql用户管理和权限管理

一、用户管理

1、查看用户信息

mysql> select host,user from user;


用户信息结果

user表中host列的值的意义

    %              匹配所有主机

    localhost    localhost不会被解析成IP地址,直接通过UNIXsocket连接

    127.0.0.1      会通过TCP/IP协议连接,并且只能在本机访问;

    ::1                ::1就是兼容支持ipv6的,表示同ipv4的127.0.0.1

2、创建用户

  identified by会将纯文本密码加密作为散列值存储

mysql> create user ceshi identified by '123456';

Query OK, 0 rows affected (0.01 sec)

3、修改用户名称

mysql 5之后可以使用rename,之前需要使用update更新user表

mysql> rename user ceshi to ceshi2;

Query OK, 0 rows affected (0.01 sec)

4、修改用户密码

mysql> set password for ceshi2 = password('456789');

Query OK, 0 rows affected, 1 warning (0.01 sec)

5、删除用户

    mysql>drop user ceshi2; //mysql5之前删除用户时必须先使用revoke 删除用户权限,然后删除用户,mysql5之后drop 命令可以删除用户的同时删除用户的相关权限

二、权限管理

mysql> show grants for ceshi;

+-----------------------------------+

| Grants for ceshi@%                |

+-----------------------------------+

| GRANT USAGE ON *.* TO 'ceshi'@'%' |

+-----------------------------------+

1 row in set (0.00 sec)

    注意:

  在数据库定义了一个新的开发者时候

mysql> create user developer@'192.168.10.%' identified by '123456';

查看developer的权限时候的命令应该是

mysql> show grants for  developer@'192.168.10.%';

2、赋予权限

使用多个权限同时赋予和回收,权限之间使用逗号分隔

mysql> grant select on homestead.* to ceshi;

Query OK, 0 rows affected (0.00 sec)

mysql> grant select,update on homestead.* to ceshi;

Query OK, 0 rows affected (0.00 sec)

3、收回权限

使用多个权限同时赋予和回收,权限之间使用逗号分隔

    mysql> revoke select on homestead.* from ceshi;//如果权限不存在会报错

Query OK, 0 rows affected (0.00 sec)

设置权限时必须给出以下信息

1,要授予的权限

2,被授予访问权限的数据库或表

3,用户名

grant和revoke可以在几个层次上控制访问权限

1,整个服务器,使用 grant ALL和revoke  ALL

2,整个数据库,使用on  database.*

3,特点表,使用on  database.table

4,特定的列

5,特定的存储过程

三、部分命令示例

grant普通数据用户,查询、插入、更新、删除 数据库中所有表数据的权利。

grant select, insert, update, delete on testdb.* to common_user@’%’

grant select,insert, update, delete on homestead.* to developer@'192.168.10.%';

grant数据库开发人员,创建表、索引、视图、存储过程、函数。。。等权限。

 grant创建、修改、删除 MySQL数据表结构权限。

grant create,alter,drop on homestead.* to developer@'192.168.10.%';

grant操作 MySQL外键权限。

grant references on homestead.* to developer@'192.168.10.%';

grant操作 MySQL视图、查看视图源代码 权限。

grant show view,create view on homestead.* to developer@'192.168.10.%';

grant操作 MySQL存储过程、函数 权限。

grant create routine,alter routine on homestead.*  to developer@'192.168.10.%';

grant普通 DBA管理某个 MySQL数据库的权限。

    grant all privileges on homestead to dba@'localhost'; //其中,关键字 “privileges” 可以省略。

grant高级 DBA管理 MySQL中所有数据库的权限。

grant all on *.* to dba@`localhost`;

注意:修改完权限以后 一定要刷新服务,或者重启服务,刷新服务用:flush privileges;

 mysql> show privileges;//查看系统的权限


系统权限

三、mysql安全配置方案

1、限制访问mysql端口的ip

windows可以通过windows防火墙或者ipsec来限制,linux下可以通过iptables来限制。

2、修改mysql的端口

windows下可以修改配置文件my.ini来实现,linux可以修改配置文件my.cnf来实现。

3、对所有用户设置强密码并严格指定对应账号的访问ip

mysql中可在user表中指定用户的访问可访问ip

4、 root特权账号的处理

建议给root账号设置强密码,并指定只容许本地登录

5、日志的处理

如需要可开启查询日志,查询日志会记录登录和查询语句。

6、 mysql进程运行账号

在windows下禁止使用local system来运行mysql账户,可以考虑使用network service或者自己新建一个账号,但是必须给与mysql程序所在目录的读取权限和data目录的读取和写入权限; 在linux下,新建一个mysql账号,并在安装的时候就指定mysql以mysql账户来运行,给与程序所在目录的读取权限,data所在目录的读取 和写入权限。

7、 mysql运行账号的磁盘权限

1)mysql运行账号需要给予程序所在目录的读取权限,以及data目录的读取和写入权限

2)不容许给予其他目录的写入和执行权限,特别是有网站的。

3)取消mysql运行账户对于cmd,sh等一些程序的执行权限。

8、网站使用的mysql账户的处理

新建一个账户,给予账户在所使用数据库的所有权限即可。这样既能保证网站对所对应的数据库的全部操作,也能保证账户不会因为权限过高而影响安全。给予单个 数据库的所有权限的账户不会拥有super, process, file等管理权限的。 当然,如果能很明确是的知道,我的网站需要哪些权限,还是不要多给权限,因为很多时候发布者并不知道网站需要哪些权限,我才建议上面的配置。而且我指的通 用的,具体到只有几台机器,不多的情况下,我个人建议还是给予只需要的权限,具体可参考上面的表格的建议。

9、删除无用数据库

test数据库对新建的账户默认有权限

四、mysql入侵提权分析及防止措施

一般来说,mysql的提权有这么几种方式:

1、 udf提权

此方式的关键导入一个dll文件,个人认为只要合理控制了进程账户对目录的写入权限即可防止被导入dll文件;然后如果万一被攻破,此时只要进程账户的权限够低,也没办执行高危操作,如添加账户等。

2、写入启动文件

这种方式同上,还是要合理控制进程账户对目录的写入权限。

3、当root账户被泄露

如果没有合理管理root账户导致root账户被入侵,此时数据库信息肯定是没办法保证了。但是如果对进程账户的权限控制住,以及其对磁盘的权限控制,服务器还是能够保证不被沦陷的。

4、普通账户泄露(上述所说的,只对某个库有所有权限的账户)

此处说的普通账户指网站使用的账户,我给的一个比较方便的建议是直接给予特定库的所有权限。账户泄露包括存在注入及web服务器被入侵后直接拿到数据库账户密码。

此时,对应的那个数据库数据不保,但是不会威胁到其他数据库。而且这里的普通账户无file权限,所有不能导出文件到磁盘,当然此时还是会对进程的账户的权限严格控制。

普通账户给予什么样的权限可以见上表,实在不会就直接给予一个库的所有权限。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,384评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,845评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,148评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,640评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,731评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,712评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,703评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,473评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,915评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,227评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,384评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,063评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,706评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,302评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,531评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,321评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,248评论 2 352

推荐阅读更多精彩内容

  • 文本情感分析:又称意见挖掘、倾向性分析等。简单而言,是对带有情感色彩的主观性文本进行分析、处理、归纳和推理的过程。...
    dd1991阅读 8,368评论 2 14
  • 今天,我一回到县城,就从小区的小店里把我的快递拿过来。打开一看,是一本厚厚的书。我怀着高兴的心情打开了书的包...
    cy小样阅读 318评论 0 6
  • 【颜色日】 色彩对心理的影响显而易见,由此诞生的色彩心理学,色彩品牌营销学都被广泛地应用在我们的生活中。今天我们想...
    采臣在等我阅读 145评论 0 0