版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、<p> 《MySQL數(shù)據(jù)庫管理》課程設(shè)計報告</p><p> 題目:MySQL集群的研究與實現(xiàn)</p><p> 完成日期: 2012 年 12 月 31 日</p><p><b> 目 錄</b></p><p> 1. 課程設(shè)計題目概述3</p><p> 2
2、. 研究內(nèi)容與目的3</p><p><b> 3. 研究方法4</b></p><p> 3.1研究方法……………………………………………………………………….. 4</p><p> 3.2實驗方法………………………………………………………………………… 5</p><p> 3.3可行性分析..…………
3、………………………………………………………………..... 5</p><p> 4. 研究報告10</p><p> 4.1規(guī)劃階段………………………………………………………………………… 10</p><p> 4.2安裝Mysql server……………………………………………………………… 10</p><p> 4.3安
4、裝Mysql Cluster……………………………………………………………. 11</p><p> 4.4配置管理節(jié)點…………………………………………………………………… 11</p><p> 4.5配置SQL節(jié)點…………………………………………………………………….13</p><p> 4.6 配置存儲節(jié)點……………………………………………………………
5、………13</p><p> 4.7啟動MySQL Cluster…………………………………………………………….13 </p><p> 4.8關(guān)閉MySQL Cluster……………………………………………………………..14</p><p> 4.9數(shù)據(jù)測試………………………………………………………………………… 14</p><p&
6、gt; 4.10安全關(guān)閉………………………………………………………………………. 14</p><p> 5. 測試報告/實驗報告………………………………………………………………...15</p><p> 6. 課題研究結(jié)論……………………………………………………………………....22</p><p> 7. 總結(jié)……………………………………………………
7、……………………………. 23</p><p> 1.課程設(shè)計題目概述</p><p> MySQL Cluster 是一種技術(shù),該技術(shù)允許在無共享的系統(tǒng)中部署“內(nèi)存中”數(shù)據(jù)庫的 Cluster 。通過無共享體系結(jié)構(gòu),系統(tǒng)能夠使用廉價的硬件,而且對軟硬件無特殊要求。此外,由于每個組件有自己的內(nèi)存和磁盤,不存在單點故障。</p><p> MySQL Clust
8、er 由一組計算機構(gòu)成,每臺計算機上均運行著多種進程,包括MySQL服務(wù)器,NDB Cluster 的數(shù)據(jù)節(jié)點,管理服務(wù)器,以及(可能)專門的數(shù)據(jù)訪問程序。</p><p> MySQL Cluster 是MySQL適合于分布式計算環(huán)境的高實用、高冗余版本。MySQL Cluster 能夠使用多種故障切換和負載平衡選項配置NDB存儲引擎,但在 Cluster 級別上的存儲引擎上做這個最簡單。MySQL Clus
9、ter的NDB存儲引擎包含完整的數(shù)據(jù)集,僅取決于 Cluster本身內(nèi)的其他數(shù)據(jù)。</p><p> 目前,MySQL Cluster的 Cluster部分可獨立于MySQL服務(wù)器進行配置。在MySQL Cluster中, Cluster的每個部分被視為1個節(jié)點。</p><p> 【關(guān)鍵字】:集群 MySQL Cluster </p><p> 2. 研究內(nèi)
10、容與目的</p><p><b> 研究目的:</b></p><p> 伴隨著企業(yè)的成長,在業(yè)務(wù)量提高的同時,系統(tǒng)的訪問量和數(shù)據(jù)流量的快速增長,其處理能力和計算強度也相應(yīng)增大,使得單一設(shè)備根本無法承擔(dān)。在此情況下,如果扔掉現(xiàn)有設(shè)備去做大量的硬件升級,這樣將造成現(xiàn)有資源的浪費,而且如果再面臨下一次業(yè)務(wù)量的提升,這又將導(dǎo)致再一次硬件升級的高額成本投入,甚至性能再卓越
11、的設(shè)備也不能滿足當(dāng)前業(yè)務(wù)量的需求。于是,人們希望通過幾個中小型服務(wù)器組建集群,實現(xiàn)數(shù)據(jù)庫的負載均衡,在需要更高數(shù)據(jù)庫處理速度,我們只要簡單地增加數(shù)據(jù)庫服務(wù)器就可以得到擴展。</p><p> 數(shù)據(jù)庫作為應(yīng)用系統(tǒng)的核心,在企業(yè)的IT系統(tǒng)中起著非常重要的作用,單一設(shè)備根本無法保證系統(tǒng)的持續(xù)運行,發(fā)生系統(tǒng)故障,嚴重影響系統(tǒng)的正常運行,甚至帶來巨大的經(jīng)濟損失。于是人們希望通過組建數(shù)據(jù)庫集群,來保證系統(tǒng)的可用性,一旦某節(jié)
12、點發(fā)生故障,系統(tǒng)會自動故障轉(zhuǎn)移,實現(xiàn)系統(tǒng)的持續(xù)工作。</p><p> 企業(yè)的數(shù)據(jù)是企業(yè)的一些重要信息,一些核心數(shù)據(jù)甚至關(guān)系著企業(yè)的命脈,單一設(shè)備根本無法保證數(shù)據(jù)的安全性,一旦發(fā)生丟失,很難再找回來,于是人們希望通過組建數(shù)據(jù)庫集群,實現(xiàn)數(shù)據(jù)集群的冗余,通過多份數(shù)據(jù)來保證安全性。</p><p> MySql是一種在目前被廣泛使用著開源的免費的數(shù)據(jù)庫,在中小型數(shù)據(jù)應(yīng)用中,一般單臺MySq
13、l服務(wù)器就能滿足要求了,但對于大型WEB或其他應(yīng)用下,巨量的數(shù)據(jù)存儲訪問,單臺MySql服務(wù)器就不能很好地勝任了,而要使多臺MySql服務(wù)器協(xié)同工作,不但要考慮MySql服務(wù)器集群結(jié)構(gòu),要考慮MySql服務(wù)器的HA熱備問題,還要考慮各服務(wù)器之間負載均衡問題。</p><p><b> 研究內(nèi)容:</b></p><p> 隨著計算機應(yīng)用的普及,數(shù)據(jù)庫已經(jīng)成為構(gòu)建電
14、子商務(wù)的關(guān)鍵服務(wù)之一。雖然集群技術(shù)很好地解決了提高訪問容量的問題(如c009le等搜索門戶網(wǎng)站),但數(shù)據(jù)庫卻成為網(wǎng)站的瓶頸,因為為了避免數(shù)據(jù)一致性問題,網(wǎng)站多采用單一的數(shù)據(jù)庫服務(wù)器為所有網(wǎng)頁服務(wù)提供數(shù)據(jù),當(dāng)訪問量提高時,單個數(shù)據(jù)庫服務(wù)器往往不堪重負。即使按照過去最優(yōu)配置建設(shè)的服務(wù)器系統(tǒng)可能也無法承擔(dān)訪問量的爆炸性增長。因此,需要創(chuàng)建具有良好可擴展性和卓越性能價格比的網(wǎng)絡(luò)數(shù)據(jù)庫服務(wù)器,以滿足快速增長的訪問量和數(shù)據(jù)流量需求。</p&g
15、t;<p> 這就需要使用特定的連接方式,將價格相對較低的硬件設(shè)備結(jié)合起來,同時也能提供高性能相當(dāng)?shù)娜蝿?wù)處理能力,即數(shù)據(jù)庫集群。</p><p> 采用Linux系統(tǒng),可以提高客戶工作站運行的可靠性和穩(wěn)定性,獲得高可用性服務(wù)器。在Linux系統(tǒng)下一種雙機互備份工作方式的MySQL數(shù)據(jù)庫集群的具體實現(xiàn)方案,實現(xiàn)了高可用性集群服務(wù)器。兩個相對獨立的應(yīng)用在兩臺機器同時運行,但彼此均設(shè)為備份機,當(dāng)某一臺
16、服務(wù)器出現(xiàn)故障時,另一臺服務(wù)器可以在短時間內(nèi)將故障服務(wù)器的應(yīng)用接管過來,從而保證了應(yīng)用的持續(xù)性。</p><p><b> 3. 研究方法</b></p><p><b> 3.1研究方法</b></p><p><b> 實驗法</b></p><p><b>
17、; 3.2實驗方法</b></p><p> (1)先使用三臺主機搭建一個集群,分別作為管理節(jié)點、數(shù)據(jù)節(jié)點、SQL節(jié)點</p><p> <1> 在主節(jié)點上創(chuàng)建數(shù)據(jù)庫、新建數(shù)據(jù)表、插入數(shù)據(jù)</p><p> <2> 在非主節(jié)點上查看主節(jié)點數(shù)據(jù)更新情況</p><p> <3> 在非主節(jié)
18、點上上創(chuàng)建數(shù)據(jù)庫、新建數(shù)據(jù)表、插入數(shù)據(jù)</p><p> <4> 在主節(jié)點上查看非主節(jié)點數(shù)據(jù)更新情況</p><p> (2)使用三臺主機搭建一個集群,其中一臺作為管理節(jié)點,另兩臺分別作為數(shù)據(jù)節(jié)點和SQL節(jié)點</p><p> <1> 在主節(jié)點上創(chuàng)建數(shù)據(jù)庫、新建數(shù)據(jù)表、插入數(shù)據(jù)</p><p> <2&g
19、t; 在非主節(jié)點上查看主節(jié)點數(shù)據(jù)更新情況</p><p> <3> 在非主節(jié)點上上創(chuàng)建數(shù)據(jù)庫、新建數(shù)據(jù)表、插入數(shù)據(jù)</p><p> <4> 在主節(jié)點上查看非主節(jié)點數(shù)據(jù)更新情況</p><p><b> 3.3可行性分析</b></p><p> ?。?)MySQL Cluster 是一種技
20、術(shù),該技術(shù)允許在無共享的系統(tǒng)中部署“內(nèi)存中”數(shù)據(jù)庫的 Cluster 。通過無共享體系結(jié)構(gòu),系統(tǒng)能夠使用廉價的硬件,而且對軟硬件無特殊要求。此外,由于每個組件有自己的內(nèi)存和磁盤,不存在單點故障。MySQL Cluster 由一組計算機構(gòu)成,每臺計算機上均運行著多種進程,包括MySQL服務(wù)器,NDB Cluster 的數(shù)據(jù)節(jié)點,管理服務(wù)器,以及(可能)專門的數(shù)據(jù)訪問程序。</p><p> ?。?)3臺主機可以通過
21、交換機連接到一起,只需要在連接前修改主機的IP地址,安裝好需要安裝的軟件,這三臺主機同時安裝有ubuntu 11.04 。</p><p> (3)在進行將5臺安裝有MySQL的主機搭建成一個集群的時候,只需要用到三臺主機,只需要將其中的兩臺主機分別作為數(shù)據(jù)節(jié)點和SQL節(jié)點。</p><p> ?。?)由于我們安裝的都是虛擬機,可以在其中開啟多臺虛擬系統(tǒng),所以又可以在這兩臺主機中做出更大
22、的集群,但是出于當(dāng)前計算機性能的問題的考慮,實現(xiàn)一臺主機跑多個虛擬系統(tǒng)很吃力,所以實驗中我們只做了將3臺安裝MySQL的主機搭建成一個小的集群。</p><p> (5)集群實現(xiàn)的多種方案</p><p> <1>MySQL Clustering(ndb-cluster stogare) MySQL公司以存儲引擎方式提供的高可靠性方案,是事務(wù)安全的,實時復(fù)制數(shù)據(jù),可用于
23、需要高可靠性及負載均衡的場合。該方案至少需要三個節(jié)點服務(wù)器才能達到較好的效果。 成本: (1) 節(jié)點服務(wù)器對RAM的需求很大,與數(shù)據(jù)庫大小呈線性比例; (2) 最好使用千兆以太網(wǎng)絡(luò); (3) 還需要使用Dolphin公司提供的昂貴的SCI卡。 優(yōu)點: (1) 可用于負載均衡場合; (2) 可用于高可靠性場合; (3) 高伸縮性; (4) 真正的數(shù)據(jù)庫冗余; (5) 容易維護?! ∪秉c: (1
24、) 隨著數(shù)據(jù)庫的變大,對RAM的需求變得更大,因此成本很高; 速度: (1) 幾乎比典型的單獨服務(wù)器(無千兆以太網(wǎng),無SCI卡,存儲引擎相關(guān)的 限制少)慢10倍?! ?yīng)用場合: (1) 冗余,高可靠性,負載均衡<2>MySQL / GFS-GNBD/ HA (Active/Passive) GFS是事務(wù)安全的文件系統(tǒng)。同一時刻可以讓一個MySQL使用共享數(shù)據(jù)?! 〕?lt;/p><p&
25、gt; MySQL Cluster (集群)基本原理MySQL簇概述</p><p> MySQL簇是一種技術(shù),該技術(shù)允許在無共享的系統(tǒng)中部署“內(nèi)存中”數(shù)據(jù)庫的簇。通過無共享體系結(jié)構(gòu),系統(tǒng)能夠使用廉價的硬件,而且對軟硬件無特殊要求。此外,由于每個組件有自己的內(nèi)存和磁盤,不存在單點故障。</p><p> MySQL簇將標準的MySQL服務(wù)器與名為NDB的“內(nèi)存中”簇式存儲引擎集成了起
26、來。在我們的文檔中,術(shù)語NDB指的是與存儲引擎相關(guān)的設(shè)置部分,而術(shù)語“MySQL簇”指的是MySQL和NDB存儲引擎的組合。</p><p> MySQL簇由一組計算機構(gòu)成,每臺計算機上均運行著多種進程,包括MySQL服務(wù)器,NDB簇的數(shù)據(jù)節(jié)點,管理服務(wù)器,以及(可能)專門的數(shù)據(jù)訪問程序。關(guān)于簇中這些組件的關(guān)系,參見下圖:</p><p> application</p>
27、<p> NDB是一種“內(nèi)存中”存儲引擎,它具有可用性高和數(shù)據(jù)一致性好的特點。</p><p> 能夠使用多種故障切換和負載平衡選項配置NDB存儲引擎,但以簇層面上的存儲引擎開始最簡單。MySQL簇的NDB存儲引擎包含完整的數(shù)據(jù)集,僅取決于簇本身內(nèi)的其他數(shù)據(jù)。</p><p> 在最低的MySQL簇配置中,至少有三個節(jié)點,這三類節(jié)點分別是:</p><
28、p> <1>管理(MGM)節(jié)點:這類節(jié)點的作用是管理MySQL簇內(nèi)的其他節(jié)點,如提供配置數(shù)據(jù)、啟動并停止節(jié)點、運行備份等。由于這類節(jié)點負責(zé)管理其他節(jié)點的配置,應(yīng)在啟動其他節(jié)點之前首先啟動這類節(jié)點。MGM節(jié)點是用命令ndb_mgmd啟動的。</p><p> <2> 數(shù)據(jù)節(jié)點:這類節(jié)點用于保存簇的數(shù)據(jù)。數(shù)據(jù)節(jié)點的數(shù)目與副本的數(shù)目相關(guān),是片段的倍數(shù)。例如,對于兩個副本,每個副本有兩個
29、片段,那么就有4個數(shù)據(jù)節(jié)點。沒有必要有一個以上的副本。數(shù)據(jù)節(jié)點是用命令ndbd啟動的。</p><p> <3> SQL節(jié)點:這是用來訪問簇數(shù)據(jù)的節(jié)點。對于MySQL簇,客戶端節(jié)點是使用NDB簇存儲引擎的傳統(tǒng)MySQL服務(wù)器。典型情況下,SQL節(jié)點是使用命令mysqld –ndbcluster啟動的,或?qū)dbcluster添加到my.cnf后使用mysqld啟動。簇配置包括對簇中單獨節(jié)點的配置,以
30、及設(shè)置節(jié)點之間的單獨通信鏈路。對于目前設(shè)計MySQL簇,其意圖在于,從處理器的能力、內(nèi)存空間和帶寬來講,存儲節(jié)點是同質(zhì)的,此外,為了提供單一的配置點,作為整體,簇的所有配置數(shù)據(jù)均位于1個配置文件中。</p><p><b> 4. 研究報告</b></p><p><b> 4.1 規(guī)劃階段</b></p><p>
31、 計劃建立有5個節(jié)點的MySQL CLuster體系,在這里將兩個SQL節(jié)點和數(shù)據(jù)節(jié)點裝在一起,因此需要用到3臺機器,具體分配如下表:</p><p> 4.2 安裝Mysql server </p><p> $wget http://dev.mysql.com/get/Downloads/MySQL-5.1/mysql-5.1.59.tar.gz/from/http://mysql
32、.cs.pu.edu.tw/</p><p> $tar -xzvf mysql-5.1.59.tar.gz</p><p> $cd mysql-5.1.59</p><p> $./configure --with-charset=utf8 --with-collation=utf8_bin --with-extra-</p><p&g
33、t; charsets=gbk,gb2312,big5,utf8,binary,ascii --prefix=/usr/local/mysql --with-plugins=partition,ndbcluster</p><p><b> $make </b></p><p> $make install</p><p> 4.3
34、安裝Mysql Cluster</p><p><b> $wget </b></p><p> http://dev.mysql.com/get/Downloads/MySQL-Cluster-7. 1/mysql-cluster-</p><p> gpl-7.1.15a-linux-x86_64-glibc23.tar.gz/fro
35、m/http://mysql.ntu.edu.tw/</p><p> $tar -xzvf mysql-cluster-gpl-7.1.15a-linux-x86_64-glibc23.tar.gz</p><p> $mv mysql-cluster-gpl-7.1.15a-linux-x86_64-glibc23.tar.gz</p><p> /usr
36、/local/mysql-cluster</p><p> $cd /usr/local/mysql-cluster</p><p> $groupadd mysql</p><p> $useradd -g mysql mysql </p><p> $passwd mysql </p><p> $cd
37、/usr/local/mysql-cluster</p><p> $chown -R mysql:mysql . </p><p> $scripts/mysql_install_db --user=mysql </p><p> $cp -rp bin/ndb* /usr/local/bin/</p><p> 4.4 配置管理節(jié)
38、點</p><p> $cp support-files/ndb-config-2-node.ini /etc/ndb_mgmd.ini</p><p> $vi /etc/ndb_mgmd.ini</p><p> [ndbd default]</p><p> NoOfReplicas= 2</p><p>
39、; MaxNoOfConcurrentOperations= 10000</p><p> DataMemory= 80M</p><p> IndexMemory= 24M</p><p> TimeBetweenWatchDogCheck= 30000</p><p> DataDir= /usr/local/mysql-clu
40、ster/data</p><p> MaxNoOfOrderedIndexes= 512</p><p> #設(shè)置管理節(jié)點服務(wù)器</p><p> [ndb_mgmd default]</p><p> DataDir= /usr/local/mysql-cluster/data #MGM上保存日志的目錄</p>&l
41、t;p> [ndb_mgmd]</p><p><b> Id=1</b></p><p> HostName= 10.0.31.49</p><p> #設(shè)置存儲節(jié)點服務(wù)器(NDB節(jié)點)</p><p><b> [ndbd] </b></p><p>&l
42、t;b> Id= 2</b></p><p> HostName= 10.0.31.40</p><p> DataDir=/usr/local/mysql-cluster/data</p><p><b> [ndbd]</b></p><p><b> Id= 3</b&g
43、t;</p><p> HostName= 10.0.31.41</p><p> DataDir=/usr/local/mysql-cluster/data</p><p> #設(shè)置SQL節(jié)點服務(wù)器</p><p><b> [mysqld]</b></p><p><b>
44、 Id= 5</b></p><p> HostName= 10.0.31.40</p><p> [mysqld]#第二個SQL節(jié)點</p><p><b> Id= 6</b></p><p> HostName= 10.0.31.41</p><p> # 選擇一個未使
45、用的端口</p><p> [tcp default]</p><p> PortNumber= 63132</p><p> 4.5 配置SQL節(jié)點</p><p><b> [mysqld]</b></p><p> basedir = /usr/local/mysql/</p
46、><p> datadir = /usr/local/mysql/data</p><p> user = mysql</p><p> port = 3306</p><p> socket = /tmp/mysql.sock</p><p> ndbcluster</p><p>
47、ndb-connectstring=10.0.31.40</p><p> [MYSQL_CLUSTER]</p><p> ndb-connectstring=10.0.31.41</p><p> 4.6 配置存儲節(jié)點(NDB節(jié)點)</p><p> $vi /etc/ndbd.cnf</p><p>
48、[mysqld]ndbclusterDataDir=/usr/local/mysql-cluster/data[MYSQL_CLUSTER]ndb-connectstring=nodeid=192.168.0.55</p><p> 4.7 啟動MySQL Cluster</p><p> 首先啟動管理節(jié)點服務(wù)器,然后啟動存儲節(jié)點服務(wù)器,最后才啟動SQL節(jié)點服務(wù)器: </
49、p><p> (1)在管理節(jié)點服務(wù)器上,執(zhí)行以下命令啟動MGM節(jié)點進程:</p><p> $/usr/local/bin/ndb_mgmd -f /etc/ndb_mgmd.ini --configdir=/usr/local/mysq</p><p><b> l-cluster</b></p><p> $n
50、etstat -ntpl |grep ndb #檢查是否成功</p><p> ?。?)在每臺存儲節(jié)點服務(wù)器上,先執(zhí)行以下命令:</p><p> $/usr/local/bin/ndbd --initial --defaults-file=/etc/ndbd.cnf</p><p> ?。?)運行以下命令啟動SQL節(jié)點服務(wù)器:</p><p&
51、gt; $mysqld_safe --defaults-file=/etc/my.cnf &</p><p> 4.8 關(guān)閉MySQL Cluster</p><p> 在MGM節(jié)點所在的機器上, Shell中簡單地輸入下述命令用來關(guān)閉Cluster:</p><p> $/usr/local/bin/ndb_mgm -e shutdown</
52、p><p> 運行以下命令關(guān)閉SQL節(jié)點的mysqld服務(wù):</p><p> $/usr/local/bin/mysqladmin -uroot shutdown</p><p><b> 4.9 數(shù)據(jù)測試</b></p><p> ?。?)在主節(jié)點上新建一個數(shù)據(jù)庫ClusterTest,新建數(shù)據(jù)表user,插入一行
53、數(shù)據(jù)</p><p> mysql> create database ClusterTest</p><p> mysql> use ClusterTest</p><p> mysql> create table user(nu mint , name varchar(50) engine=NDB);</p><p>
54、; mysql> select * from user;</p><p> ?。?)在非主節(jié)點上查看數(shù)據(jù)同步情況</p><p> mysql> use ClusterTest</p><p> mysql> select * from user;</p><p> (3)在非主節(jié)點上新建一個數(shù)據(jù)庫ClusterTe
55、st,新建數(shù)據(jù)表user,插入一行數(shù)據(jù)</p><p> mysql> create database ClusterTest</p><p> mysql> use ClusterTest</p><p> mysql> create table user(nu mint , name varchar(50) engine=NDB);<
56、;/p><p> mysql> select * from user;</p><p> ?。?)在主節(jié)點上查看數(shù)據(jù)同步情況</p><p> mysql> use ClusterTest</p><p> mysql> select * from user;</p><p><b>
57、4.10安全關(guān)閉</b></p><p> 要想關(guān)閉 Cluster,可在MGM節(jié)點所在的機器上,在Shell中簡單地輸入下述命令:</p><p> [db1~]root# /usr/local/mysql/ndb_mgm -e shutdown</p><p> 運行以下命令關(guān)閉SQL節(jié)點的mysqld服務(wù):</p><p&
58、gt; [db2~]root# /usr/local/mysql/bin/mysqladmin -uroot shutdown</p><p> 5. 測試報告/實驗報告</p><p><b> 實驗報告</b></p><p> (1)下載mysql-cluster-gpl-7.1.22-linux-x86_64-glibc 23.
59、tar.gz安裝包,選擇服務(wù)器架構(gòu)類型。</p><p> ?。?)建立mysql用戶組和mysql用戶:#groupadd mysql && useradd mysql -g mysql(3)解壓壓縮包并重命名:</p><p> #tar zxvf mysql-cluster-gpl-7.1.22-linux-x86_64-glibc 23.tar.gz</
60、p><p> #mv mysql-cluster-gpl-7.1.22-linux-x86_64-glibc 23 mysqlc</p><p> (4)進入mysqlc目錄創(chuàng)建logs目錄并更改mysqlc目錄的所有者</p><p> #cd mysqlc && mkdir logs</p><p> #cd ..
61、 && chown -R mysql:mysql mysqlc</p><p><b> 截圖如下: </b></p><p> (5)建系統(tǒng)相關(guān)數(shù)據(jù)庫以及表</p><p> #scripts/mysql_install_db --user=mysql</p><p><b> ?。?)
62、配置管理節(jié)點</b></p><p> #mkdir /var/lib/mysql-cluster && cd /var/lib/mysql-cluster</p><p> # vim /var/lib/mysql-cluster/config.ini</p><p><b> 保存并退回出</b></
63、p><p><b> 截圖如下:</b></p><p> ?。?)安裝配置數(shù)據(jù)節(jié)點</p><p> 復(fù)制管理節(jié)點上的mysqlc整個目錄到數(shù)據(jù)節(jié)點1上的/usr/local目錄,重命名為mysql,確保mysql目錄的所屬用戶和組為mysql。</p><p> 復(fù)制配置文件和啟動腳本</p><
64、;p> #cp support-files/my-medium.cnf /etc /my.cnf</p><p> #cp support-files/mysql.server /etc /init.d/mysqld</p><p><b> 編輯配置文件</b></p><p> #vim /etc /my.cnf</p&
65、gt;<p> 增加[mysqld]下面的配置項</p><p> 保存后退出,在數(shù)據(jù)節(jié)點2上進行相同操作。</p><p><b> 截圖如下:</b></p><p><b> (8)啟動管理節(jié)點</b></p><p><b> (9)啟動數(shù)據(jù)節(jié)點</b
66、></p><p> (10)啟動SQL節(jié)點</p><p> ?。?1)在管理端查看集群當(dāng)前狀態(tài)</p><p> (12)在節(jié)點2上啟動數(shù)據(jù)節(jié)點和SQL節(jié)點</p><p><b> 測試報告</b></p><p> 主節(jié)點上創(chuàng)建ClusterTest數(shù)據(jù)庫,user數(shù)據(jù)表,插
67、入一條數(shù)據(jù)。</p><p> 在非主節(jié)點上查看數(shù)據(jù)同步情況: </p><p> 在非主節(jié)點上更新數(shù)據(jù)</p><p> 查看主節(jié)點上數(shù)據(jù)同步情況</p><p><b> 6. 課題研究結(jié)論</b></p><p> MySQL Cluster 由一組計算機構(gòu)成,每臺計算機上均運行著
68、多種進程,包括MySQL服務(wù)器,NDB Cluster 的數(shù)據(jù)節(jié)點,管理服務(wù)器,以及(可能)專門的數(shù)據(jù)訪問程序。</p><p> MySQL Cluster 是MySQL適合于分布式計算環(huán)境的高實用、高冗余版本。MySQL Cluster 能夠使用多種故障切換和負載平衡選項配置NDB存儲引擎,但在 Cluster 級別上的存儲引擎上做這個最簡單。MySQL Cluster的NDB存儲引擎包含完整的數(shù)據(jù)集,僅取
69、決于 Cluster本身內(nèi)的其他數(shù)據(jù)。在課程設(shè)計中實現(xiàn)了對一臺計算機上進行創(chuàng)建數(shù)據(jù)庫、新建數(shù)據(jù)表、插入數(shù)據(jù),在其他計算機上均能查看這些信息的功能 。</p><p> 采用Linux系統(tǒng),可以提高客戶工作站運行的可靠性和穩(wěn)定性,獲得高可用性服務(wù)器。在Linux系統(tǒng)下一種雙機互備份工作方式的MySQL數(shù)據(jù)庫集群的具體實現(xiàn)方案,實現(xiàn)了高可用性集群服務(wù)器。兩個相對獨立的應(yīng)用在兩臺機器同時運行,但彼此均設(shè)為備份機,當(dāng)某
70、一臺服務(wù)器出現(xiàn)故障時,另一臺服務(wù)器可以在短時間內(nèi)將故障服務(wù)器的應(yīng)用接管過來,從而保證了應(yīng)用的持續(xù)性。</p><p><b> 7. 總結(jié)</b></p><p> 隨著網(wǎng)絡(luò)技術(shù)的飛速發(fā)展,傳統(tǒng)的服務(wù)器體系結(jié)構(gòu)愈來愈不適應(yīng)當(dāng)前的需求,集群技術(shù)以其獨特的優(yōu)點很好地適應(yīng)了當(dāng)前網(wǎng)絡(luò)發(fā)展的需要。而Linux以其開源代碼模式成為當(dāng)前集群研究的熱點,本文正是基于這一點,介紹了
71、MySQL集群的基本概念及其實現(xiàn)方式,依靠集群文件系統(tǒng)實現(xiàn)對系統(tǒng)中的所有文件、設(shè)備和網(wǎng)絡(luò)資源的全局訪問,突破了數(shù)據(jù)庫容量的瓶頸限制。開源數(shù)據(jù)庫開發(fā)商MySQL公司在2007 MySQL大會上宣布了最新的MySQL Cluster Carrier Grade Edition數(shù)據(jù)庫DBT2基準測試結(jié)果。該基準測試結(jié)果顯示了MySQL Cluster Carrier Grade Edition的高擴展性,使用8個節(jié)點的Cluster能達到每分
72、鐘100,000個事務(wù)處理。所以企業(yè)在網(wǎng)絡(luò)規(guī)劃資金欠缺的情況下,用免費的MySQL Cluster架設(shè)數(shù)據(jù)庫集群,完全可以滿足大流量的信息處理需求。</p><p> MySQL數(shù)據(jù)庫有很多優(yōu)點</p><p><b> 擴展性和靈活性 </b></p><p> MySQL數(shù)據(jù)庫服務(wù)器提供非常強大的擴展性,可以支持深度嵌入應(yīng)用系統(tǒng),大小
73、只有1MB。也可以支持TB級別的數(shù)據(jù)倉庫。平臺靈活性一直以來是MySQL的特性,MySQL現(xiàn)在支持Linux,UNIX,和Windows。當(dāng)然,MySQL的開源本性允許全面的自定義,這滿足了那些需要添加特殊要求至數(shù)據(jù)庫的需求。 </p><p><b> 高性能 </b></p><p> 獨特的存儲引擎架構(gòu)使得數(shù)據(jù)庫專業(yè)人員可以為特定的應(yīng)用配置有針對性的MySQ
74、L數(shù)據(jù)庫,由此,可以獲得出人意料的性能結(jié)果。不管應(yīng)用是高速的事務(wù)處理或是每天處理上億查詢大容量web站點,MySQL可以滿足任何系統(tǒng)最急需的性能要求。使用高速加載工具,不同的內(nèi)存緩存,全文索引,以及其它的性能加強機制,MySQL提供了現(xiàn)今關(guān)鍵業(yè)務(wù)系統(tǒng)需要的所有功能和特性。 </p><p><b> 高可用 </b></p><p> 堅若磐石的可靠性和持續(xù)的可用
75、性是MySQL的特征,客戶憑借MySQL確保24小時的服務(wù)。MySQL提供各種高可用的方案,高速的主/從復(fù)制配置,特殊集群服務(wù)器提供的即時切換,以及其它第三方供應(yīng)商為MySQL數(shù)據(jù)庫提供的獨特高可用解決方法。 </p><p><b> 強大的事務(wù)支持 </b></p><p> MySQL提供一個強大的事務(wù)處理引擎。特性包括完整的ACID(原子性,一致性,隔離性
76、,持久性)事務(wù)支持,不限制的行級鎖,分布式事務(wù)能力,多版本事務(wù)支持。另外,也確保數(shù)據(jù)完整性,方法是通過服務(wù)器強制的引用完整性,特殊事務(wù)隔離級別,即時死鎖檢測。 </p><p> Web和數(shù)據(jù)倉庫能力 </p><p> MySQL事實上可用于高速web站點,因為它具備高性能的查詢引擎,大量快速數(shù)據(jù)插入能力,有力地支持特定web方法如全文搜索。這些特性同樣適用于數(shù)據(jù)倉庫環(huán)境,這里的My
77、SQL擴展至可以容納T級別的數(shù)據(jù)年。其它的特性,如內(nèi)存表,B-樹索引和hash索引,以及高達80%壓縮率的壓縮表。使得MySQL完全可以用于web站點和商業(yè)智能應(yīng)用。 </p><p><b> 強大的數(shù)據(jù)保護 </b></p><p> 保障公司數(shù)據(jù)資產(chǎn)安全是數(shù)據(jù)庫管理員的日常工作之一。MySQL提供超乎尋常的安全特性,可以確保絕對的數(shù)據(jù)安全。在數(shù)據(jù)庫安全認證方
78、面,MySQL提供有力機制以確保只有授機用戶可以訪問數(shù)據(jù)庫服務(wù)器,這樣就可以有能力將用戶阻止在客戶端機器的一層。SSH和SLL的支持確保了連接的安全與可靠。粒度對象權(quán)限框架保證了用戶可能看到他們被許可看的,強大的數(shù)據(jù)加密和解密功能確保了敏感數(shù)據(jù)不被未授權(quán)的查看。最后,MySQL和其它第三方軟件提供商提供的備份和恢復(fù)工具允許完全的邏輯與物理備份以及按時間點恢復(fù)。 </p><p><b> 全面的應(yīng)用開
79、發(fā) </b></p><p> MySQL之所以成為全球最流行的開源數(shù)據(jù)庫的原因之一是它針對每一個應(yīng)用開發(fā)提供全面的支持。在數(shù)據(jù)庫里,支持包括存儲過程,觸發(fā)器,函數(shù),視圖,游標,ANSI標準SQL,以及更多。對于嵌入式應(yīng)用,可以使用嵌入式MySQL的插件庫,幾乎支持任意應(yīng)用。MySQL提供連接器和驅(qū)動(ODBC,JDBC,等等)。這使得各種應(yīng)用程序都可以使用MySQL作為首選的數(shù)據(jù)庫管理服務(wù)器。不管
80、是,PHP, Perl, Java, Visual Basic, 還是 .NET,MySQL都可滿足應(yīng)用開發(fā)人員成功構(gòu)建數(shù)據(jù)庫驅(qū)動信息系統(tǒng)的需求。 </p><p><b> 管理方便 </b></p><p> MySQL有著異乎尋常的快速部署能力。軟件從下載到安裝完成平均時間少于是15分鐘。對于以下任意平臺都是: Microsoft Windows, Linu
81、x, Macintosh, 或是 UNIX。一旦安裝,自管理特性,比如自動空間增長,自動重啟,以及動態(tài)改變配置為數(shù)據(jù)庫管理員大大減少了壓力。MySQL提供了一套圖形化管理和遷移工具,使得DBA可以管理,解決問題,以及從一個單一的工作臺控制多個MySQL服務(wù)器。許多第三方的軟件供應(yīng)商提供工具,可以讓DBA進行數(shù)據(jù)設(shè)計和ETL,完成數(shù)據(jù)庫管理工作,任務(wù)管理,性能監(jiān)控。</p><p> 開源自由和24*7支持 &l
82、t;/p><p> 很多公司對于是否完全采用開源軟件還持懷疑態(tài)度。因為他們認為使用MySQL不可能會得到他們當(dāng)前依賴的商業(yè)服務(wù)對關(guān)鍵業(yè)務(wù)提供的支持。事實上,這些懷疑是完全沒有必要的,MySQL企業(yè)版提供一天24小時的支持。MySQL不是一個典型的開源項目,因為其全部的軟件都是由Oracle所有,正因為如此,存在一個特殊的付費和支持模型,使得存在一個自由開源和得到支持受信軟件的結(jié)合體。 </p><
83、;p> 最低的總體擁有成本 </p><p> 將當(dāng)前數(shù)據(jù)庫驅(qū)動的應(yīng)用程序遷移至MySQL,或是在新的開發(fā)項目中使用MySQL,公司將可以體會到成本大大的降低了。將MySQL數(shù)據(jù)庫服務(wù)器和使用廉價硬件擴展架構(gòu)相結(jié)合,公司可以發(fā)現(xiàn)可以獲得超乎想象的擴展性和性能,所有的這些花費遠遠少于使用水平擴展的方式。另外,可靠性和易維護性意味著MySQL可以讓數(shù)據(jù)庫管理員不用在解決性能問題或是宕機時間上耗費時間,而只需
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 課程設(shè)計mysql集群的研究與實現(xiàn)
- mysql數(shù)據(jù)庫課程設(shè)計
- mysql集群
- 集群通信系統(tǒng)課程設(shè)計
- 課程設(shè)計基于linux下的mysql數(shù)據(jù)庫的研究
- 分布式mysql數(shù)據(jù)庫集群在線監(jiān)測系統(tǒng)設(shè)計與實現(xiàn)
- 課程設(shè)計the linux-based installation and configuration of mysql database
- 分布式MySQL數(shù)據(jù)庫集群在線監(jiān)測系統(tǒng)設(shè)計與實現(xiàn).pdf
- java課程設(shè)計--基于mysql的學(xué)生信息管理系統(tǒng)
- 基于MySQL集群實現(xiàn)的高性能數(shù)據(jù)庫架構(gòu)設(shè)計.pdf
- 樂曲程序的設(shè)計與實現(xiàn)---課程設(shè)計
- 生成樹協(xié)議的研究與實現(xiàn)課程設(shè)計
- mysql集群解決方案
- opensips+freeswitch+mysql集群
- 精品課程網(wǎng)站的設(shè)計與實現(xiàn)設(shè)計課程設(shè)計
- java+mysql學(xué)生信息管理系統(tǒng)課程設(shè)計報告
- vlsi課程設(shè)計——同步fifo的設(shè)計與實現(xiàn)
- web課程設(shè)計--個人博客的設(shè)計與實現(xiàn)
- 課程設(shè)計--nat功能的配置與實現(xiàn)
- 預(yù)測編碼的分析與實現(xiàn)課程設(shè)計
評論
0/150
提交評論