首先把mysql的服務(wù)先停掉,更改MySQL配置文件My.ini中的數(shù)據(jù)庫存儲主路徑,將老的數(shù)據(jù)庫存儲主路徑中的數(shù)據(jù)庫文件和文件夾復制到新的存儲主路徑,接下來重啟搞定
成都創(chuàng)新互聯(lián)成立于2013年,我們提供高端網(wǎng)站建設(shè)、重慶網(wǎng)站制作、成都網(wǎng)站設(shè)計、網(wǎng)站定制、成都全網(wǎng)營銷、小程序開發(fā)、微信公眾號開發(fā)、seo優(yōu)化排名服務(wù),提供專業(yè)營銷思路、內(nèi)容策劃、視覺設(shè)計、程序開發(fā)來完成項目落地,為柔性防護網(wǎng)企業(yè)提供源源不斷的流量和訂單咨詢。
一.首先把mysql的服務(wù)先停掉。
二.更改MySQL配置文件My.ini中的數(shù)據(jù)庫存儲主路徑
打開MySQL默認的安裝文件夾C:\Program
Files\MySQL\MySQL
Server
5.1中的my.ini文件,點擊記事本頂部的“編輯”,“查找”,在查找內(nèi)容中輸入datadir后并點擊“查找下一個”轉(zhuǎn)到“Path
to
the
database
root數(shù)據(jù)庫存儲主路徑”參數(shù)設(shè)置,找到datadir="C:/Documents
and
Settings/All
Users/Application
Data/MySQL/MySQL
Server
5.1/Data/"即是默認的數(shù)據(jù)庫存儲主路徑設(shè)置,現(xiàn)將它改到C:\mysql\data(你希望的)文件夾,正確的設(shè)置是datadir="C:/mysql/data/"。
更改完成后點擊菜單欄的“文件”,再點擊“保存”。
三.將老的數(shù)據(jù)庫存儲主路徑中的數(shù)據(jù)庫文件和文件夾復制到新的存儲主路徑
將C:/Documents
and
Settings/All
Users/Application
Data/MySQL/MySQL
Server
5.1/Data/文件夾中的所有文件和文件夾拷貝到你新建的文件夾目錄下。
四.重啟MySQL服務(wù)
五.驗證更改數(shù)據(jù)庫存儲主路徑的操作是否成功
FreeBSD主機上的mysql安裝的時候數(shù)據(jù)庫文件放在/var/db/mysql下,在Linux主機上的默認存儲位置是/var/lib/mysql/下。 如果想更換mysql的數(shù)據(jù)文件的存儲位置,則: FreeBSD下: # /usr/local/etc/rc.d/mysql-server stop(停止mysql) # mkdir /other/db(建立新的數(shù)據(jù)文件目錄,也可以直接移動過來) # mv /var/db/mysql /other/db(移動數(shù)據(jù)文件) # ln -s /other/db/mysql /var/db/mysql(建立數(shù)據(jù)文件的軟鏈接) # /usr/local/etc/rc.d/mysql-server start(啟動mysql)OK!Linux下:(linux下經(jīng)過測試,可以不用停止mysql而直接操作,不過如果是經(jīng)常更新的數(shù)據(jù)庫還是先停止的好,停止的方法在此就不介紹了?。?# mkdir /data/database(建立新的數(shù)據(jù)文件目錄,也可以直接移動過來) # mv /var/lib/mysql /data/database/(移動數(shù)據(jù)文件) # ln -s /data/database/mysql /var/lib/mysql(建立數(shù)據(jù)文件的軟鏈接) 如果您的操作用戶不是mysql,例如root用戶操作,那可能mysql對新建立的數(shù)據(jù)文件夾沒有讀取權(quán)限,還有chown,或者是chgrp,chmod才可以!
Linux 進程通過 C 標準庫中的內(nèi)存分配函數(shù) malloc 向系統(tǒng)申請內(nèi)存,但是到真正與內(nèi)核交互之間,其實還隔了一層,即內(nèi)存分配管理器(memory allocator)。常見的內(nèi)存分配器包括:ptmalloc(Glibc)、tcmalloc(Google)、jemalloc(FreeBSD)。MySQL 默認使用的是 glibc 的 ptmalloc 作為內(nèi)存分配器。
內(nèi)存分配器采用的是內(nèi)存池的管理方式,處在用戶程序?qū)雍蛢?nèi)核層之間,它響應用戶的分配請求,向操作系統(tǒng)申請內(nèi)存,然后將其返回給用戶程序。
為了保持高效的分配,分配器通常會預先向操作系統(tǒng)申請一塊內(nèi)存,當用戶程序申請和釋放內(nèi)存的時候,分配器會將這些內(nèi)存管理起來,并通過一些算法策略來判斷是否將其返回給操作系統(tǒng)。這樣做的最大好處就是可以避免用戶程序頻繁的調(diào)用系統(tǒng)來進行內(nèi)存分配,使用戶程序在內(nèi)存使用上更加高效快捷。
關(guān)于 ptmalloc 的內(nèi)存分配原理,個人也不是非常了解,這里就不班門弄斧了,有興趣的同學可以去看下華庭的《glibc 內(nèi)存管理 ptmalloc 源代碼分析》【文末鏈接】。
關(guān)于如何選擇這三種內(nèi)存分配器,網(wǎng)上資料大多都是推薦摒棄 glibc 原生的 ptmalloc,而改用 jemalloc 或者 tcmalloc 作為默認分配器。因為 ptmalloc 的主要問題其實是內(nèi)存浪費、內(nèi)存碎片、以及加鎖導致的性能問題,而 jemalloc 與 tcmalloc 對于內(nèi)存碎片、多線程處理優(yōu)化的更好。
目前 jemalloc 應用于 Firefox、FaceBook 等,并且是 MariaDB、Redis、Tengine 默認推薦的內(nèi)存分配器,而 tcmalloc 則應用于 WebKit、Chrome 等。
MySql安裝過程中,沒有修改掉數(shù)據(jù)存儲位置的話,可能會是數(shù)據(jù)存儲到自己并不希望的位置,故需要修改
先利用命令行登錄數(shù)據(jù)庫
mysql -u root -p
查看數(shù)據(jù)庫數(shù)據(jù)存儲位置
show variables like '%datadir%'
去該目錄下找到文件夾中的所有文件(該目錄一般是隱藏的),將其中所有文件拷貝到你希望數(shù)據(jù)文件存儲的位置,
我是想拷貝到D:/MySQl/data目錄下的
打開安裝目錄下的my.ini文件,將datadir="C:/ProgramData/MySQL/MySQL Server 5.5/data/",這行修改為datadir="D\MySQL\data"(這里用又斜線,否則有可能報錯)。
退出所有對mysql.exe的調(diào)用,任務(wù)管理器看一下服務(wù)MySQL有沒有停止,如果沒有,在cmd中命令net stop mysql停止服務(wù)。然后在net start mysql重新啟動服務(wù)
查詢數(shù)據(jù)庫位置,查看是否成功
MySQL作為最常用的數(shù)據(jù)庫,經(jīng)常遇到各種各樣的問題。今天要說的就是表存儲引擎的修改。有三種方式,列表如下。
1.真接修改。在數(shù)據(jù)多的時候比較慢,而且在修改時會影響讀取性能。my_table是操作的表,innoDB是新的存儲引擎。
復制代碼
代碼如下:ALTER
TABLE
my_table
ENGINE=InnoDB
2.導出,導入。這個比較容易操作,直接把導出來的sql文件給改了,然后再導回去。用mysqldump
,楓哥常用的是navicate那樣更容易上手。友情提醒風險較大。
3.創(chuàng)建,插入。這個比第一種速度快,
安全性比第二種高,推薦。分2步操作
a.創(chuàng)建表,先創(chuàng)建一個和要操作表一樣的表,然后更改存儲引擎為目標引擎。
復制代碼
代碼如下:
CREATE
TABLE
my_tmp_table
LIKE
my_table;
ALTER
TABLE
my_tmp_table
ENGINE=InnoDB;
b.插入。為了安全和速度,最好加上事務(wù),并限制id(主鍵)范圍。
復制代碼
代碼如下:
INSERT
INTO
my_tmp_table
SELECT
*
FROM
my_table;
就到這里,希望對需要的同學有幫助。
將datadir = /var/lib/mysql 改成 datadir = /data/mysql/mysql
如果出現(xiàn)如下權(quán)限限制的話,先輸入:set noreadonly 再輸入:wq 保存后退出
將
/var/lib/mysql/ r,
/var/lib/mysql/** rwk,
改成
/data/mysql/mysql/ r,
/data/mysql/mysql/** rwk,
將
/var/lib/mysql{,d}/mysql{,d}.sock rw,
改成
/data/mysql/mysql{,d}/mysql{,d}.sock rw,
驗證修改成功。