停止 MariaDB 服务
sudo systemctl stop mariadb
sudo systemctl status mariadb # 应显示 "inactive"
创建新数据目录并设置权限
sudo mkdir -p /data/mysql
sudo chown mysql:mysql /data/mysql
sudo chmod 750 /data/mysql
复制原数据到数据盘新位置
sudo rsync -av /var/lib/mysql/ /data/mysql/
sudo ls -l /data/mysql/
修改 MariaDB 配置文件
vim /etc/my.cnf.d/mariadb-server.cnf
mysqld
datadir=/data/mysql #/var/lib/mysql
socket=/data/mysql/mysql.sock #/var/lib/mysql/mysql.sock
log-error=/data/mysql/mariadb.log #/var/log/mariadb/mariadb.log
pid-file=/data/mysql/mariadb.pid #/run/mariadb/mariadb.pid
应用 SELinux设置正确上下文
sudo semanage fcontext -a -t mysqld_db_t "/data/mysql(/.*)?"
如出现 AttributeError: module 'pkg_resources' has no attribute 'file'
修改
sudo vim /usr/lib64/python3.6/site-packages/setools/init.py
version = pkg_resources.get_distribution("setools").version
绕过版本检查
version = "4.3.0" # 手动指定版本(可选)
sudo restorecon -Rv /data/mysql
启动 MariaDB 并验证
sudo systemctl start mariadb
sudo systemctl status mariadb
如出现:mysqli::real_connect(): (HY000/2002): No such file or directory
通常表示 PHP 无法通过 Unix socket 连接到 MariaDB/MySQL ,最常见的原因是:MariaDB 的 socket 文件路径 和 PHP 配置的 socket 路径不一致
查找php.ini文件地址
php --ini # CLI 模式
php -i | grep "Configuration File" # Web 模式(需通过浏览器或 phpinfo())
vim /etc/php.ini
mysqli.default_socket = /data/mysql/mysql.sock
pdo_mysql.default_socket = /data/mysql/mysql.sock
mysql.default_socket = /data/mysql/mysql.sock
重新启动apache
sudo systemctl restart php-fpm # 或
sudo systemctl restart httpd # Apache