近日因测试安全产品需要,想调整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  这两个目录的权限或属主需作调整。

总结

以上所述是小编给大家介绍的Linux下的 mariadb 使用 root 用户启动方式,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!