MYSQL默認的數據文件存儲目錄爲/var/lib/mysql。假如要把目錄移到/home/data下需要進行下面幾步:
1、home目錄下建立data目錄
cd /homemkdir data
2、把MySQL服務進程停掉:
mysqladmin -u root -p shutdown
3、把/var/lib/mysql整個目錄移到/home/data
mv /var/lib/mysql /home/data/
這樣就把MySQL的數據文件移動到了/home/data/mysql下
4、找到my.cnf配置文件
如果/etc/目錄下沒有my.cnf配置文件,請到/usr/share/mysql/下找到*.cnf文件,拷貝其中一個到/etc/並改名爲my.cnf)中。命令如下:
[root@test1 mysql]# cp /usr/share/mysql/my-medium.cnf /etc/my.cnf
5、編輯MySQL的配置文件/etc/my.cnf
爲保證MySQL能夠正常工作,需要指明mysql.sock文件的產生位置。修改socket=/var/lib/mysql/mysql.sock一行中等號右邊的值爲:/home/mysql/mysql.sock 。操作如下:
vi my.cnf (用vi工具編輯my.cnf文件,找到下列數據修改之)# The MySQL server[mysqld] port = 3306#socket = /var/lib/mysql/mysql.sock(原內容,爲了更穩妥用“#”註釋此行)socket = /home/data/mysql/mysql.sock (加上此行)
6、修改MySQL啓動腳本/etc/init.d/mysql
最後,需要修改MySQL啓動腳本/etc/init.d/mysql,把其中datadir=/var/lib/mysql一行中,等號右邊的路徑改成你現在的實際存放路徑:home/data/mysql。
[root@test1 etc]# vi /etc/init.d/mysql#datadir=/var/lib/mysql(註釋此行)datadir=/home/data/mysql (加上此行)
如果是CentOS還要改 /usr/bin/mysqld_safe 相關文件位置;
最後 做一個mysql.sock 鏈接:
in -s /home/data/mysql/mysql.sock /var/lib/mysql/mysql.sock
7、重新啓動MySQL服務
/etc/init.d/mysqld start
或用reboot命令重啓Linux
如果工作正常移動就成功了,否則對照前面的7步再檢查一下。還要注意目錄的屬主和權限。
複製內容到剪貼板
代碼:
[root@sample ~]# chown -R mysql:mysql /home/data/mysql/ ← 改變數據庫的歸屬爲mysql
[root@sample ~]# chmod 700 /home/data/mysql/test/ ← 改變數據庫目錄屬性爲700
[root@sample ~]# chmod 660 /home/data/mysql/test/* ← 改變數據庫中數據的屬性爲660
錯誤解決方案:
1.在CentOS上,如果mysql是通過yum安裝的,那麼可能使用上面的方法不能完全湊效。
原因:mysql的配置文件有多處,除了更改/etc/my.cnf文件之外,還需要更改/usr/lib64/mysql/mysql_config
這個文件裏面有一行“ldata='/var/lib/mysql'”和"socket=/var/lib/mysql/mysql.sock",這裏也需要改掉
2.另外,還有權限問題,查看/var/log/mysqld.log,發現Can't create test file /xxx/mysql/centos5.lower-test
這裏是因爲沒有權限創建或讀取文件。
解決辦法就是使用setenforce 0 這個命令,讓系統關閉權限校驗,然後再運行命令 service mysqld start 發現OK了。
另外一個辦法是restorecon -FRv /home/data/mysql,或者chcon -R -t mysqld_db_t /home/data/mysql