近日因測驗安全產品需要,想調整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 這兩個目錄的權限或屬主需作調整,
轉載請註明出處,本文鏈接:https://www.uj5u.com/caozuo/154788.html
標籤:Linux
上一篇:輕量級監控平臺之cpu監控
