MySQL 群集是一種技術(shù),該技術(shù)允許在無共享的系統(tǒng)中部署“內(nèi)存中”和“磁盤中”數(shù)據(jù)庫的 Cluster 。通過無共享體系結(jié)構(gòu),系統(tǒng)能夠使用廉價的硬件,而且對軟硬件無特殊要求。此外,由于每個組件有自己的內(nèi)存和磁盤,不存在單點故障。MySQL Cluster 由一組計算機(jī)構(gòu)成,每臺計算機(jī)上均運(yùn)行著多種進(jìn)程,包括 MySQL 服務(wù)器,NDB Cluster 的數(shù)據(jù)節(jié)點,管理服務(wù)器,以及(可能存在的)專門的數(shù)據(jù)訪問程序。
我們提供的服務(wù)有:網(wǎng)站制作、成都網(wǎng)站建設(shè)、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、撫順ssl等。為上千多家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的撫順網(wǎng)站制作公司
管理服務(wù)器(MGM節(jié)點)負(fù)責(zé)管理 Cluster 配置文件和 Cluster 日志。Cluster 中的每個節(jié)點從管理服務(wù)器檢索配置數(shù)據(jù)。當(dāng)數(shù)據(jù)節(jié)點內(nèi)出現(xiàn)新的事件時,節(jié)點將關(guān)于這類事件的信息傳輸?shù)焦芾矸?wù)器,然后,將這類信息寫入 Cluster 日志。
目前能夠運(yùn)行 MySQL Cluster 的操作系統(tǒng)有 Linux、Mac OS X 和 Solaris,最新的版本已經(jīng)支持 Windows 操作系統(tǒng)。
MySQL 群集的數(shù)據(jù)節(jié)點之間的通信是不加密的,并且需要高速的帶寬,所以建議把群集建立在一個高速局域網(wǎng)內(nèi),不建議跨網(wǎng)段、跨公網(wǎng)的部署這種系統(tǒng)體系。
MySQL 群集分為三種節(jié)點:管理節(jié)點,數(shù)據(jù)節(jié)點和SQL節(jié)點。
管理節(jié)點:主要用于管理各個節(jié)點,能夠通過命令對某個節(jié)點進(jìn)行重啟、關(guān)閉、啟動等操作。也能夠監(jiān)視全部節(jié)點的工作狀態(tài)。
數(shù)據(jù)節(jié)點:主要是對數(shù)據(jù)的存儲,不提供其他的服務(wù)。
SQL節(jié)點:主要是對外提供SQL功能,類似一臺普通的 MySQL Server。
而SQL節(jié)點和數(shù)據(jù)節(jié)點可以是同一臺機(jī)器,也就是說這臺機(jī)器即是SQL節(jié)點也是數(shù)據(jù)節(jié)點。它們只是邏輯關(guān)系上的劃分,實際部署時,甚至所有的階段都可以位于同一臺物理機(jī)器上,只是配置較復(fù)雜些。
一、軟件下載機(jī)器操作環(huán)境
配置 MySQL 群集必需使用其群集版本,注意和 MySQL Server 版本的區(qū)別。本文以 Windows 平臺下的 MySQL 群集版本 MySQL Cluster 7.1.3 為例(截至2010年6月初的最高版本),這是 MySQL Server 5.1 系列版本之一,添加了群集的功能。下載地址為:,選擇 mysql-cluster-gpl-noinstall-7.1.3-win32.zip 文件,這是一個 for Windows 32位版本的、免安裝的二進(jìn)制版本。
根據(jù)自己的操作系統(tǒng)的位數(shù),也可以選擇 64 位版本的。還有一個 27.2M 的 Windows(x86, 32-bit) 版本,下載下來需要自己編譯,有經(jīng)驗的高級用戶可以選用。
本實驗在 2 臺安裝 Windows Server 2003(sp2) 的機(jī)器上進(jìn)行。節(jié)點分配及 IP 配置如下:
第一臺機(jī)器,IP 為 10.0.0.201,作為管理節(jié)點(MGM),SQL節(jié)點1(SQL1),數(shù)據(jù)節(jié)點1(NDBD1)。
第二臺機(jī)器,IP 為 10.0.0.202,作為SQL節(jié)點2(SQL2),數(shù)據(jù)節(jié)點2(NDBD2)。
管理節(jié)點最好不要與數(shù)據(jù)節(jié)點部署在同一臺服務(wù)器上,否則可能會因為該數(shù)據(jù)節(jié)點服務(wù)器的當(dāng)機(jī),而導(dǎo)致管理節(jié)點服務(wù)器的問題,從而導(dǎo)致整個群集系統(tǒng)的崩潰。
二,配置管理節(jié)點:
在第一臺機(jī)器上,建文件夾 D:\mysql-cluster,在其下建立文件 config.ini,內(nèi)容如下:
[NDBD DEFAULT]
NoOfReplicas=1
[MYSQLD DEFAULT]
[NDB_MGMD DEFAULT]
[TCP DEFAULT]
# Managment Server
[NDB_MGMD]
hostname=10.0.0.201
# Storage Engines
[NDBD]
hostname=10.0.0.201
datadir= D:\data
[NDBD]
hostname=10.0.0.202
datadir= D:\data
# SQL Engines
[MYSQLD]
hostname=10.0.0.201
[MYSQLD]
hostname=10.0.0.202
Cluster 管理節(jié)點的默認(rèn)端口是1186,數(shù)據(jù)節(jié)點的默認(rèn)端口是 2202。從 MySQL 5.0.3開始,該限制已被放寬,Cluster 能夠根據(jù)空閑的端口自動地為數(shù)據(jù)節(jié)點分配端口。如果你的版本低于5.0.22,請注意這個細(xì)節(jié)。
Cluster 管理節(jié)點作為一個服務(wù)端(通過運(yùn)行 db_mgmd.exe 程序讀取本配置文件來啟動),通過本機(jī)上的客戶端 ndb_mgm.exe 來連接和操作。
三、配置 MySQL 數(shù)據(jù)庫服務(wù)器:
在2臺機(jī)器上,分別依次操作。
解壓 mysql-cluster-gpl-noinstall-7.1.3-win32.zip 文件到 D:\mysql-cluster-gpl-noinstall-7.1.3-win32 文件夾下,把 D:\mysql-cluster-gpl-noinstall-7.1.3-win32\bin 加到 Windows 的系統(tǒng) path 中。
打開DOS命令行窗口(配置完系統(tǒng)path后,在再次打開新的命令行窗口),執(zhí)行以下語句,讓 MySQL 作為 Windows 服務(wù)運(yùn)行:
mysqld.exe -install mysql
再在 Windows 服務(wù)管理界面里,配置 mysql 服務(wù),手動啟動(不要自動啟動)。
把 D:\mysql-cluster-gpl-noinstall-7.1.3-win32 下的某個備用的配置文件(例如my-small.ini)復(fù)制為 my.ini 文件。
建立 D:\tmp 文件夾。
四、配置SQL節(jié)點和數(shù)據(jù)節(jié)點:
在2臺機(jī)器上,分別依次操作。
建立文件夾 D:\data。
編輯 NySQL 配置文件 D:\mysql-cluster-gpl-noinstall-7.1.3-win32\my.ini,在 [mysqld] 節(jié)末尾加語句:
#SQL群集節(jié)點
ndbcluster
ndb-connectstring=10.0.0.201
有了 ndbcluster 語句,mysql 服務(wù)將作為群集的 SQL 節(jié)點啟動。mysqld.exe 命令帶參數(shù) –ndbcluster 運(yùn)行是一樣的效果。
mysql 服務(wù)連接到數(shù)據(jù)節(jié)點的 2202 默認(rèn)端口,或自動分配的別的可用端口。
(問題:SQL節(jié)點如何獲得數(shù)據(jù)節(jié)點的IP地址?是否通過連接管理節(jié)點,取得所有數(shù)據(jù)節(jié)點的IP地址的列表?)
這里的連接字符串的值在 MySQL 服務(wù)啟動時使用,用于連接到管理節(jié)點。
在末尾加語句:
#NDB集群節(jié)點
[mysql_cluster]
ndb-connectstring=10.0.0.201
注:好像以下形式也可:
[ndbd]
ndb-connectstring=10.0.0.201
這里的連接字符串的值在數(shù)據(jù)節(jié)點啟動時使用,用于連接到管理節(jié)點。
五,啟動群集各服務(wù)器
啟動順序依次是:管理節(jié)點、數(shù)據(jù)節(jié)點、SQL節(jié)點。
1,啟動管理節(jié)點
在第一臺服務(wù)器的DOS窗口,運(yùn)行命令:
C:\ndb_mgmd.exe -f d:\mysql-cluster.conf\config.ini –configdir=d:\mysql-cluster
注:如果不帶 –configdir=d:\mysql-cluster 參數(shù),將默認(rèn)為 C:\mysql\mysql-cluster 文件夾。
屏幕顯示:
C:\ndb_mgmd.exe -f d:\mysql-cluster.conf\config.ini –configdir=d:\mysql-cluster
2010-06-10 01:16:57 [MgmtSrvr] INFO — NDB Cluster Management Server. mysql-5.1.44 ndb-7.1.3
2010-06-10 01:16:57 [MgmtSrvr] INFO — Reading cluster configuration from ‘d:\mysql-cluster.conf\config.ini'
2010-06-10 01:16:57 [MgmtSrvr] INFO — Got initial configuration from ‘d:\mysql-cluster.conf\config.ini', will try to set it when all ndb_mgmd(s) started
2010-06-10 01:16:57 [MgmtSrvr] INFO — Mgmt server state: nodeid 1 reserved for ip 10.0.0.201, m_reserved_nodes 1.
2010-06-10 01:16:57 [MgmtSrvr] INFO — Id: 1, Command port: *:1186
==INITIAL==
2010-06-10 01:16:57 [MgmtSrvr] INFO — Starting initial configuration change
2010-06-10 01:16:57 [MgmtSrvr] INFO — Configuration 1 commited
2010-06-10 01:16:57 [MgmtSrvr] INFO — Config change completed! New generation: 1
==CONFIRMED==
2,啟動數(shù)據(jù)節(jié)點
分別在2臺服務(wù)器的DOS窗口運(yùn)行命令。
第一次,或初始化群集節(jié)點時,運(yùn)行命令:
ndbd.exe –initial
初始化之后,只運(yùn)行 ndbd.exe 即可。若帶參數(shù) –initial 運(yùn)行,將使正常運(yùn)行的群集系統(tǒng)中,數(shù)據(jù)節(jié)點的數(shù)據(jù)全部丟失。
數(shù)據(jù)節(jié)點依賴管理節(jié)點服務(wù)器,進(jìn)行數(shù)據(jù)的自動復(fù)制和同步,使各個數(shù)據(jù)節(jié)點的數(shù)據(jù)保持一致,并在某個數(shù)據(jù)節(jié)點意外關(guān)閉又恢復(fù)后,進(jìn)行數(shù)據(jù)的恢復(fù)重建。
3,啟動SQL節(jié)點
有了 ndbcluster 語句,啟動 mysql 服務(wù),就啟動了SQL節(jié)點。應(yīng)在前2種節(jié)點啟動后,分別在2臺服務(wù)器上進(jìn)行。
六、群集管理
在所有的數(shù)據(jù)節(jié)點和SQL節(jié)點未啟動之前,運(yùn)行群集管理節(jié)點服務(wù)的客戶端 ndb_mgm.exe,只能獲得以下信息:
C:\ndb_mgm.exe
— NDB Cluster — Management Client –
ndb_mgm show
Cluster Configuration
———————
[ndbd(NDB)] 2 node(s)
id=2 (not connected, accepting connect from 10.0.0.201)
id=3 (not connected, accepting connect from 10.0.0.202)
[ndb_mgmd(MGM)] 1 node(s)
id=1 @10.0.0.201 (mysql-5.1.44 ndb-7.1.3)
[mysqld(API)] 2 node(s)
id=4 (not connected, accepting connect from 10.0.0.201)
id=5 (not connected, accepting connect from 10.0.0.202)
ndb_mgm
說明數(shù)據(jù)節(jié)點、SQL節(jié)點均未連接到管理節(jié)點服務(wù)。
在所有的數(shù)據(jù)節(jié)點和SQL節(jié)點正確啟動之后,將獲得以下信息:
ndb_mgm show
Cluster Configuration
———————
[ndbd(NDB)] 2 node(s)
id=2 @10.0.0.201 (mysql-5.1.44 ndb-7.1.3, Nodegroup: 0, Master)
id=3 @10.0.0.202 (mysql-5.1.44 ndb-7.1.3, Nodegroup: 1)
[ndb_mgmd(MGM)] 1 node(s)
id=1 @10.0.0.201 (mysql-5.1.44 ndb-7.1.3)
[mysqld(API)] 2 node(s)
id=4 @10.0.0.201 (mysql-5.1.44 ndb-7.1.3)
id=5 @10.0.0.202 (mysql-5.1.44 ndb-7.1.3)
ndb_mgm
關(guān)閉群集的DOS命令:
ndb_mgm -e shutdown
或在 ndb_mgm 環(huán)境下執(zhí)行 shutdown 命令。
以上命令或關(guān)閉管理節(jié)點服務(wù)和所有的數(shù)據(jù)節(jié)點。隨意、強(qiáng)行關(guān)閉群集系統(tǒng)(關(guān)機(jī)或關(guān)閉進(jìn)程),會導(dǎo)致數(shù)據(jù)沒有全部寫回磁盤而導(dǎo)致的數(shù)據(jù)丟失。
關(guān)閉SQL節(jié)點的 mysqld 服務(wù):
C:\net stop mysql,或:
C:\mysqladmin -u root shutdown
七、測試
正常運(yùn)行的 MySQL 群集系統(tǒng),通過SQL節(jié)點可以對數(shù)據(jù)節(jié)點進(jìn)行數(shù)據(jù)庫操作,各數(shù)據(jù)節(jié)點可以自動進(jìn)行數(shù)據(jù)同步。某一個數(shù)據(jù)節(jié)點關(guān)閉后,不影響SQL節(jié)點的使用。某些數(shù)據(jù)節(jié)點出錯后,可以進(jìn)行恢復(fù)。需要注意的是,SQL節(jié)點建立數(shù)據(jù)庫時,必須選擇“ndbcluster”數(shù)據(jù)庫引擎。如果不選擇“ndbcluster”引擎,建立的數(shù)據(jù)庫將不會進(jìn)入MySQL群集系統(tǒng)中,但是可以獨立使用。
另外,每個 NDB 表必須有一個主鍵。如果在創(chuàng)建表時未定義主鍵,NDB Cluster 存儲引擎將自動生成隱含的主鍵。該隱含的鍵也將占用空間,就像任何其他的表索引一樣。由于沒有足夠的內(nèi)存來容納這些自動創(chuàng)建的鍵,出現(xiàn)問題并不罕見。
首先是我們將鼠標(biāo)移動到如下圖所示的計算機(jī)的圖標(biāo)上,點擊右鍵,選擇管理。
請點擊輸入圖片描述
請點擊輸入圖片描述
然后我們點擊如下圖界面中的服務(wù)和應(yīng)用程序。
請點擊輸入圖片描述
請點擊輸入圖片描述
接下來可以看到它下面有一個我們的目標(biāo)——服務(wù)。
請點擊輸入圖片描述
請點擊輸入圖片描述
服務(wù)的話它是按字母排列的,我們往下拉,找到Mysql服務(wù)。此時可以看到它是一個手動啟動的狀態(tài)。
請點擊輸入圖片描述
請點擊輸入圖片描述
在mysql服務(wù)上點擊鼠標(biāo)右鍵,選擇屬性。
請點擊輸入圖片描述
請點擊輸入圖片描述
然后跳出的如下圖的界面中我們將手動改成自動,點擊確定,這樣你的mysql服備就是一個自啟動的狀態(tài)。
請點擊輸入圖片描述
請點擊輸入圖片描述
到官網(wǎng)下載mysql-5.5.10-win32.zip,然后將mysql解壓到任意路徑,如:C:\mysql-5.5.10-win32
打開計算機(jī)-屬性-高級系統(tǒng)設(shè)置-環(huán)境變量,新建一個環(huán)境變量,變量名為:MYSQL_HOME,變量值為你的mysql根目錄,如:C:\mysql-5.5.10-win32
然后在系統(tǒng)變量Path中添加:;%MYSQL_HOME%\bin
在根目錄下面有幾個已經(jīng)寫好的"my-"開頭的ini文件,選一個適合你的,如:my-small.ini。復(fù)制一份,將文件名修改為my.ini,添加以下內(nèi)容:
Properties代碼
[mysqld]
#設(shè)置字符集為utf8
default-character-set = utf8
basedir = C:/mysql-5.5.10-win32
datadir = C:/mysql-5.5.10-win32/data
[client]
#設(shè)置客戶端字符集
default-character-set = utf8
[WinMySQLadmin]
Server = C:/mysql-5.5.10-win32/bin/mysqld.exe
打開命令提示符,進(jìn)入%MYSQL_HOME%/bin目錄,執(zhí)行命令:mysqld -install將mysql安裝到windows的服務(wù)。執(zhí)行成功后會提示:C:\mysql-5.5.10-win32\binService successfully installed.
如果想要卸載服務(wù)執(zhí)行命令:mysqld -remove。
然后在命令提示符下執(zhí)行:net start mysql就能啟動mysql了,停止服務(wù)輸入命令:net stop mysql。如果想設(shè)置mysql是否自動啟動,可以在開始菜單-運(yùn)行中輸入service.msc打開服務(wù)管理進(jìn)行設(shè)置。
第一次登錄的時候輸入:
C:\Users\Administratormysql -u root
修改密碼:
mysql update mysql.user set password=PASSWORD('root') where User='root'
mysql flush privileges
不過我在安裝過程中還是出了點小問題,啟動mysql的時候報錯:
系統(tǒng)出錯。
發(fā)生系統(tǒng)錯誤 1067。
進(jìn)程意外終止。
打開%MYSQL_HOME%/data目錄下的用戶名.err文件,mysql的錯誤日志就記錄在這個文件中。在里面發(fā)現(xiàn)這樣一句話:
110327 0:12:02 [ERROR] MySQL: unknown variable 'default-character-set=utf8'
感覺很奇怪,以前一直都這樣安裝的。最后在mysql的官網(wǎng)上找到一篇中國DBA的求助信息,原來這是新版本的一個bug,不支持在my.ini中直接設(shè)置字符集為utf8。解決辦法是:在default-character-set=utf8前面加上loose-即:
Properties代碼
[mysqld]
#設(shè)置字符集為utf8
loose-default-character-set = utf8
[client]
#設(shè)置客戶端字符集
loose-default-character-set = utf8
啟動果然不再報錯了。。。那份求助信息的原文地址:
后記:
雖然使用上面的方式加入loose-以后,mysql啟動不再報錯了。但是在插入數(shù)據(jù)時依然出現(xiàn)了亂碼問題,給我造成了不小的麻煩。
mysql show variables like '%char%';
通過以上命令查看字符集編碼,得到如下結(jié)果:
+--------------------------+---------------------------------------+
| Variable_name | Value |
+--------------------------+---------------------------------------+
| character_set_client | utf8 |
| character_set_connection | utf8 |
| character_set_database | latin1 |
| character_set_filesystem | binary |
| character_set_results | utf8 |
| character_set_server | latin1 |
| character_set_system | utf8 |
| character_sets_dir | C:\mysql-5.5.10-win32\share\charsets\ |
+--------------------------+---------------------------------------+
可以看出character_set_database ,character_set_server 的編碼還是默認(rèn)的latin1。
在[mysqld]配置選項下添加character-set-server = utf8,重啟服務(wù)進(jìn)入mysql再次查看:
+--------------------------+---------------------------------------+
| Variable_name | Value |
+--------------------------+---------------------------------------+
| character_set_client | utf8 |
| character_set_connection | utf8 |
| character_set_database | utf8 |
| character_set_filesystem | binary |
| character_set_results | utf8 |
| character_set_server | utf8 |
| character_set_system | utf8 |
| character_sets_dir | C:\mysql-5.5.10-win32\share\charsets\ |
+--------------------------+---------------------------------------+
問題完美解決
[client]\x0d\x0aport = 3306\x0d\x0asocket = /tmp/mysql.sock\x0d\x0a[mysqld]\x0d\x0aport = 3306\x0d\x0asocket = /tmp/mysql.sock\x0d\x0a\x0d\x0abasedir = /usr/local/mysql\x0d\x0adatadir = /data/mysql\x0d\x0apid-file = /data/mysql/mysql.pid\x0d\x0auser = mysql\x0d\x0abind-address = 0.0.0.0\x0d\x0aserver-id = 1 #表示是本機(jī)的序號為1,一般來講就是master的意思\x0d\x0a\x0d\x0askip-name-resolve\x0d\x0a# 禁止MySQL對外部連接進(jìn)行DNS解析,使用這一選項可以消除MySQL進(jìn)行DNS解析的時間。但需要注意,如果開啟該選項,\x0d\x0a# 則所有遠(yuǎn)程主機(jī)連接授權(quán)都要使用IP地址方式,否則MySQL將無法正常處理連接請求\x0d\x0a\x0d\x0a#skip-networking\x0d\x0a\x0d\x0aback_log = 600\x0d\x0a# MySQL能有的連接數(shù)量。當(dāng)主要MySQL線程在一個很短時間內(nèi)得到非常多的連接請求,這就起作用,\x0d\x0a# 然后主線程花些時間(盡管很短)檢查連接并且啟動一個新線程。back_log值指出在MySQL暫時停止回答新請求之前的短時間內(nèi)多少個請求可以被存在堆棧中。\x0d\x0a# 如果期望在一個短時間內(nèi)有很多連接,你需要增加它。也就是說,如果MySQL的連接數(shù)據(jù)達(dá)到max_connections時,新來的請求將會被存在堆棧中,\x0d\x0a# 以等待某一連接釋放資源,該堆棧的數(shù)量即back_log,如果等待連接的數(shù)量超過back_log,將不被授予連接資源。\x0d\x0a# 另外,這值(back_log)限于您的操作系統(tǒng)對到來的TCP/IP連接的偵聽隊列的大小。\x0d\x0a# 你的操作系統(tǒng)在這個隊列大小上有它自己的限制(可以檢查你的OS文檔找出這個變量的最大值),試圖設(shè)定back_log高于你的操作系統(tǒng)的限制將是無效的。\x0d\x0a\x0d\x0amax_connections = 1000\x0d\x0a# \x0d\x0aMySQL的最大連接數(shù),如果服務(wù)器的并發(fā)連接請求量比較大,建議調(diào)高此值,以增加并行連接數(shù)量,當(dāng)然這建立在機(jī)器能支撐的情況下,因為如果連接數(shù)越多,\x0d\x0a介于MySQL會為每個連接提供連接緩沖區(qū),就會開銷越多的內(nèi)存,所以要適當(dāng)調(diào)整該值,不能盲目提高設(shè)值??梢赃^'conn%'通配符查看當(dāng)前狀態(tài)的連接\x0d\x0a數(shù)量,以定奪該值的大小。\x0d\x0a\x0d\x0amax_connect_errors = 6000\x0d\x0a# 對于同一主機(jī),如果有超出該參數(shù)值個數(shù)的中斷錯誤連接,則該主機(jī)將被禁止連接。如需對該主機(jī)進(jìn)行解禁,執(zhí)行:FLUSH HOST。\x0d\x0a\x0d\x0aopen_files_limit = 65535\x0d\x0a# MySQL打開的文件描述符限制,默認(rèn)最小1024;當(dāng)open_files_limit沒有被配置的時候,比較max_connections*5和ulimit -n的值,哪個大用哪個,\x0d\x0a# 當(dāng)open_file_limit被配置的時候,比較open_files_limit和max_connections*5的值,哪個大用哪個。\x0d\x0a\x0d\x0atable_open_cache = 128\x0d\x0a# MySQL每打開一個表,都會讀入一些數(shù)據(jù)到table_open_cache緩存中,當(dāng)MySQL在這個緩存中找不到相應(yīng)信息時,才會去磁盤上讀取。默認(rèn)值64\x0d\x0a# 假定系統(tǒng)有200個并發(fā)連接,則需將此參數(shù)設(shè)置為200*N(N為每個連接所需的文件描述符數(shù)目);\x0d\x0a# 當(dāng)把table_open_cache設(shè)置為很大時,如果系統(tǒng)處理不了那么多文件描述符,那么就會出現(xiàn)客戶端失效,連接不上\x0d\x0a\x0d\x0amax_allowed_packet = 4M\x0d\x0a# 接受的數(shù)據(jù)包大小;增加該變量的值十分安全,這是因為僅當(dāng)需要時才會分配額外內(nèi)存。例如,僅當(dāng)你發(fā)出長查詢或MySQLd必須返回大的結(jié)果行時MySQLd才會分配更多內(nèi)存。\x0d\x0a# 該變量之所以取較小默認(rèn)值是一種預(yù)防措施,以捕獲客戶端和服務(wù)器之間的錯誤信息包,并確保不會因偶然使用大的信息包而導(dǎo)致內(nèi)存溢出。\x0d\x0a\x0d\x0abinlog_cache_size = 1M\x0d\x0a# 一個事務(wù),在沒有提交的時候,產(chǎn)生的日志,記錄到Cache中;等到事務(wù)提交需要提交的時候,則把日志持久化到磁盤。默認(rèn)binlog_cache_size大小32K\x0d\x0a\x0d\x0amax_heap_table_size = 8M\x0d\x0a# 定義了用戶可以創(chuàng)建的內(nèi)存表(memory table)的大小。這個值用來計算內(nèi)存表的最大行數(shù)值。這個變量支持動態(tài)改變\x0d\x0a\x0d\x0atmp_table_size = 16M\x0d\x0a# MySQL的heap(堆積)表緩沖大小。所有聯(lián)合在一個DML指令內(nèi)完成,并且大多數(shù)聯(lián)合甚至可以不用臨時表即可以完成。\x0d\x0a# 大多數(shù)臨時表是基于內(nèi)存的(HEAP)表。具有大的記錄長度的臨時表 (所有列的長度的和)或包含BLOB列的表存儲在硬盤上。\x0d\x0a#\x0d\x0a \x0d\x0a如果某個內(nèi)部heap(堆積)表大小超過tmp_table_size,MySQL可以根據(jù)需要自動將內(nèi)存中的heap表改為基于硬盤的MyISAM表。\x0d\x0a還可以通過設(shè)置tmp_table_size選項來增加臨時表的大小。也就是說,如果調(diào)高該值,MySQL同時將增加heap表的大小,可達(dá)到提高聯(lián)接查\x0d\x0a詢速度的效果\x0d\x0a\x0d\x0aread_buffer_size = 2M\x0d\x0a# MySQL讀入緩沖區(qū)大小。對表進(jìn)行順序掃描的請求將分配一個讀入緩沖區(qū),MySQL會為它分配一段內(nèi)存緩沖區(qū)。read_buffer_size變量控制這一緩沖區(qū)的大小。\x0d\x0a# 如果對表的順序掃描請求非常頻繁,并且你認(rèn)為頻繁掃描進(jìn)行得太慢,可以通過增加該變量值以及內(nèi)存緩沖區(qū)大小提高其性能\x0d\x0a\x0d\x0aread_rnd_buffer_size = 8M\x0d\x0a# MySQL的隨機(jī)讀緩沖區(qū)大小。當(dāng)按任意順序讀取行時(例如,按照排序順序),將分配一個隨機(jī)讀緩存區(qū)。進(jìn)行排序查詢時,\x0d\x0a# MySQL會首先掃描一遍該緩沖,以避免磁盤搜索,提高查詢速度,如果需要排序大量數(shù)據(jù),可適當(dāng)調(diào)高該值。但MySQL會為每個客戶連接發(fā)放該緩沖空間,所以應(yīng)盡量適當(dāng)設(shè)置該值,以避免內(nèi)存開銷過大\x0d\x0a\x0d\x0asort_buffer_size = 8M\x0d\x0a# MySQL執(zhí)行排序使用的緩沖大小。如果想要增加ORDER BY的速度,首先看是否可以讓MySQL使用索引而不是額外的排序階段。\x0d\x0a# 如果不能,可以嘗試增加sort_buffer_size變量的大小\x0d\x0a\x0d\x0ajoin_buffer_size = 8M\x0d\x0a# 聯(lián)合查詢操作所能使用的緩沖區(qū)大小,和sort_buffer_size一樣,該參數(shù)對應(yīng)的分配內(nèi)存也是每連接獨享\x0d\x0a\x0d\x0athread_cache_size = 8\x0d\x0a# 這個值(默認(rèn)8)表示可以重新利用保存在緩存中線程的數(shù)量,當(dāng)斷開連接時如果緩存中還有空間,那么客戶端的線程將被放到緩存中,\x0d\x0a# 如果線程重新被請求,那么請求將從緩存中讀取,如果緩存中是空的或者是新的請求,那么這個線程將被重新創(chuàng)建,如果有很多新的線程,\x0d\x0a# 增加這個值可以改善系統(tǒng)性能.通過比較Connections和Threads_created狀態(tài)的變量,可以看到這個變量的作用。(_表示要調(diào)整的值)\x0d\x0a# 根據(jù)物理內(nèi)存設(shè)置規(guī)則如下:\x0d\x0a# 1G — 8\x0d\x0a# 2G — 16\x0d\x0a# 3G — 32\x0d\x0a# 大于3G — 64\x0d\x0a\x0d\x0aquery_cache_size = 8M\x0d\x0a#MySQL的查詢緩沖大小(從4.0.1開始,MySQL提供了查詢緩沖機(jī)制)使用查詢緩沖,MySQL將SELECT語句和查詢結(jié)果存放在緩沖區(qū)中,\x0d\x0a# 今后對于同樣的SELECT語句(區(qū)分大小寫),將直接從緩沖區(qū)中讀取結(jié)果。根據(jù)MySQL用戶手冊,使用查詢緩沖最多可以達(dá)到238%的效率。\x0d\x0a# 通過檢查狀態(tài)值'Qcache_%',可以知道query_cache_size設(shè)置是否合理:如果Qcache_lowmem_prunes的值非常大,則表明經(jīng)常出現(xiàn)緩沖不夠的情況,\x0d\x0a# 如果Qcache_hits的值也非常大,則表明查詢緩沖使用非常頻繁,此時需要增加緩沖大??;如果Qcache_hits的值不大,則表明你的查詢重復(fù)率很低,\x0d\x0a# 這種情況下使用查詢緩沖反而會影響效率,那么可以考慮不用查詢緩沖。此外,在SELECT語句中加入SQL_NO_CACHE可以明確表示不使用查詢緩沖\x0d\x0a\x0d\x0aquery_cache_limit = 2M\x0d\x0a#指定單個查詢能夠使用的緩沖區(qū)大小,默認(rèn)1M\x0d\x0a\x0d\x0akey_buffer_size = 4M\x0d\x0a#指定用于索引的緩沖區(qū)大小,增加它可得到更好處理的索引(對所有讀和多重寫),到你能負(fù)擔(dān)得起那樣多。如果你使它太大,\x0d\x0a# 系統(tǒng)將開始換頁并且真的變慢了。對于內(nèi)存在4GB左右的服務(wù)器該參數(shù)可設(shè)置為384M或512M。通過檢查狀態(tài)值Key_read_requests和Key_reads,\x0d\x0a# 可以知道key_buffer_size設(shè)置是否合理。比例key_reads/key_read_requests應(yīng)該盡可能的低,\x0d\x0a# 至少是1:100,1:1000更好(上述狀態(tài)值可以使用SHOW STATUS LIKE 'key_read%'獲得)。注意:該參數(shù)值設(shè)置的過大反而會是服務(wù)器整體效率降低\x0d\x0a\x0d\x0aft_min_word_len = 4\x0d\x0a# 分詞詞匯最小長度,默認(rèn)4\x0d\x0a\x0d\x0atransaction_isolation = REPEATABLE-READ\x0d\x0a# MySQL支持4種事務(wù)隔離級別,他們分別是:\x0d\x0a# READ-UNCOMMITTED, READ-COMMITTED, REPEATABLE-READ, SERIALIZABLE.\x0d\x0a# 如沒有指定,MySQL默認(rèn)采用的是REPEATABLE-READ,ORACLE默認(rèn)的是READ-COMMITTED\x0d\x0a\x0d\x0alog_bin = mysql-bin\x0d\x0abinlog_format = mixed\x0d\x0aexpire_logs_days = 30 #超過30天的binlog刪除\x0d\x0a\x0d\x0alog_error = /data/mysql/mysql-error.log #錯誤日志路徑\x0d\x0aslow_query_log = 1\x0d\x0along_query_time = 1 #慢查詢時間 超過1秒則為慢查詢\x0d\x0aslow_query_log_file = /data/mysql/mysql-slow.log\x0d\x0a\x0d\x0aperformance_schema = 0\x0d\x0aexplicit_defaults_for_timestamp\x0d\x0a\x0d\x0a#lower_case_table_names = 1 #不區(qū)分大小寫\x0d\x0a\x0d\x0askip-external-locking #MySQL選項以避免外部鎖定。該選項默認(rèn)開啟\x0d\x0a\x0d\x0adefault-storage-engine = InnoDB #默認(rèn)存儲引擎\x0d\x0a\x0d\x0ainnodb_file_per_table = 1\x0d\x0a# InnoDB為獨立表空間模式,每個數(shù)據(jù)庫的每個表都會生成一個數(shù)據(jù)空間\x0d\x0a# 獨立表空間優(yōu)點:\x0d\x0a# 1.每個表都有自已獨立的表空間。\x0d\x0a# 2.每個表的數(shù)據(jù)和索引都會存在自已的表空間中。\x0d\x0a# 3.可以實現(xiàn)單表在不同的數(shù)據(jù)庫中移動。\x0d\x0a# 4.空間可以回收(除drop table操作處,表空不能自已回收)\x0d\x0a# 缺點:\x0d\x0a# 單表增加過大,如超過100G\x0d\x0a# 結(jié)論:\x0d\x0a# 共享表空間在Insert操作上少有優(yōu)勢。其它都沒獨立表空間表現(xiàn)好。當(dāng)啟用獨立表空間時,請合理調(diào)整:innodb_open_files\x0d\x0a\x0d\x0ainnodb_open_files = 500\x0d\x0a# 限制Innodb能打開的表的數(shù)據(jù),如果庫里的表特別多的情況,請增加這個。這個值默認(rèn)是300\x0d\x0a\x0d\x0ainnodb_buffer_pool_size = 64M\x0d\x0a# InnoDB使用一個緩沖池來保存索引和原始數(shù)據(jù), 不像MyISAM.\x0d\x0a# 這里你設(shè)置越大,你在存取表里面數(shù)據(jù)時所需要的磁盤I/O越少.\x0d\x0a# 在一個獨立使用的數(shù)據(jù)庫服務(wù)器上,你可以設(shè)置這個變量到服務(wù)器物理內(nèi)存大小的80%\x0d\x0a# 不要設(shè)置過大,否則,由于物理內(nèi)存的競爭可能導(dǎo)致操作系統(tǒng)的換頁顛簸.\x0d\x0a# 注意在32位系統(tǒng)上你每個進(jìn)程可能被限制在 2-3.5G 用戶層面內(nèi)存限制,\x0d\x0a# 所以不要設(shè)置的太高.\x0d\x0a\x0d\x0ainnodb_write_io_threads = 4\x0d\x0ainnodb_read_io_threads = 4\x0d\x0a# innodb使用后臺線程處理數(shù)據(jù)頁上的讀寫 I/O(輸入輸出)請求,根據(jù)你的 CPU 核數(shù)來更改,默認(rèn)是4\x0d\x0a# 注:這兩個參數(shù)不支持動態(tài)改變,需要把該參數(shù)加入到my.cnf里,修改完后重啟MySQL服務(wù),允許值的范圍從 1-64\x0d\x0a\x0d\x0ainnodb_thread_concurrency = 0\x0d\x0a# 默認(rèn)設(shè)置為 0,表示不限制并發(fā)數(shù),這里推薦設(shè)置為0,更好去發(fā)揮CPU多核處理能力,提高并發(fā)量\x0d\x0a\x0d\x0ainnodb_purge_threads = 1\x0d\x0a# InnoDB中的清除操作是一類定期回收無用數(shù)據(jù)的操作。在之前的幾個版本中,清除操作是主線程的一部分,這意味著運(yùn)行時它可能會堵塞其它的數(shù)據(jù)庫操作。\x0d\x0a# 從MySQL5.5.X版本開始,該操作運(yùn)行于獨立的線程中,并支持更多的并發(fā)數(shù)。用戶可通過設(shè)置innodb_purge_threads配置參數(shù)來選擇清除操作是否使用單\x0d\x0a# 獨線程,默認(rèn)情況下參數(shù)設(shè)置為0(不使用單獨線程),設(shè)置為 1 時表示使用單獨的清除線程。建議為1\x0d\x0a\x0d\x0ainnodb_flush_log_at_trx_commit = 2\x0d\x0a# 0:如果innodb_flush_log_at_trx_commit的值為0,log buffer每秒就會被刷寫日志文件到磁盤,提交事務(wù)的時候不做任何操作(執(zhí)行是由mysql的master thread線程來執(zhí)行的。\x0d\x0a# 主線程中每秒會將重做日志緩沖寫入磁盤的重做日志文件(REDO LOG)中。不論事務(wù)是否已經(jīng)提交)默認(rèn)的日志文件是ib_logfile0,ib_logfile1\x0d\x0a# 1:當(dāng)設(shè)為默認(rèn)值1的時候,每次提交事務(wù)的時候,都會將log buffer刷寫到日志。\x0d\x0a# 2:如果設(shè)為2,每次提交事務(wù)都會寫日志,但并不會執(zhí)行刷的操作。每秒定時會刷到日志文件。要注意的是,并不能保證100%每秒一定都會刷到磁盤,這要取決于進(jìn)程的調(diào)度。\x0d\x0a# 每次事務(wù)提交的時候?qū)?shù)據(jù)寫入事務(wù)日志,而這里的寫入僅是調(diào)用了文件系統(tǒng)的寫入操作,而文件系統(tǒng)是有 緩存的,所以這個寫入并不能保證數(shù)據(jù)已經(jīng)寫入到物理磁盤\x0d\x0a# 默認(rèn)值1是為了保證完整的ACID。當(dāng)然,你可以將這個配置項設(shè)為1以外的值來換取更高的性能,但是在系統(tǒng)崩潰的時候,你將會丟失1秒的數(shù)據(jù)。\x0d\x0a# 設(shè)為0的話,mysqld進(jìn)程崩潰的時候,就會丟失最后1秒的事務(wù)。設(shè)為2,只有在操作系統(tǒng)崩潰或者斷電的時候才會丟失最后1秒的數(shù)據(jù)。InnoDB在做恢復(fù)的時候會忽略這個值。\x0d\x0a# 總結(jié)\x0d\x0a# 設(shè)為1當(dāng)然是最安全的,但性能頁是最差的(相對其他兩個參數(shù)而言,但不是不能接受)。如果對數(shù)據(jù)一致性和完整性要求不高,完全可以設(shè)為2,如果只最求性能,例如高并發(fā)寫的日志服務(wù)器,設(shè)為0來獲得更高性能\x0d\x0a\x0d\x0ainnodb_log_buffer_size = 2M\x0d\x0a# 此參數(shù)確定些日志文件所用的內(nèi)存大小,以M為單位。緩沖區(qū)更大能提高性能,但意外的故障將會丟失數(shù)據(jù)。MySQL開發(fā)人員建議設(shè)置為1-8M之間\x0d\x0a\x0d\x0ainnodb_log_file_size = 32M\x0d\x0a# 此參數(shù)確定數(shù)據(jù)日志文件的大小,更大的設(shè)置可以提高性能,但也會增加恢復(fù)故障數(shù)據(jù)庫所需的時間\x0d\x0a\x0d\x0ainnodb_log_files_in_group = 3\x0d\x0a# 為提高性能,MySQL可以以循環(huán)方式將日志文件寫到多個文件。推薦設(shè)置為3\x0d\x0a\x0d\x0ainnodb_max_dirty_pages_pct = 90\x0d\x0a# innodb主線程刷新緩存池中的數(shù)據(jù),使臟數(shù)據(jù)比例小于90%\x0d\x0a\x0d\x0ainnodb_lock_wait_timeout = 120 \x0d\x0a# InnoDB事務(wù)在被回滾之前可以等待一個鎖定的超時秒數(shù)。InnoDB在它自己的鎖定表中自動檢測事務(wù)死鎖并且回滾事務(wù)。InnoDB用LOCK TABLES語句注意到鎖定設(shè)置。默認(rèn)值是50秒\x0d\x0a\x0d\x0abulk_insert_buffer_size = 8M\x0d\x0a# 批量插入緩存大小, 這個參數(shù)是針對MyISAM存儲引擎來說的。適用于在一次性插入100-1000+條記錄時, 提高效率。默認(rèn)值是8M??梢葬槍?shù)據(jù)量的大小,翻倍增加。\x0d\x0a\x0d\x0amyisam_sort_buffer_size = 8M\x0d\x0a# MyISAM設(shè)置恢復(fù)表之時使用的緩沖區(qū)的尺寸,當(dāng)在REPAIR TABLE或用CREATE INDEX創(chuàng)建索引或ALTER TABLE過程中排序 MyISAM索引分配的緩沖區(qū)\x0d\x0a\x0d\x0amyisam_max_sort_file_size = 10G\x0d\x0a# 如果臨時文件會變得超過索引,不要使用快速排序索引方法來創(chuàng)建一個索引。注釋:這個參數(shù)以字節(jié)的形式給出\x0d\x0a\x0d\x0amyisam_repair_threads = 1\x0d\x0a# 如果該值大于1,在Repair by sorting過程中并行創(chuàng)建MyISAM表索引(每個索引在自己的線程內(nèi)) \x0d\x0a\x0d\x0ainteractive_timeout = 28800\x0d\x0a# 服務(wù)器關(guān)閉交互式連接前等待活動的秒數(shù)。交互式客戶端定義為在mysql_real_connect()中使用CLIENT_INTERACTIVE選項的客戶端。默認(rèn)值:28800秒(8小時)\x0d\x0a\x0d\x0await_timeout = 28800\x0d\x0a# 服務(wù)器關(guān)閉非交互連接之前等待活動的秒數(shù)。在線程啟動時,根據(jù)全局wait_timeout值或全局interactive_timeout值初始化會話wait_timeout值,\x0d\x0a# 取決于客戶端類型(由mysql_real_connect()的連接選項CLIENT_INTERACTIVE定義)。參數(shù)默認(rèn)值:28800秒(8小時)\x0d\x0a# MySQL服務(wù)器所支持的最大連接數(shù)是有上限的,因為每個連接的建立都會消耗內(nèi)存,因此我們希望客戶端在連接到MySQL Server處理完相應(yīng)的操作后,\x0d\x0a# 應(yīng)該斷開連接并釋放占用的內(nèi)存。如果你的MySQL Server有大量的閑置連接,他們不僅會白白消耗內(nèi)存,而且如果連接一直在累加而不斷開,\x0d\x0a# 最終肯定會達(dá)到MySQL Server的連接上限數(shù),這會報'too many connections'的錯誤。對于wait_timeout的值設(shè)定,應(yīng)該根據(jù)系統(tǒng)的運(yùn)行情況來判斷。\x0d\x0a# 在系統(tǒng)運(yùn)行一段時間后,可以通過show processlist命令查看當(dāng)前系統(tǒng)的連接狀態(tài),如果發(fā)現(xiàn)有大量的sleep狀態(tài)的連接進(jìn)程,則說明該參數(shù)設(shè)置的過大,\x0d\x0a# 可以進(jìn)行適當(dāng)?shù)恼{(diào)整小些。要同時設(shè)置interactive_timeout和wait_timeout才會生效。\x0d\x0a\x0d\x0a[mysqldump]\x0d\x0aquick\x0d\x0amax_allowed_packet = 16M #服務(wù)器發(fā)送和接受的最大包長度\x0d\x0a[myisamchk]\x0d\x0akey_buffer_size = 8M\x0d\x0asort_buffer_size = 8M\x0d\x0aread_buffer = 4M\x0d\x0awrite_buffer = 4M
MySQL默認(rèn)的數(shù)據(jù)文件存儲目錄為/var/lib/mysql。假如要把MySQL目錄移到/home/data下需要進(jìn)行下面幾步:\x0d\x0a1、home目錄下建立data目錄\x0d\x0acd /home\x0d\x0amkdir data\x0d\x0a2、把MySQL服務(wù)進(jìn)程停掉\x0d\x0amysqladmin -u root -p shutdown\x0d\x0a3、把/var/lib/mysql整個目錄移到/home/data\x0d\x0amv /var/lib/mysql /home/data/\x0d\x0a這樣就把MySQL的數(shù)據(jù)文件移動到了/home/data/mysql下。\x0d\x0a4、找到my.cnf配置文件\x0d\x0a如果/etc/目錄下沒有my.cnf配置文件,請到/usr/share/mysql/下找到*.cnf文件,拷貝其中一個到/etc/并改名為my.cnf)中。命令如下:\x0d\x0a\x0d\x0a[root@test1 mysql]# cp /usr/share/mysql/my-medium.cnf /etc/my.cnf\x0d\x0a\x0d\x0a5、編輯MySQL的配置文件/etc/my.cnf\x0d\x0a為保證MySQL能夠正常工作,需要指明mysql.sock文件的產(chǎn)生位置。修改socket=/var/lib/mysql/mysql.sock一行中等號右邊的值為:/home/mysql/mysql.sock。操作如下:\x0d\x0a\x0d\x0avi my.cnf (用vi工具編輯my.cnf文件,找到下列數(shù)據(jù)修改之)\x0d\x0a# The MySQL server\x0d\x0a[mysqld]\x0d\x0aport = 3306\x0d\x0a#socket = /var/lib/mysql/mysql.sock(原內(nèi)容,為了更穩(wěn)妥用“#”注釋此行)\x0d\x0asocket = /home/data/mysql/mysql.sock (加上此行) \x0d\x0a\x0d\x0a6、修改MySQL啟動腳本/etc/init.d/mysql\x0d\x0a最后,需要修改MySQL啟動腳本/etc/init.d/mysql,把其中datadir=/var/lib/mysql一行中,等號右邊的路徑改成你現(xiàn)在的實際存放路徑:home/data/mysql。\x0d\x0a\x0d\x0a[root@test1 etc]# vi /etc/init.d/mysql\x0d\x0a#datadir=/var/lib/mysql(注釋此行)\x0d\x0adatadir=/home/data/mysql (加上此行) \x0d\x0a\x0d\x0a7、重新啟動MySQL服務(wù)\x0d\x0a\x0d\x0a/etc/init.d/mysql start\x0d\x0a\x0d\x0a或用reboot命令重啟Linux\x0d\x0a如果工作正常移動就成功了,否則對照前面的7步再檢查一下。\x0d\x0a還要注意目錄的屬主和權(quán)限。
import_table(importTable) 的延申功能:可定制化行輸入。
import_table(importTable) 我們之前有介紹過,是一款并行導(dǎo)入各種格式文本的工具,封裝了 MySQL 語句?load data local infile。
比如說要導(dǎo)入一個以 TAB 為分隔符的文本數(shù)據(jù)文件:/tmp/sample_ytt.txt?到表:ytt_new.t1,可以執(zhí)行下面語句:
上面結(jié)果是?load data infile?語句的導(dǎo)入結(jié)果。如果改用 import_table 方法來做同樣的事情,基于 Python 語法,使用方法如下:
那接下來看另外一個需求:在導(dǎo)入文本文件時對每行做預(yù)處理(例如在導(dǎo)入數(shù)據(jù)之前更改列 r2 的值為 mod(r1,10),列 r5 的值為 abs(r4-46) ),這樣可以減少導(dǎo)入后再次處理的時間開銷。
這個需求用?load data infile?語句非常容易實現(xiàn):(導(dǎo)入時更改列 r2 和 r5 的數(shù)據(jù),類似 UPDATE 語法)
那如果要用 util.import_table(importTable) 來實現(xiàn)上面的需求,在 MySQL 8.0.22 之前是沒辦法的。
隨著 MySQL 8.0.22 的發(fā)布,MySQL 對 import_table 方法做了些擴(kuò)充功能,其中增加了一個選項 “decodeColumns” 可以實現(xiàn)字段的預(yù)先輸入定制化功能,并且還可以更加豐富。
接下來用 import_table 來實現(xiàn)上面的需求,定制化字段 r2 和 r5:
以上 Options 選項,見下圖:
我來具體解釋下上圖的含義:藍(lán)色字體 columns 對應(yīng)的數(shù)組分別指定數(shù)據(jù)文件中的每行字段,也就是默認(rèn)的 TAB 分隔符所分割的每列值,1 和 2 代表占位符,1 代表數(shù)據(jù)文件中每行的第一個列,2 代表數(shù)據(jù)文件中每行的第四列,decodeColumns 字典分別對需要預(yù)先輸入的字段做處理。比如 r1 字段保留為變量 @1,r2 字段對應(yīng) mod(r1,10) 等。
如果還是不太理解變換規(guī)則,可以臨時打開 general log, 上面 import_table(importTable)對應(yīng)的 MySQL 日志為:
以上日志寫的很清楚,內(nèi)部轉(zhuǎn)換為最基本的load data infile語法。
那這里我簡單解讀了下 MySQL 8.0.22 對 MySQL Shell 的一項定制化輸入文本文件的新特性,更多的新特性可以繼續(xù)關(guān)注。