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

相关推荐
XDHCOM1 天前
ORA-32484重复列名错误,ORACLE数据库CYCLE子句故障修复与远程处理方案
数据库·oracle
翻斗包菜1 天前
PostgreSQL 日常维护完全指南:从基础操作到高级运维
运维·数据库·postgresql
呆瑜nuage1 天前
MySQL表约束详解:8大核心约束实战指南
数据库·mysql
liliangcsdn1 天前
Agent Memory智能体记忆系统的示例分析
数据库·人工智能·全文检索
那个失眠的夜1 天前
Mybatis延迟加载策略
xml·java·数据库·maven·mybatis
Rick19931 天前
SQL 执行流程
数据库·sql
M--Y1 天前
Redis常用数据类型
数据结构·数据库·redis
猿小喵1 天前
MySQL慢查询分析与处理-第二篇
数据库·mysql·性能优化
Y001112361 天前
MySQL-进阶
开发语言·数据库·sql·mysql
徒 花1 天前
数据库知识复习01
数据库