mariadb系统盘迁移数据盘

停止 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

相关推荐
星星也在雾里10 小时前
PgBouncer 解决 PostgreSQL 连接数超限 + 可视化监控
数据库·postgresql
雨辰AI12 小时前
SpringBoot3 + 人大金仓读写分离 + 分库分表 + 集群高可用 全栈实战
java·数据库·mysql·政务
长城202412 小时前
关于MySql的ONLY_FULL_GROUP_BY问题
数据库·mysql·聚合列
常常有12 小时前
MySQL 底层执行原理:输入SQL语句到两阶段提交
数据库·sql·mysql
Mr. zhihao13 小时前
深入解析redis基本数据结构
数据结构·数据库·redis
m0_7488394913 小时前
利用天正暖通CAD快速掌握风管数量统计的方法
数据库
随身数智备忘录13 小时前
什么是设备管理体系?设备管理体系包含哪些核心模块?
网络·数据库·人工智能
海市公约13 小时前
MySQL更新语句执行全流程:从Buffer Pool修改到二阶段提交
数据库·mysql·binlog·innodb·undo log·二阶段提交·update执行原理
颂love14 小时前
MySQL的执行流程
android·数据库·mysql
程序leo源14 小时前
Qt窗口详解
开发语言·数据库·c++·qt·青少年编程·c#