管理MySQL用户主要有哪些功能
admin
2023-05-13 05:41:51
0

下文主要给大家带来管理MySQL用户主要有哪些功能,希望这些文字能够带给大家实际用处,这也是我编辑管理MySQL用户主要有哪些功能这篇文章的主要目的。好了,废话不多说,大家直接看下文吧。


1. MySQL用户管理

12345'user'@'host'; host:IP、主机名、NETWORK、%(任意长字符),_(任意单个字符)    skip_name_resolve={ON|OFF} 跳过主机名解析 [root@node2 ~]# vim /etc/my.cnf skip_name_resolve=ON

 

2.查看用户
示例:

1MariaDB [mysql]> SELECT User,Host,Password FROM user;

 

3.创建用户
CREATE USER  'user'@'host' [IDENTIFIED BY [PASSWORD] 'password'] [,'user'@'host' [IDENTIFIED BY [PASSWORD] 'password']...]
示例:

1MariaDB [(none)]> CREATE USER 'tom'@'127.0.0.1' IDENTIFIED BY 'liumanlin' , 'jerry'@'%' IDENTIFIED BY 'liumanlin';

 

4.重命名:RENAME USER
RENAME USER old_user TO new_user[, old_user TO new_user] ...
示例:

1MariaDB [mysql]> RENAME USER 'tom'@'127.0.0.1' TO 'jerry'@'172.18.%.%';

 

5.删除用户
DROP USER 'user'@'host' [, 'user'@'host'] ...
示例:

12MariaDB [mysql]> DROP USER 'jerry'@'%';MariaDB [mysql]> DROP USER ''@'localhost';

 

6.让MySQL重新加载授权列表
FLUSH PRIVILEGES;
示例:

1MariaDB [mysql]> FLUSH PRIVILEGES;

 

7.修改用户密码
(1) SET PASSWORD [FOR 'user'@'host'] = PASSWORD('cleartext password'); PASSWORD是MySQL内建加密函数
示例:

12MariaDB [mysql]> SET PASSWORD FOR 'root'@'localhost' = PASSWORD('liumanlin');MariaDB [mysql]> FLUSH PRIVILEGES;


(2) UPDATE mysql.user SET Password=PASSWORD('cleartext password')  WHERE User='USERNAME' AND Host='HOST';
示例:

12MariaDB [mysql]> UPDATE user SET Password=PASSWORD('liumanlin') WHERE User='root' AND Host='127.0.0.1';MariaDB [mysql]> FLUSH PRIVILEGES;


(3) mysqladmin -uUSERNAME -hHOST -p  password 'NEW_PASS'
示例:

1[root@node2 ~]# mysqladmin -h227.0.0.1 -uroot -p password 'liumanlin';

 

8.忘记管理员密码的解决办法
(1) 启动mysqld进程时,使用--skip-grant-tables和--skip-networking选项
示例:
CentOS 7:

1234[root@node2 ~]# vim /usr/lib/systemd/system/mariadb.service ExecStart=/usr/bin/mysqld_safe --basedir=/usr --skip-grant-tables --skip-networking[root@node2 ~]# systemctl daemon-reload[root@node2 ~]# systemctl restart mariadb.service


CentOS 6:

1[root@node2 ~]# vim /etc/init.d/mysqld 同理


(2) 通过UPDATE命令修改管理员密码
示例:

123MariaDB [mysql]> UPDATE user SET Password=PASSWORD('liumanlin') WHERE User='root' AND Host='127.0.0.1';[root@node2 ~]# vim /usr/lib/systemd/system/mariadb.serviceExecStart=/usr/bin/mysqld_safe --basedir=/usr


(3) 以正常方式启动mysqld进程;
示例:

12[root@node2 ~]# systemctl daemon-reload[root@node2 ~]# systemctl restart mariadb.service

 

9.授权:GRANT

12345GRANT priv_type [(column_list)] [, priv_type [(column_list)]] ...ON [object_type] priv_levelTO user_specification [, user_specification] ...[REQUIRE {NONE | ssl_option [[AND] ssl_option] ...}][WITH with_option ...]


object_type(对象类型):
 TABLE
 | FUNCTION
 | PROCEDURE
priv_level:
 *
 | *.*(所有库的所有表)
 | db_name.*(指定库的所有表)
 | db_name.tbl_name(指定库的指定表)
 | tbl_name(指定表)
 | db_name.routine_name(指定库的指定函数)
ssl_option:
 SSL
 | X509
 | CIPHER 'cipher'
 | ISSUER 'issuer'
 | SUBJECT 'subject'    
with_option:
 GRANT OPTION
 | MAX_QUERIES_PER_HOUR count
 | MAX_UPDATES_PER_HOUR count
 | MAX_CONNECTIONS_PER_HOUR count
 | MAX_USER_CONNECTIONS count
示例1:

12345678910MariaDB [mysql]> GRANT CREATE ON hidb.* TO 'jerry'@'172.18.%.%';[root@node2 ~]# mysql -ujerry -h272.18.67.12 -pMariaDB [(none)]> CREATE DATABASE hidb;MariaDB [(none)]> use hidb;MariaDB [hidb]> CREATE TABLE tbl1 (name CHAR(20));MariaDB [hidb]> CREATE INDEX test ON tbl1(name);ERROR 1142 (42000): INDEX command denied to user 'jerry'@'172.18.67.12' for table 'tbl1' (无权创建索引,用以下方法)MariaDB [mysql]> GRANT INDEX ON hidb.* TO 'jerry'@'172.18.%.%';MariaDB [mysql]> SHOW GRANTS  FOR 'jerry'@'172.18.%.%';MariaDB [hidb]> CREATE INDEX test ON tbl1(name); (授权成功)


示例2:

12345678MariaDB [mysql]> CREATE USER 'tom'@'172.18.%.%' IDENTIFIED BY 'liumanlin';[root@node2 ~]# mysql -utom -h272.18.67.12 -p (可正常登录)MariaDB [mysql]> GRANT ALL ON hidb.* TO 'tom'@'172.18.%.%' REQUIRE SSL; (使用ssl授权登录)MariaDB [mysql]> SHOW GRANTS FOR 'tom'@'172.18.%.%';MariaDB [mysql]> FLUSH PRIVILEGES;[root@node2 ~]# mysql -utom -h272.18.67.12 -pEnter password:ERROR 1045 (28000): Access denied for user 'tom'@'172.18.67.12' (using password: YES) (无法连接,需指明ssl证书)


示例3:

123456789101112MariaDB [mysql]> SHOW GLOBAL VARIABLES LIKE '%ssl%';+---------------+----------+| Variable_name | Value    |+---------------+----------+| have_openssl  | DISABLED || have_ssl      | DISABLED || ssl_ca        |          || ssl_capath    |          || ssl_cert      |          || ssl_cipher    |          || ssl_key       |          |+---------------+----------+

 

10.查看授权:SHOW GRANTS
SHOW GRANTS [FOR 'user'@'host']
示例:

1MariaDB [mysql]> SHOW GRANTS FOR 'tom'@'172.18.%.%';

 

11.取消授权:REVOKE

12345REVOKE  priv_type [(column_list)][, priv_type [(column_list)]] ...ON [object_type] priv_levelFROM  'user'@'host' [,  'user'@'host'] ...REVOKE ALL PRIVILEGES, GRANT OPTIONFROM user [, user] ...


示例:

123MariaDB [mysql]> REVOKE CREATE VIEW ON hidb.* FROM 'tom'@'172.18.%.%';MariaDB [mysql]> SHOW GRANTS FOR 'tom'@'172.18.%.%';MariaDB [mysql]> FLUSH PRIVILEGES;

对于以上关于管理MySQL用户主要有哪些功能,大家是不是觉得非常有帮助。如果需要了解更多内容,请继续关注我们的行业资讯,相信你会喜欢上这些内容的。

相关内容

热门资讯

支付宝:正向警方寻求帮助 澎湃新闻记者 陈月石“支付宝用户称关闭支付功能后深夜被扣款捐赠了184万元”引发热议后,支付宝方面做...
美国代表团变身好奇宝宝拍不停 据凤凰卫视报道,国际社会高度关注中美元首会晤。有消息指,此次美方白宫的记者团有近200人。据凤凰卫视...
“百万学员”知识主播王仲焘偷税... 【大河财立方消息】 5月15日,国家税务总局北京市税务局通报,近期,国家税务总局北京市税务局第三稽查...
数据透视债市“科技板”一周年,... 【大河财立方 记者 杨萨 李国庆】去年5月7日,中国人民银行、中国证监会联合发布《关于支持发行科技创...
河南省纪委监委:王惠玲涉嫌严重... 据郑州市纪委监委消息:荥阳市政协党组成员、副主席王惠玲涉嫌严重违纪违法,目前正接受郑州市纪委监委纪律...
今年前4个月进出口额同比增长2... 河南日报讯 (全媒体记者 王歌 通讯员 刘远方)河南外贸再交亮眼成绩单。5月14日,记者从郑州海关获...
促消费,许昌这样“破题” 从“品质胖东来”到“品质许昌”,从“为一家商超而来”到“为一城精彩而留”促消费,许昌这样“破题”观众...
长信科技获得实用新型专利授权:... 证券之星消息,根据天眼查APP数据显示长信科技(300088)新获得一项实用新型专利授权,专利名为“...
最高降2000元!多家电商平台... 随着电商年中大促“618”临近,多家平台已提前打响手机价格战。记者5月15日获悉,iPhone 17...
基于开源欧拉,宇航级嵌入式星载... IT之家 5 月 14 日消息,据“开放原子”公众号,近日,基于开源欧拉的宇航级嵌入式操作系统搭载某...