zoukankan      html  css  js  c++  java
  • Linux下的 mariadb 使用 root 用户启动方式

    近日因测试安全产品需要,想调整mariadb的启动用户为root, 经历一番波折后终于成功!

    注意:以root身份启动mysql是一项非常危险行为,相当于给了数据库操作用户(数据库管理员或黑客)一个通过mysql对系统直接操作的通道!

    实际上是官方不允许root启动的, 因此在一般启动方式下root启动会返回启动失败,并于 /var/log/mariadb/mariadb.log 中提示

    Please consult the Knowledge Base to find out how to run mysqld as root!


    好吧,转入正题,关于Mariadb 启动方式:

    一般人就会操作:  systemctl start mariadb

    然而这个指令实际上就是调用了  mariadb.service  (具体目录用find找),执行对 mariadb 进行启动。

    mariadb.service 修改配置如下:

    # vi `find /usr -name 'mariadb.service' ` 

    [Unit]

    [Service]

    Type=simple

    User=mysql      此处修改为  User=root        ||  服务的启动用户

    Group=mysql    此处修改为  Group=root      ||  服务的启动组

    #初始化mysql库文件的脚本,如果 mysql目录不为空会提示 Database Mariadb is probably initialized in /var/lib/mysql already, nothing is done,  如果排错时看见此内容可忽略

    ExecStartPre=/usr/libexec/mariadb-prepare-db-dir %n           

    #执行mysqld的执行脚本,做了安全检查,就是这个文件限制root启动的

    ExecStart=/usr/bin/mysqld_safe --basedir=/usr   此处添加参数   --user=root     

    以下略。。。

    #systemctl demon-reload

    #systemctl restart mariadb

    PS:同样操作方式支持mysql以其他用户启动,

    BUT   /var/lib/mysql  /var/log/mariadb  这两个目录的权限或属主需作调整。

  • 相关阅读:
    结对(求数组的最大子数组和)
    结对3(求一维数组最大子数组的和扩展)
    结对3(电梯调度需求分析)
    结对开发2(求二维数组的最大子数组和)
    四则运算3(四则运算2程序的扩展)
    四则运算2代码测试
    四则运算2程序及运行
    C++输出四则运算设计题的思路
    C++编程显示四则运算题目
    软件课外读物阅读计划
  • 原文地址:https://www.cnblogs.com/caya-yuan/p/11898915.html
Copyright © 2011-2022 走看看