MySQL修改datadir目录

MySQL修改datadir目录

更改MySQL的数据目录由/var/lib/mysql/更换至/data/mysql/

1)关闭MySQL
[root@test2 ~]# systemctl stop mysqld
Shutting down MySQL..................                      [  OK  ]
2)datadir和socket的目录
datadir=/data/mysql  
socket=/data/mysql/mysql.sock
3)拷贝数据文件
mkdir -p /data/mysql  
chown -R mysql:mysql /data/mysql
cp -a var/lib/mysql/* /data/mysql/
4)启动MySQL
[root@test2 ~]# systemctl start mysql
Starting MySQL.........                                    [  OK  ]
5)问题解决

更改了mysql的配置文件,重新启动的时候发现:启动失败:

Job for mysqld.service failed because the control process exited with error code. See “systemctl status mysqld.service” and “journalctl -xe” for details.

查看日志:

Loaded: loaded (/etc/rc.d/init.d/mysqld; bad; vendor preset: disabled)

Can’t create test file /home/mysql/data/d064lh.lower-test

原因就是

SELinux惹的祸

通俗的讲就是linux服务器的安全策略

这个文章可以看看:https://linux.cn/article-7317-1.html

https://www.iteye.com/blog/jejoker-1882028

解决:

临时关闭:setenforce 0

永久关闭需要修改配置文件,重启机器:

修改/etc/selinux/config 文件

将SELINUX=enforcing改为SELINUX=disabled

也有可能是apparmor问题

https://www.cnblogs.com/Amaranthus/p/5738332.html

6)不修改/etc/my.cnf利用软连接的方法
rm -rf /var/lib/mysql
ln -s /var/lib/mysql /data/mysql
chown -R mysql:mysql /data/mysql
systemctl start mysql
7)测试
mysql> show variables like '%datadir%';
+---------------+--------------+
| Variable_name | Value        |
+---------------+--------------+
| datadir       | /data/mysql/ |
+---------------+--------------+
1 row in set (0.01 sec)

mysql> create database hch;
Query OK, 1 row affected (0.10 sec)

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| OMServer           |
| ceshi              |
| hch                |
| hchtest            |
| hchtest1           |
| mysql              |
| percona            |
| performance_schema |
| rep_test           |
| repldb             |
| repldb1            |
| test               |
| wna                |
+--------------------+
14 rows in set (0.00 sec)

mysql> use hch;
Database changed

mysql> create table t1(id int);
Query OK, 0 rows affected (0.15 sec)

mysql> insert into t1 values(1);
Query OK, 1 row affected (0.08 sec)

mysql> insert into t1 values(2);
Query OK, 1 row affected (0.00 sec)

mysql> select * from t1;
+------+
| id   |
+------+
|    1 |
|    2 |
+------+
2 rows in set (0.00 sec)
  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值