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

相关推荐
m0_748554816 小时前
golang如何实现用户订阅偏好管理_golang用户订阅偏好管理实现总结
jvm·数据库·python
早日退休!!!7 小时前
《数据结构选型指南》笔记
数据结构·数据库·oracle
xcLeigh7 小时前
KES数据库性能优化实战
数据库·sql·性能优化·sql优化·数据性能
阿正呀7 小时前
Redis怎样实现本地缓存的高效失效通知
jvm·数据库·python
yoyo_zzm8 小时前
Laravel9.x新特性全解析
数据库·mysql·nginx
2501_901200538 小时前
mysql如何设置InnoDB引擎参数_优化innodb_buffer_pool
jvm·数据库·python
m0_495496419 小时前
mysql处理复杂SQL性能_InnoDB优化器与MyISAM差异
jvm·数据库·python
forEverPlume10 小时前
PHP怎么使用Eloquent Attribute Composition属性组合_Laravel通过组合构建复杂属性【方法】
jvm·数据库·python
2301_8092047010 小时前
mysql在docker容器中如何部署_利用docker-compose快速启动
jvm·数据库·python
虹科网络安全10 小时前
艾体宝产品|深度解读 Redis 8.4 新增功能:原子化 Slot 迁移(上)
数据库·redis·bootstrap