设为首页 收藏本站
查看: 331|回复: 0

[经验分享] mysql之DCL(GRANT、REVOKE)和mysql用户密码相关

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-8-3 08:57:54 | 显示全部楼层 |阅读模式
DCL:数据控制语言
    GRANT
    REVOKE

用户:虚拟用户。
密码:使用password()函数

用户的账号仅提供认证,要想使用功能需要另外的授权。

用户账号结构:
    USERNAME@HOST

    USERNAME:
        一般不超过16个字符

    HOST:
        HOSTNAME
        IP
        IP/NETMASK
        FQDN
        DOMAIN
        %任意长度任意字符
        _任意单个字符

    默认mysql启动时会正反解主机名,所以启用mysql服务器是可以使用--skip-name-resolv禁用解析,可以 提高用户连接速度。


授权表:
    mysql在启动的时候会读取下列表到内存,并根据这些表生成授权表:
    user
        用户账号,全局权限,其他的非权限字段
    db
        数据库级别的权限定义
    host
        已废弃,已整合进user表中
    tables_priv
        表级别的权限定义
    colums_priv
        列(字段)段级别权限
    procs_priv
        存储过程和存储函数相关的权限
    proxies_priv
        代理用户权限

    查看对应授权表的内容:
        mysql>USE mysql;
        mysql>SELECT * FROM db \G

权限级别:
    全局
    库
    表
    列
    存储过程和存储函数

常见语句的权限应用范围:
    CREATE 数据库 表 索引
    DROP 数据库 表 视图
    GRANT OPTION 数据库 表 存储过程和函数
    LOCK TABLES 数据库
    REFERENCES 数据库 表
    EVENT 数据库

    INSERT 表 字段
    SELECT 表 字段
    UPDATE 表字段

    DELETE 表
    ALTER 表
    INDEX 表

    CREATE TEMPORARY TABLES  表
    TRIGGER 表

    CREATE TABLESPACE 服务器管理
    CREATE USER 服务器管理
    PROCESS 服务器管理
    PROXY 服务器管理
    RELOAD 服务器管理
    REPLICATION CLIENT 服务器管理
    REPLACTION SLAVE 服务器管理
    SHOW DATABASES 服务器管理
    SHUTDONW 服务器管理
    SUPER 服务器管理
    ALL [PRIVILEGES] 服务器管理
    USAGE 服务器管理

    FILE 访问服务所在服务器上的文件

    ALTER ROUTINE 储存过程和函数
    CREATE ROUTINE 储存过程和函数
    EXECUTE 储存过程和函数

    CREATE VIEW 视图
    SHOW VIEW 视图

用户账号和密码:
    创建用户:
        CREATE USER 'USERNAME'@'HOST' [IDENTIFIED BY 'PASSWORD']
        通常创建的用户只有USAGE权限和简单的查询权限。

    查看用户:
        mysql>USE mysql;
        mysql> SELECT User,Host,Password From user;

    删除用户:
        DROP USER 'USERNAME'@‘HOST’

    为用户设定密码:
        1.在mysql交互交互模式下:
            mysql> SET PASSWORD FOR 'USERNAME'@'HOST'=PASSWORD('PASSWORD');

        2.使用mysqladmin:
            #mysqladmin -uUSERNAME -hHOST -p password 'PASSWORD'

        3.直接修改数据库:
            mysql> UPDATE user SET Password=PASSWORD('PASSWORD') WHERE USER='USERNAME' AND HOST='HOST';
            mysql>FLUSH PRIVILEGES;

    重命名用户:
        RENAME USER OLDUSER TO NEWUSER


用户权限:
    指定用户权限:
        若用户不存在则自动创建并授权。
        GRANT PRI1,PRI2,... ON [OBJECT_TYPE] PRIV_LEVEL TO 'USERNMAE'@'HOST' [IDENTIFIED BY 'PASSWORD'] [REQUIRE] [WITH WITH_OPTION];
            PRI:
                ALL PRIVILEGES 所有的权限

            OBJECT_TYPE: 对象类型
                TABLE
                FUNCTION 函数
                PROCEDURE  存储过程或存储函数

            PRIV_LEVEL:
                * 所有库
                *.* 所有表
                DBNAME.* 某个库的所有表
                DBNAME.TBNAME 某个库的某张表
                TBNAME 特定表
                DBNAME,ROUTINNAME 某个数据库的存储过程或存储函数

            REQUIRE:用户在连接的时候必须满足的相关属性
                NONE 无
                SSL_OPTION ssl相关
                    SSL 基于ssl
                    X509 基于x509格式的证书。

            WITH_OPTION:资源使用限定,NUM为0表示不做限定。
                GRANT_OPTION 允许该用户将获得的权限授权给其他用户
                MAX_QUERIES_PER_HOUR NUM 每小时最大查询个数为NUM个
                MAX_UPDATES_PER_HOUR NUM 每小时允许使用NUM次UPDATE
                MAX_CONNECTIONS_PER_HOUR NUM每小时发起NUM个连接请求
                MAX_USER_CONNECTIONS NUM 每小时某个账户连接次数为NUM个

    取消用户权限:
        REVOKE PRT1,PRI2,... ON [OBJECT_TYPE] PRIV_LEVEL FROM 'USERNAME'@'HOST';

    查看用户权限:
        SHOW GRANTS FOR 'USERNAME'@'HOST';

    刷新授权:
        FLUSH PRIVILEGES;

实例:
    1.创建用户test并设定密码为testpwd:
        mysql>CREATE USER 'test'@'%' IDENTIFIED BY 'testpwd';
        或
        mysql>GRANT ...
        或
        mysql>INSERT INTO mysql.user  ;

        mysql>FLUSH PRIVILEGES;


        注意:若信创建用户无法登陆,请删除匿名用户。正常情况下在初始化后就应该做。

        mysql>USE mysql;
        mysql>DELETE FROM user WHERE user='';
        mysql>FLUSH PRIVILEGES;


    2.使用GRANT命令创建账户test和重设密码为testpwd:
        mysql>CRANT CREATE ON test.* TO 'test'@'%' IDENTIFIED BY ‘testpwd’;


    3.给test用户授权CREATE权限并查看:
        mysql>GRANT CREATE ON test.* TO 'test'@'%';
        mysql>FLUSH PRIVILEGES;
        mysql>SHOW GRANTS FOR 'test'@'%';
        mysql>\q

        注意:在设定权限并刷新后,重新登陆即可生效。


    4.字段权限的授权:
        mysql>USE test
        mysql>GRANT UPDATE(Age) ON testdb TO 'test'@'%';
        mysql>UPDATE testdb SET Age=40 WHERE ID=1;


    5.SUPER权限的应用:
        mysql>GRANT SUPER ON *.* TO 'test'@'%';

        SUPER权限比较特殊,可以执行SHUTDOWN,修改全局变量等。

    6.取消test在testdb数据库中的SELECT权限:
        mysql>REVOKE SELECT ON testdb.* FROM 'test'@'%'

    7.数据库管理员密码找回:
        找回思路:
            关闭服务 --> 修改服务脚本增加启动选项 --> 启动服务 -->使用UPDATE命令修改密码 --> 关闭服务 -->修改脚本 --> 重启服务

            --skip-grant-tables 跳过授权表
            --skip-networkding 禁用网络,防止其他用户通过网络登陆。


        #systemctl stop mysqld
        #vim /etc/init.d/mysqld
            ...
            case "$mode" in
                'start')
                    $bindri/mysqld_safe  --skip-grant-tables --skip-networking ...
            ...
        #systemctl start mysqld
        #mysql
        mysql>USE mysql;
        mysql>SELET User,Host,Password FROM user;
        mysql>UPDATE user SET PASSWORD=PASSWORD('123456') WHERE User='root';
        mysql>\q
        #systemctl stop mysqld
        #vim /etc/init.d/mysqld
            ...
           case "$mode" in
                'start')
                    $bindri/mysqld_safe ...
            ...
        #systemctl start mysqld;
        #mysql -uroot -p123456
        mysql>

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-93503-1-1.html 上篇帖子: MySQL 存储过程 存储函数 概念示例 下篇帖子: mysql之mysql安装、初始化,以及mysql相关命令的使用
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表