mysql5.6修改默认目录_MySQL修改默认存储路径
Linux下存儲數(shù)據(jù),MySQL無疑是個(gè)很不錯(cuò)的選擇。MySQL的默認(rèn)存儲路徑為/var/lib/mysql。以前數(shù)據(jù)庫一直不是很大,總共十個(gè)G左右的
Linux下存儲數(shù)據(jù),MySQL無疑是個(gè)很不錯(cuò)的選擇。MySQL的默認(rèn)存儲路徑為/var/lib/mysql。以前數(shù)據(jù)庫一直不是很大,總共十個(gè)G左右的大小,放在默認(rèn)路徑毫無壓力。但是今天,因?yàn)樾聦?dǎo)入一個(gè)數(shù)據(jù)庫,光是導(dǎo)入數(shù)據(jù)就是30+G,瞬間就悲劇了,因?yàn)槲也]有為/目錄準(zhǔn)備足夠的硬盤分區(qū)空間。所以,修改配置,遷移數(shù)據(jù)庫存儲路徑到合適的地方成了最省力的選擇。
停止mysql服務(wù),準(zhǔn)備數(shù)據(jù)
因?yàn)檫@是運(yùn)行到一半修改的,所以有一些歷史遺留數(shù)據(jù)。應(yīng)當(dāng)先停止數(shù)據(jù)庫服務(wù),我使用的Fedora 19 , 命令可以如下
# service mysqld stop
然后妥妥的把數(shù)據(jù)從默認(rèn)位置 /var/lib/mysql下的內(nèi)容到目標(biāo)位置 -- 比如我的,/home/mysql
修改配置文件
my.cnf
首先需要修改配置文件/etc/my.cnf。其中有datadir和socket之類字樣。意義不言自明,就是修改它們的路徑啦。當(dāng)然,這個(gè)my.cnf可能出現(xiàn)在其他地方,如果是新的用戶,甚至可能找不到,但沒有關(guān)系,
ls /usr/share/mysql/
可以看到一些mysql-XXX-cnf , 可以從其中選擇一些作為模板,修改一下,丟/etc下即可。
get_mysql_option
除了cnf外,還需要修改一個(gè)get_mysql_option的設(shè)置,真是受不了。。。
網(wǎng)上大多是以前版本,稱應(yīng)該修改"/etc/rc.d/init.d/mysqld"這個(gè)文件 -- 實(shí)際上對于fedora 19而言,這個(gè)腳本并不存在。
查看錯(cuò)誤信息,可以看到錯(cuò)誤提示如下:
[root@f-argcv etc]# systemctl status mysqld.service
mysqld.service - MariaDB database server
Loaded: loaded (/usr/lib/systemd/system/mysqld.service; enabled)
Active: failed (Result: exit-code) since Wed 2013-10-23 19:38:22 HKT; 8s ago
Process: 4936 ExecStartPost=/usr/libexec/mysqld-wait-ready $MAINPID (code=exited, status=1/FAILURE)
Process: 4935 ExecStart=/usr/bin/mysqld_safe --basedir=/usr (code=exited, status=0/SUCCESS)
Process: 4913 ExecStartPre=/usr/libexec/mysqld-prepare-db-dir %n (code=exited, status=0/SUCCESS)
Oct 23 19:38:20 f-argcv systemd[1]: Starting MariaDB database server...
Oct 23 19:38:21 f-argcv mysqld_safe[4935]: 131023 19:38:21 mysqld_safe Logging to '/var/log/mysqld.log'.
Oct 23 19:38:21 f-argcv mysqld_safe[4935]: 131023 19:38:21 mysqld_safe Starting mysqld daemon with databases from /home/mysql/data
Oct 23 19:38:21 f-argcv mysqld_safe[4935]: 131023 19:38:21 mysqld_safe mysqld from pid file /var/run/mysqld/mysqld.pid ended
Oct 23 19:38:22 f-argcv systemd[1]: mysqld.service: control process exited, code=exited status=1
Oct 23 19:38:22 f-argcv systemd[1]: Failed to start MariaDB database server.
Oct 23 19:38:22 f-argcv systemd[1]: Unit mysqld.service entered failed state.
出現(xiàn)問題的源頭似乎是/usr/libexec/mysqld-wait-ready 。 檢查修改basedir等參數(shù),然后開跑即可。。。
其他方法
實(shí)在不行,還有最后的辦法:備份數(shù)據(jù),卸載,,重新安裝 -- 有yum在這其實(shí)也很方便。
然后配置好文件,尤其是修改/usr/bin/mysql_install_db,其中的ldata參數(shù)
mysql_install_db
即可
后記
后來,我重裝了機(jī)器,給var單獨(dú)配了個(gè)可擴(kuò)展的分區(qū)。個(gè)人覺得,這才是最讓人舒服的設(shè)置。
--------------------------------------分割線 --------------------------------------
用mysqldump和mysqlbinlog的MySQL數(shù)據(jù)恢復(fù)實(shí)驗(yàn)
Ubuntu 14.04下安裝MySQL
《MySQL權(quán)威指南(原書第2版)》清晰中文掃描版 PDF
Ubuntu 14.04 LTS 安裝 LNMP Nginx\PHP5 (PHP-FPM)\MySQL
Ubuntu 14.04下搭建MySQL主從服務(wù)器
Ubuntu 12.04 LTS 構(gòu)建高可用分布式 MySQL 集群
Ubuntu 12.04下源代碼安裝MySQL5.6以及Python-MySQLdb
MySQL-5.5.38通用二進(jìn)制安裝
--------------------------------------分割線 --------------------------------------
本文永久更新鏈接地址:
本文原創(chuàng)發(fā)布php中文網(wǎng),轉(zhuǎn)載請注明出處,感謝您的尊重!
總結(jié)
以上是生活随笔為你收集整理的mysql5.6修改默认目录_MySQL修改默认存储路径的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: mysql业务 日志_mysql笔记之日
- 下一篇: linux cmake编译源码,linu