首页 > 数据库 >2023.6.15 08.数据库安全管理

2023.6.15 08.数据库安全管理

时间:2023-06-15 23:13:21浏览次数:54  
标签:权限 15 GRANT 08 user mysql 数据库安全 localhost priv

08.数据库安全管理 ⽤户账户管理 访问权限系统 访问权限回收 在讨论安全时,我们需要考虑整个服务器主机安全(⽽不仅仅是MySQL服务)需要抵御攻击, 窃听, 扫描, 破解等。 MySQL 对所有连接数据库⽤户进⾏了 ACL 访问控制,减少服务器被内部不规范操作导致故障。 MySQL 还⽀持客户端和服务器之间的 SSL 加密连接。 当然这⾥讨论的许多概念都不是特定于 MySQL ⼏乎所有的应⽤程序都适⽤相同的⼀般思路。 MySQL 运⾏时,请遵循以下准则: 不要给⽤户(应⽤)配置超级⽤户权限,授权最⼩化 不要在数据库中存储明⽂密码 不要使⽤较为简单的字符密码 不允许⾮授信任主机使⽤扫描 数据库跟谁打交道 业务层java 公司堡垒机开放   ⽤户账户管理 1.登录和退出 MySQL , 使⽤ mysql -u root -p 可以连接数据库, 但这只是本地连接数据库的⽅式, 在⽣产很多情况 下都是连接⽹络中某⼀个主机上的数据库 -P //指定连接远程数据库端⼝[默认3306] -h //指定连接远程数据库地址[默认localhost] -u //指定连接远程数据库账户[默认root] -p //指定连接远程数据库密码[默认密码为空] -e //执⾏mysql数据库sql指令 -S //指定mysql数据库Socket //不安全 [root@sql ~]# mysql -uroot -p"Wing@123" //推荐⽅式 [root@sql ~]# mysql -uroot -p Enter password: //推送远程登录⽅式 [root@sql ~]# mysql -h10.1.106.70 -P3306 -uroot -p Enter password: //⾮交互式操作数据库 [root@sql ~]# mysql -uroot -pWing@123 -e "show databases;" mysql: [Warning] Using a password on the command line interface can be insecure. +--------------------+ | Database | +--------------------+ | information_schema | | mysql | | performance_schema | | shop | | sys | | testdb | | wing | +--------------------+ 2.创建⽤户 MySQL中创建⽤户的语法如下: CREATE USER 'username'@'127.0.0.1' IDENTIFIED BY 'password'; username 是要创建的⽤户名, hostname 是该⽤户所在的主机名或IP地址, password 是该⽤户的密码。 如果要创建⼀个可以从任何主机连接到MySQL服务器的⽤户,可以将 hostname 设置为 % ,如下所示: CREATE USER 'username'@'%' IDENTIFIED BY 'password' 创建⽤户后,需要为该⽤户授予适当的权限,以便该⽤户可以执⾏所需的操作。可以使⽤ GRANT 语句来授予权限, 例如: GRANT SELECT, INSERT, UPDATE ON database.* TO 'username'@'hostname'; 授予⽤户在 database 数据库中执⾏ SELECT 、 INSERT 和 UPDATE 操作的权限。 示列: //先创建⽤户, 后授权(CREATE USER 语句创建) mysql> create user wing@'localhost' identified by 'Wing@123'; //基于已有⽤户进⾏授权 mysql> grant all on *.* to wing@'localhost'; //使⽤GRANT 语句创建⽤户并授权 mysql> grant all on *.* to wing@'localhost' identified by 'Wing@123';   3.删除⽤户 //1.drop user 语句删除 mysql> drop user 'wing'@'localhost'; #注意mysql5.6:先回收权限, 然后删除 mysql> revoke all privilege user_name; mysql> drop user user_name; //2.delete语句删除 mysql> delete from mysql.user where user='wing' and host='localhost'; mysql> select user,host from user; +---------------+-----------+ | user | host | +---------------+-----------+ | root | % | | mysql.session | localhost | | mysql.sys | localhost | | root | localhost | +---------------+-----------+ 4 rows in set (0.00 sec)   4.修改 root ⽤户密码 //⽅法1, Shell修改⽅式 # mysqladmin -uroot -p'Wing@123' password 'NewWing@123' //⽅法2, 修改数据表 # mysql -uroot -p'NewWing@123' mysql> update mysql.user set authentication_string=password('Wing@123') where user='root' and host='localhost'; //刷新权限 mysql> flush privileges; //⽅法3, 设定密码 mysql> set password=password('Wing@123');   5.修改其他⽤户密码 //⽅法1 mysql> create user wing1@'localhost' identified by 'Wing1@123'; mysql> set password for wing1@'localhost'=password('NewWing1@123'); //⽅法2, 修改数据表 mysql> update mysql.user set authentication_string=password('Wing1@123') where user='wing1' and host='localhost'; //刷新权限 mysql> flush privileges; //普通⽤户⾃⼰修改⾃⼰密码 set password=password("Wing1@123"); 访问权限系统 mysql权限表 mysql.user 全局授权 ⽤户字段 权限字段 安全字段 资源控制字段 mysql> select * from mysql.user where user='root'\G *************************** 1. row *************************** Host: localhost User: root Select_priv: Y Insert_priv: Y Update_priv: Y Delete_priv: Y Create_priv: Y Drop_priv: Y Reload_priv: Y Shutdown_priv: Y Process_priv: Y File_priv: Y Grant_priv: Y References_priv: Y Index_priv: Y Alter_priv: Y Show_db_priv: Y Super_priv: Y Create_tmp_table_priv: Y Lock_tables_priv: Y Execute_priv: Y Repl_slave_priv: Y Repl_client_priv: Y Create_view_priv: Y Show_view_priv: Y Create_routine_priv: Y Alter_routine_priv: Y Create_user_priv: Y Event_priv: Y Trigger_priv: Y Create_tablespace_priv: Y ssl_type: ssl_cipher: x509_issuer: x509_subject: max_questions: 0 max_updates: 0 max_connections: 0 max_user_connections: 0 plugin: mysql_native_password authentication_string: *4147336C7F7536D206BD558035D39F064E07A2E3 password_expired: N password_last_changed: 2023-05-25 17:15:33 password_lifetime: NULL account_locked: N mysql.db (数据库级) ⽤户字段 权限字段 mysql> select * from mysql.db\G *************************** 1. row *************************** Host: localhost Db: performance_schema User: mysql.session Select_priv: Y Insert_priv: N Update_priv: N Delete_priv: N Create_priv: N Drop_priv: N Grant_priv: N References_priv: N Index_priv: N Alter_priv: N Create_tmp_table_priv: N Lock_tables_priv: N Create_view_priv: N Show_view_priv: N Create_routine_priv: N Alter_routine_priv: N Execute_priv: N Event_priv: N Trigger_priv: N mysql.tables_priv(表级) mysql.columns_priv(列级) 权限应⽤的顺序 user->db->tables->columns 语法格式 grant 权限列表 on 库名.表名 to '⽤户名'@'客户端主机' [identified by ' 密码' with option 参数]; 相关参数: 1.权限列表 all 所有权限(不包括授权权限) 单独授权 select,update,insert,delete 2.库名表名 *.* 所有库下的所有表 Global level wing.* 针对 wing 库下的所有表 Database level wing.student 针对 wing 库下的 student 表 Table level SELECT (id),INSERT (name,age) ON wing.t1 针对 wing 库下⾯ t1 表的字段 Column level 3.客户端主机 localhost 指定本机 10.1.106.70 指定具体主机 10.1.106.0 ⽹段的所有主机 10.1.106.% ⽹段的所有主机 % 指定所有主机   参数 GRANT OPTION 授权选项 MAX_QUERIES_PER_HOUR 定义每⼩时允许执⾏的查询数 MAX_UPDATES_PER_HOUR 定义每⼩时允许执⾏的更新数 MAX_CONNECTIONS_PER_HOUR 定义每⼩时可以建⽴的连接数 MAX_USER_CONNECTIONS 定义单个⽤户同时可以建⽴的连接数   grant 授权示例 //没有授权的权限 select user,host,authentication_string from mysql.user; delete from mysql.user where user='wing' and host='%'; GRANT ALL ON *.* TO wing@'%' IDENTIFIED BY 'Wing@123'; mysql> GRANT ALL ON *.* TO wing@'%' IDENTIFIED BY 'Wing@123'; ERROR 1045 (28000): Access denied for user 'wing'@'%' (using password: YES) //有授权权限 delete from mysql.user where user='wing1' and host='%'; delete from mysql.user where user='wing1' and host='localhost'; GRANT ALL ON *.* TO wing1@'%' IDENTIFIED BY 'Wing@123' WITH GRANT OPTION; //授权bbs库给wing2⽤户 GRANT ALL ON bbs.* TO wing2@'%' IDENTIFIED BY 'Wing@123'; create database bbs; //授权bbs库给wing3⽤户@10.1.106.70 GRANT ALL ON bbs.* TO wing3@'10.1.106.70' IDENTIFIED BY 'Wing@123'; mysql -uwing3 -p -h10.1.106.70 // 授权bbs.user表只能 wing4⽤户访问 GRANT ALL ON bbs.user TO wing4@'%' IDENTIFIED BY 'Wing@123'; mysql> create table t1(id int); Query OK, 0 rows affected (0.01 sec) mysql> create table user(id int AUTO_INCREMENT PRIMARY key,name varchar(10),age int); Query OK, 0 rows affected (0.01 sec) mysql> show tables; +---------------+ | Tables_in_bbs | +---------------+ | user | +---------------+ 1 row in set (0.00 sec) //授权wing5对 bbs库user表中id 只能查询, name和age字段可以插⼊ GRANT SELECT(id),INSERT(name,age) ON bbs.user TO wing5@'%' IDENTIFIED BY 'Wing@123'; insert into user(name,age) values('wing',18); mysql> select id from user; +----+ | id | +----+ | 1 | +----+ 1 row in set (0.00 sec) mysql> select id,name,age from user; ERROR 1143 (42000): SELECT command denied to user 'wing5'@'mysql.server' for column 'name' in table 'user' mysql> insert into user(id,name,age) values(2,'wing',18); ERROR 1143 (42000): INSERT command denied to user 'wing5'@'mysql.server' for column 'id' in table 'user' mysql> insert into user(name,age) values('wing',18); Query OK, 1 row affected (0.00 sec) mysql> select id from user; +----+ | id | +----+ | 1 | | 2 | +----+ 2 rows in set (0.00 sec) 访问权限回收 1.查看⽤户权限 mysql> show grants; +---------------------------------------------------------------------+ | Grants for root@localhost | +---------------------------------------------------------------------+ | GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' WITH GRANT OPTION | | GRANT PROXY ON ''@'' TO 'root'@'localhost' WITH GRANT OPTION | +---------------------------------------------------------------------+ 2 rows in set (0.00 sec) mysql> SHOW GRANTS\G *************************** 1. row *************************** Grants for root@localhost: GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' WITH GRANT OPTION *************************** 2. row *************************** Grants for root@localhost: GRANT PROXY ON ''@'' TO 'root'@'localhost' WITH GRANT OPTION 2 rows in set (0.00 sec) #查看所有⽤户 mysql> select user,host,authentication_string from mysql.user; +---------------+-------------+-------------------------------------------+ | user | host | authentication_string | +---------------+-------------+-------------------------------------------+ | root | localhost | *4147336C7F7536D206BD558035D39F064E07A2E3 | | mysql.session | localhost | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE | | mysql.sys | localhost | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE | | root | % | *D9ED32292D8F86849C725F9D9FD2B7B2FC29F2BA | | wing3 | 10.1.106.70 | *D9ED32292D8F86849C725F9D9FD2B7B2FC29F2BA | | wing2 | % | *D9ED32292D8F86849C725F9D9FD2B7B2FC29F2BA | | wing1 | % | *D9ED32292D8F86849C725F9D9FD2B7B2FC29F2BA | | wing4 | % | *D9ED32292D8F86849C725F9D9FD2B7B2FC29F2BA | | wing5 | % | *D9ED32292D8F86849C725F9D9FD2B7B2FC29F2BA | +---------------+-------------+-------------------------------------------+ //查看其它⽤户权限 mysql> show grants for wing1@'%'; +--------------------------------------------------------------+ | Grants for wing1@% | +--------------------------------------------------------------+ | GRANT ALL PRIVILEGES ON *.* TO 'wing1'@'%' WITH GRANT OPTION | +--------------------------------------------------------------+ 1 row in set (0.00 sec)   2.回收权限 语法: REVOKE 权限列表 ON 数据库名 FROM ⽤户名@'客户端主机'; //回收Delete权限 mysql> revoke DELETE on *.* from wing1@'%'; Query OK, 0 rows affected (0.01 sec) mysql> show grants for wing1@'%'\G *************************** 1. row *************************** Grants for wing1@%: GRANT SELECT, INSERT, UPDATE, CREATE, DROP, RELOAD, SHUTDOWN, PROCESS, FILE, REFERENCES, INDEX, ALTER, SHOW DATABASES, SUPER, CREATE TEMPORARY TABLES, LOCK TABLES, EXECUTE, REPLICATION SLAVE, REPLICATION CLIENT, CREATE VIEW, SHOW VIEW, CREATE ROUTINE, ALTER ROUTINE, CREATE USER, EVENT, TRIGGER, CREATE TABLESPACE ON *.* TO 'wing1'@'%' WITH GRANT OPTION 1 row in set (0.00 sec) //回收所有权限 mysql> revoke ALL PRIVILEGES ON *.* from 'wing1'@'%'; Query OK, 0 rows affected (0.00 sec) mysql> show grants for wing1@'%'\G *************************** 1. row *************************** Grants for wing1@%: GRANT USAGE ON *.* TO 'wing1'@'%' WITH GRANT OPTION 1 row in set (0.00 sec) //回收grant权限 mysql> revoke GRANT OPTION ON *.* from 'wing1'@'%'; Query OK, 0 rows affected (0.00 sec) mysql> show grants for wing1@'%'\G *************************** 1. row *************************** Grants for wing1@%: GRANT USAGE ON *.* TO 'wing1'@'%' 1 row in set (0.00 sec) 开发⼈员 就是select 权限 或者对某⼀个库有权限 ⼀定不能root权限 业务测java程序 连接都有单独⾃⼰权限 app ⽤户只能访问app库 权限最⼩化    

标签:权限,15,GRANT,08,user,mysql,数据库安全,localhost,priv
From: https://www.cnblogs.com/BXXY5961/p/17484449.html

相关文章

  • 2023.6.15每日一题
    原题链接:A-CodeforcesRound666(Div.1)-CB-EducationalCodeforcesRound82(RatedforDiv.2)-CA.MonsterInvaders-2300题目大意在一款RPG当中,有两种类型的怪物,普通怪物血量为\(1\),boss的血量为\(2\)。我们有三种攻击手段:手枪,对一个怪物造成1点伤害,......
  • 2023-06-15:说一说Redis的Key和Value的数据结构组织?
    2023-06-15:说一说Redis的Key和Value的数据结构组织?答案2023-06-15:全局哈希表Redis使用哈希表作为保存键值对的数据结构,通过哈希函数将Key映射为哈希表中的一个索引位置,使得Key-Value可以在O(1)时间复杂度内被快速访问。在Redis中,哈希表是由多个哈希桶(也称为槽位/数组元素)组成......
  • 2023.6.15 07.数据库存储过程
    07.数据库存储过程存储过程MySQL存储过程是⼀组预编译的SQL语句,可以在MySQL数据库中定义和存储,并在需要时执⾏。存储过程可以接受参数、执⾏条件判断、循环、异常处理等操作,使得开发⼈员可以把⼀系列操作组合成⼀个可重复使⽤的单元,从⽽提⾼代码的复⽤性和可维护......
  • (2023.6.15)linux下can的调试工具交叉编译
    //源码包路径:https://public.pengutronix.de/software/libsocketcan/libsocketcan-0.0.11.tar.bz2https://public.pengutronix.de/software/socket-can/canutils/v4.0/canutils-4.0.6.tar.bz2//编译命令./configure--host=arm-linux-gnueabihf--prefix=/home/fangzeli/work/......
  • 2023-6-15 面试笔试复盘总结
    四川君迪能源后端笔试2023-6-15简答题:线程和进程的区别本质区别:进程是操作系统资源分配的基本单位,而线程是处理器任务调度和执行的基本单位。包含关系:一个进程至少有一个线程,线程是进程的一部分,所以线程也被称为轻权进程或者轻量级进程。资源开销:每个进程都有独立的地址空......
  • 欧奈儿行业 RPS 排名,一图览全貌 2023-06-15
    自动复盘2023-06-15k线图是最好的老师,点击详情图可以看到行业20日RPS的排名,最底下子图是行业rps走势线跟踪板块总结:成交额超过100亿排名靠前,macd柱由绿转红成交量要大于均线有必要给每个行业加一个上级的归类,这样更能体现主流方向rps有时候比较滞后,但不少是欲......
  • C/C++《数据结构》课程设计指导书[2023-06-15]
    C/C++《数据结构》课程设计指导书[2023-06-15]《数据结构》课程设计指导书适用专业:计算机2022级编写人:李玉龙2023年5月《数据结构》课程设计指导书一、设计目的1、训练学生灵活应用所学数据结构知识,独立完成问题分析,结合数据结构理论知识,编写程序求解指定问题;2.初步掌握软......
  • C/C++器材信息管理系统[2023-06-15]
    C/C++器材信息管理系统[2023-06-15]使用C++程序设计语言,完成一个项目,项目名为:器材信息管理系统,要实现的功能如下,且每项功能具有数据校对验证:1、实现新器材的录入,包括器材的名称、录入日期、购买价钱等信息;2、当有器材借用需求时,进行借用登记,主要流程为:查询器材数量,若库存数量大......
  • 深入理解ASEMI代理光宝LTV-152光耦的特性与应用
    编辑-Z光耦LTV-152是一种广泛应用于电子设备中的光电器件,它的主要功能是实现电路之间的隔离和信号传输。本文将深入探讨光耦LTV-152的特性和应用,帮助读者更好地理解和使用这种重要的电子元件。 一、光耦LTV-152的特性 1.高隔离电压:光耦LTV-152具有高达5000Vrms的隔离电压,......
  • 2023-06-15 css伪类before、after制作文字两边横线
    <divclass="box">测试</div>···.box{color:#ccc;text-align:center;position:relative;&::after{position:absolute;left:24rpx;top:52%;content:'';width:calc(50%......