MySQL Cluster是一种技术,该技术允许在无共享的系统中部署“内存中”数据库的簇。通过无共享体系结构,系统能够使用廉价的硬件,而且对软硬件无特殊要求。此外,由于每个组件都有自己的内存和磁盘,所以不存在单点故障。
坚守“ 做人真诚 · 做事靠谱 · 口碑至上 · 高效敬业 ”的价值观,专业网站建设服务10余年为成都成都酒店设计小微创业公司专业提供企业网站设计营销网站建设商城网站建设手机网站建设小程序网站建设网站改版,从内容策划、视觉设计、底层架构、网页布局、功能开发迭代于一体的高端网站建设服务。
MySQL簇将标准的MySQL服务器与名为NDB的“内存中”的簇式存储引擎集成了起来。术语NDB指的是与存储引擎相关的设置部分,而术语“MySQL簇”指的是MySQL和NDB存储引擎的组合。
MySQL簇由一组计算机构成,每台计算机上均运行着多种进程,包括MySQL服务器,NDB簇的数据节点,管理服务器(MGM),以及(可能)专门的数据访问程序。关于簇中这些组件的关系,如下图:
所有这些程序一起构成了MySQL簇。将数据保存到NBD簇引擎中时,表将保存在数据节点内。能够从簇中所有其他MySQL服务器直接访问这些表。因此,假如在将数据保存在簇内的工资应用程序中,如果某一应用程序更新了一位雇员的工资,所有查询该数据的其他MySQL 服务器能立刻发现这种变化。
对于MySQL簇,保存在数据节点的数据可被映射,簇能够处理单独数据节点的故障,除了少数事物将因事物状态丢失而被放弃外,不会产生其他影响。由于事物性应用程序能够处理失败事宜,因而它不是问题源。
NDB 是一种“内存中”存储引擎,它具有可用性高和数据一致性好的特点。
能够使用多种故障切换和负载平衡选项配置NDB 存储引擎,但以簇层面上的存储引擎开始最简单。MySQL簇的NDB存储引擎包含完整的数据集,仅取决于簇本身内的其他数据。
下面名,我们将介绍设置由NDB存储引擎和一些MySQL服务器构成的MySQL簇的设置方法。
目前,MySQL簇的部分可以独立于MySQL服务器进行配置。在MySQL簇中,簇的每个部分被视为一个节点。
注释:在很多情况下,术语“节点”用于指计算机,但在讨论MySQL簇时,它表示的是进程。在单台计算机上可以有任意数目的节点,所以我们才有可能将多个不同功能的节点配置在同一台计算机上,为此,我们采用术语簇主机。
有三类簇节点,在最低的MySQL簇配置中,至少有三个节点,这三类节点分别是:
管理节点(MGM):这类节点的作用是管理MySQL簇内的其他节点,如提供配置数据,启动并停止节点,运行备份等。由于这类节点负责管理其他节点的配置,所以管理节点应在其他节点之前先启动。MGM节点是用命令ndb_mgm启动的。
数据节点(NDB):这类节点用于保存簇的数据。数据集点的数目与副本的数目相关,是片段的倍数。例如,对于两个副本,每个副本又两个片段,那么就有4个数据节点。没有必要有一个以上的副本。。数据节点是用命令ndbd来启动的。
SQL节点:这类节点是用来访问簇数据的节点。对于MySQL簇,客户端节点是使用NDB 簇存储引擎的传统MySQL服务器。典型情况下,SQL节点是使用命令mysql -ndbcluster来启动的,或将ndbcluster添加到my.cnf后面使用mysqld启动。
簇配置包括对簇中单独节点的配置,以及设置节点之间的单独通信链路。对于目前设计的MySQL簇,其意图在于,从处理器的能力,内存空间和宽带来讲,存储节点是同质的,此外,为了提供单一的配置点,作为整体,簇的所有配置均位于一个文件中。
管理服务器(MGM节点)负责管理簇配置文件和簇日志。簇中的每个节点从管理服务器检索配置数据,并请求确定管理服务器所在的位置的方式。当数据节点内出现有趣的事件时,节点将关于这类事件的信息传输到管理服务器,然后,啊经这类信息写入簇日志。
实验过程中,只是用两台计算机来实现MySQL-Cluster环境的配置,具体环境如下:
管理节点(MGM)服务器:192.168.3.47 主机名:songzi nodeid=1
数据节点1(NDB ):192.168.3.47 nodeid=11
数据节点2(NDB):192.168.4.128 nodeid=12
SQL节点1:192.168.3.47 nodeid=21
SQL节点2:192.168.4.128 nodeid=22
其中192.168.3.47安装的为Ubuntu12.04的32位操作系统,192.168.4.128安装的为ubuntu12.04的64位操作系统。
对于MySQL-Cluster的安装包下载,下载地址见http://dev.mysql.com/downloads/cluster/ ,其中192.168.3.47的操作系统为32位的linux,所以选择的下载版本为:mysql-cluster-gpl-7.3.3-linux-glibc2.5-i686.tar.gz。而192.168.4.128为64 位的linux操作系统,所以选择的下载版本为:mysql-cluster-gpl-7.3.3-linux-glibc2.5-x86_64.tar.gz。在终端中执行 :uname -m指令可查看操作系统的信息,若结果显示为i686,则为32位操作系统。若结果为x86_64,则为64位操作系统。务必选择正确的版本,并下载。
此外 如果之前安装过mysql-server,在进行此次实验之前,需要将mysql-server卸载,执行以下指令卸载mysql
sudo apt-get autoremove –purge mysql-serversudo apt-get remove mysql-serversudo apt-get autoremove mysql-serversudo apt-get remove mysql-common (非常重要)
四 安装
对于每台运行存储或者SQL节点的MySQL簇计算机,必须在其上安装MySQL服务器的二进制版本。对于管理节点,没有必要安装MySQL服务器的二进制版本,但应安装MGM 服务器端口监督程序和客户端二进制版本(分别是ndb_mgmd和ndb_mgm)。本节将详细介绍每种簇节点安装正确的二进制版本所需要的步骤。
4.1 存储节点和SQL节点安装
SQL节点和数据节点的安装步骤基本相同,所以在设计为存储节点或SQL节点的的每一台机器上,以系统根用户身份执行以下步骤:
\1. 检查/etc/passwd和/etc/group/文件,查看在系统上是否已经存在mysql组和mysql用户,这时因为某些操作系统会将其作为安装进程的一部分创建。可以使用以下指令查看:
cat show /etc/passwd
cat show /etc/group
如果它们不存在,则需要创建新的mysql用户组,然后为该组添加一个mysql用户
groupadd mysql
useradd -g mysql mysql
\2. 进入包含已经下载好文件的目录,解压档案文件,并创建与mysql可执行文件链接symlink。注意,根据MySQL的版本号和浏览器下载文件的目录,实际的文件和目录名可能会有所不同。如本人下载文件在浏览器默认的/home/jenny/Downloads目录下,
cd /home/jenny/Downloads
tar zxvf -C mysql-cluster-gpl-7.3.3-linux-glibc2.5-i686.tar.gz /usr/local/bin
cd /var/tmp
ln -s /usr/local/bin/mysql-cluster-gpl-7.3.3-linux-glibc2.5-i686.tar.gz mysql
\3. 进入mysql目录,运行所提供的用于创建系统数据库的脚本:
cd mysql
scripts/mysql_install_db –user=mysql
如果此脚本不能运行,若报错为主机名不匹配的话,则很有可能是下载的版本不对,查看操作系统是32位还是64位,选择正确的版本。若报错找不到默认的文件,则很有可能是因为之前的mysql-server没有卸载,执行上文提供的指令,彻底卸载mysql-server。
\4. 为MySQL服务器和数据目录设置必要的权限:
chown -R root .
chown -R mysql data
chgrp -R mysql .
注意,在每台运行数据节点的机器上,数据目录是/usr/local/mysql/data,也可另外指定,若指定为此目录,则此文件必须存在,必要时需手动创建。配置管理节点时将用到这类信息。
\5. 将MySQL启动脚本拷贝恰当的目录下,使之成为可执行的脚本,并设置它以便在启动操作系统时启动:
cp support-files/mysql.server /etc/init.d
chmod +x /etc/init.d/mysql.server
chconfig –add mysql.server
请记住,对于存储节点或SQL节点所在的每台机器,必须分别执行以上步骤。
4.2 管理节点安装
对于管理(MGM)节点,不需要安装mysqld可执行文件,仅需要安装用于MGM服务器和客户端的二进制文件,这类文件可在下载的档案文件中找到。假定将下载的档案文件放在了/var/tmp文件下,以系统管理员的身份执行以下步骤,在簇管理节点主机上安装ndb_mgmd和ndb_mgm:
\1. 进入/var/tmp目录,从档案文件中将ndb_mgmd和ndb_mgm提取到恰当的目录下,如/usr/local/bin:
cd /var/tmp
tar zxvf -C mysql-cluster-gpl-7.3.3-linux-glibc2.5-i686.tar.gz
cp /mysql-cluster-gpl-7.3.3-linux-glibc2.5-i686.tar.gz/bin/ndb_mgm* /usr/local/bin/
\2. 进入nndb_mgmd和ndb_mgm所在的目录,然后使这两个文件成为可执行的:
cd /usr/local/bin
chmod mysql-cluster-gpl-7.3.3-linux-glibc2.5-i686.tar.gzd +x ndb_mgm*
至此,所有节点的安装工作就已经完成,接下来将详细介绍每个节点的具体配置方法。
本文名称:Ubuntu中安装和配置MySQL-Cluster
分享网址:http://www.csdahua.cn/qtweb/news25/511675.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网