MySQL修改預設儲存路徑

來源:互聯網
上載者:User

MySQL修改預設儲存路徑

Linux下儲存資料,MySQL無疑是個很不錯的選擇。MySQL的預設儲存路徑為/var/lib/mysql。以前資料庫一直不是很大,總共十個G左右的大小,放在預設路徑毫無壓力。但是今天,因為新匯入一個資料庫,光是匯入資料就是30+G,瞬間就悲劇了,因為我並沒有為/目錄準備足夠的硬碟分區空間。所以,修改配置,遷移資料庫儲存路徑到合適的地方成了最省力的選擇。

停止mysql服務,準備資料

因為這是運行到一半修改的,所以有一些曆史遺留資料。應當先停止資料庫服務,我使用的Fedora 19 , 命令可以如下

# service mysqld stop

然後妥妥的把資料從預設位置 /var/lib/mysql下的內容到目標位置 -- 比如我的,/home/mysql

修改設定檔

my.cnf

首先需要修改設定檔/etc/my.cnf。其中有datadir和socket之類字樣。意義不言自明,就是修改它們的路徑啦。當然,這個my.cnf可能出現在其他地方,如果是新的使用者,甚至可能找不到,但沒有關係,

ls /usr/share/mysql/

可以看到一些mysql-XXX-cnf , 可以從其中選擇一些作為模板,修改一下,丟/etc下即可。

get_mysql_option

除了cnf外,還需要修改一個get_mysql_option的設定,真是受不了。。。

網上大多是以前版本,稱應該修改"/etc/rc.d/init.d/mysqld"這個檔案 -- 實際上對於fedora 19而言,這個指令碼並不存在。
查看錯誤資訊,可以看到錯誤提示如下:

[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.

出現問題的源頭似乎是/usr/libexec/mysqld-wait-ready 。 檢查修改basedir等參數,然後開跑即可。。。

其他方法

實在不行,還有最後的辦法:備份資料,卸載,重新安裝 -- 有yum在這其實也很方便。
然後配置好檔案,尤其是修改/usr/bin/mysql_install_db,其中的ldata參數

mysql_install_db 

即可

後記

後來,我重裝了機器,給var單獨配了個可擴充的分區。個人覺得,這才是最讓人舒服的設定。

--------------------------------------分割線 --------------------------------------

用mysqldump和mysqlbinlog的MySQL資料恢複實驗

Ubuntu 14.04下安裝MySQL

《MySQL權威指南(原書第2版)》清晰中文掃描版 PDF

Ubuntu 14.04 LTS 安裝 LNMP Nginx\PHP5 (PHP-FPM)\MySQL

Ubuntu 14.04下搭建MySQL主從伺服器

Ubuntu 12.04 LTS 構建高可用分布式 MySQL 叢集

Ubuntu 12.04下原始碼安裝MySQL5.6以及Python-MySQLdb

MySQL-5.5.38通用二進位安裝

--------------------------------------分割線 --------------------------------------

本文永久更新連結地址:

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.