2023年全國碩士研究生考試考研英語一試題真題(含答案詳解+作文范文)_第1頁
已閱讀1頁,還剩25頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論