mysql cluster配置
依赖包要求:cmake gcc gcc-c++ ncurses Perl ncurses-devel
在7.3以及更高的版本中, WITH_NDB_JAVA是默认启动的,需要配置JAVA环境,WITH_CLASSPATH配置JAVA目录。如果不启用,可以: -DWITH_NDB_JAVA=OFF。
CMAKE配置选项:
具体参阅:https://dev.mysql.com/doc/refman/5.6/en/source-configuration-options.html#cmake-general-options
cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/usr/local/mysql/data -DMYSQL_UNIX_ADDR=/usr/local/mysql/data/mysqld.sock -DWITH_EXTRA_CHARSETS=all -DWITH_SSL=bundled -DWITH_EMBEDDED_SERVER=1 -DENABLED_LOCAL_INFILE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_NDB_JAVA=OFF -DWITH_NDBCLUSTER_STORAGE_ENGINE=1 -DWITH_boost=/usr/local/boost
SQL节点存储的是表结构,数据节点存储的是数据文件。
配置参数:
数据节点配置参数参阅:https://dev.mysql.com/doc/refman/5.7/en/mysql-cluster-params-ndbd.html https://dev.mysql.com/doc/refman/5.7/en/mysql-cluster-ndbd-definition.html
SQL节点配置参数参阅:https://dev.mysql.com/doc/refman/5.7/en/mysql-cluster-params-api.html https://dev.mysql.com/doc/refman/5.7/en/mysql-cluster-api-definition.html
管理节点参数参阅:https://dev.mysql.com/doc/refman/5.7/en/mysql-cluster-params-mgmd.html https://dev.mysql.com/doc/refman/5.7/en/mysql-cluster-mgm-definition.html
其他参数参阅:https://dev.mysql.com/doc/refman/5.7/en/mysql-cluster-params-other.html
管理节点需要一个config.ini文件,SQL节点和数据节点需要一个my.cnf文件。
SQL节点与数据节点配置(my.cnf): #SQL节点与数据节点配置都是一样的,在管理节点上区分两个节点。
[mysqld]
ndbcluster
skip-ndbcluster
binlog_format=row
log-bin=fb-bin
server-id=2151
ndb-connectstring=192.168.152.156
secure-file-priv=''
[mysql_cluster]
ndb-connectstring=192.168.152.156
[ndbd]
connect-string=192.168.152.156
[ndb_mgm]
connect-string=192.168.152.156
[ndb_mgmd]
config-file=/etc/mysql/config.ini
[mysqldump]
quick
max_allowed_packet = 24M
[mysql]
auto-rehash #使用TAB键自动补全
[mysqld_safe]
open-files-limit = 65536
管理节点(config.ini):
[ndbd default] #数据节点所有默认配置
NoOfReplicas=2 #一份数据在集群中的存在份数,与数据节点对应
DataMemory=80M #装载到内存中的数据大小
IndexMemory=18M #装载到内存中索引大小
ServerPort=2202 #默认端口
LockPagesInMainMemory=1 #将进程锁定在内存中,以避免与磁盘的交换
NoOfFragmentLogFiles=300 #设置节点的REDO日志文件的个数
DataDir=/usr/local/mysql/data #数据节点目录,包括集群日志文件,进程输出文件和守护进程的进程ID(PID)文件
MaxNoOfConcurrentOperations=100000 #设置事务中同时更新的最大记录数
MaxNoOfConcurrentTransactions=50000 #定义节点中最大事务数
ODirect=1 #开启这个设置会使内地版NDB尝试采用O_DIRECT写LCP、备份、重做日志,通常使用更少的内存和cpu。
SchedulerSpinTimer=400 #定义线程在进入睡眠状态之前多少毫秒被执行
SchedulerExecutionTimer=100 #定义线程在被发送前多少毫秒被执行
RealTimeScheduler=1 #设置ndbcluster线程启用真实时间的时序安排
TimeBetweenGlobalCheckpoints=1000
TimeBetweenEpochs=200
RedoBuffer=32M #设置redo日志缓存
MaxNoOfTables=1024 #该参数为作为整体的簇设置了最大表对象数目。该参数的默认值为128。最小值为8,最大值为20320,每个表对象每节点约需20KB的空间。
MaxNoOfOrderedIndexes=256 #设置哈希索引在系统中同意时间被使用的总数,该参数的默认值为128。
BackupMaxWriteSize=1M #设置备份日志和备份数据缓冲写入磁盘的默认大小
BackupDataBufferSize=16M #设置备份数据缓存的大小
BackupLogBufferSize=4M #设置备份日志缓存的大小
BackupMemory=20M #备份内存,该参数是BackupDataBufferSize和BackupLogBufferSize之和。
[tcp default]
SendBufferMemory=2M
ReceiveBufferMemory=2M
[ndb_mgmd] #管理节点
Nodeid=1
HostName=198.51.100.10 #IP或者hostname,管理节点
DataDir=/usr/local/mysql/data #数据文件存放目录
[ndbd] #数据节点节点1
HostName=198.51.100.30 #节点IP
NodeId=11 #节点ID
LockExecuteThreadToCPU=1
LockMaintThreadsToCPU=0
[ndbd] #数据节点节点2
HostName=198.51.100.40 #节点IP
NodeId=12
LockExecuteThreadToCPU=1
LockMaintThreadsToCPU=0
[mysqld] #sql节点1
Nodeid=21
HostName=198.51.100.20
[mysqld] #sql节点2
Nodeid=22
HostName=198.51.100.20
初始化数据库:
5.7之前:
mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data
5.7之后:
mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data
管理节点上进行初始化:
ndb_mgmd -f /var/lib/mysql-cluster/config.ini --ndb-nodeid=1 #指定config.ini文件位置,配置文件位置
数据节点上执行:
ndbd --ndbcluster
--ndbcluster(--initial):该NDBCLUSTER存储引擎是必要的使用NDB簇
SQL节点上执行:
service mysqld start
启动顺序:管理节点-->数据节点-->SQL节点
关闭集群,在管理节点上执行:
ndb_mgm -e shutdown
错误解决:
1、Mixing of localhost (default for [NDBD]HostName) with other hostname(192.168.152.156) is illegal
查找管理节点上config.ini文件中的[ndbd]模块,删除多余的。
2、Nodegroup 0 has 1 members, NoOfReplicas=2
编辑config.ini文件,修改参数:NoOfReplicas值修改为1。
3、数据节点链接不上
检查防火墙是否关闭,配置文件config.ini是否配置正确。
mysql cluster限制:
1、数据节点的节点ID范围必须是1-48 管理节点的节点ID在1-255 NDB群集中的最大节点总数为255 元数据最大数据量为20320
2、事物隔离级别只支持RC级别,当更新或删除多行数据时,可能会发生读已提交现象,这时必须使用当前读。
3、任何包含BLOB和TEXT的列,NDB引擎都会使用S锁来锁定改行,但是对于有索引的列,不会使用共享锁
4、错误会导致整个事物回滚
5、不适合处理大事物,因为会消耗更多的内存,本身NDB引擎是建立在内存上的
6、硬件机器必须是同一种体系结构
7、sql_log_bin对数据操作没有影响; 但是,它支持模式操作。NDB群集无法为具有BLOB列但没有主键的表生成二进制日志。
8、副本冗余数量为1时,数据丢失无法恢复,所以必须为2.
mysql cluster配置的更多相关文章
- MySQL Cluster 配置详细介绍
在上篇文章已经详细说明了MySQL Cluster搭建与测试,现在来说说详细的配置参数.在MySQL Cluster 环境的配置文件 config.ini 里面,每一类节点都有两个(或以上)的相应配置 ...
- MySQL Cluster配置概述
一. MySQL Cluster概述 MySQL Cluster 是一种技术,该技术允许在无共享的系统中部署“内存中”数据库的 Cluster .通过无共享体系结构,系统能够使用廉价的硬件,而 ...
- Mysql Cluster配置基本篇
一.下载mysql-cluster 从mysql官网下载对应的mysql-cluster 二.配置管理节点 1.解压mysql-cluster,找到解压文件中的ndb_mgm和ndb_mgmd 2.复 ...
- MySQL Cluster 7.3.5 集群配置参数优化(优化篇)
按照前面的教程:MySQL Cluster 7.3.5 集群配置实例(入门篇),可快速搭建起基础版的MySQL Cluster集群,但是在生成环境中,还是有很多问题的,即配置参数需要优化下, 当前生产 ...
- Windows Server 2008R2配置MySQL Cluster
目录 配置环境 相关知识 配置过程 配置 ini参数解释 启动集群 检查配置 同步测试 故障测试 写在之后 配置环境 VMware:(版本10.0.01) 操作系统:Windows Server 20 ...
- mysql cluster (mysql 集群)安装配置方案(转)
一.准备 1.准备服务器 计划建立有5个节点的MySQL CLuster体系,需要用到5台服务器,但是我们做实验时没有这么多机器,可以只用2台,我就是一台本机,一台虚拟机搭建了有5个节点的MySQL ...
- mysql cluster 安装配置方案
mysql cluster (mysql 集群)安装配置方案 一.准备 1.准备服务器 计划建立有5个节点的MySQL CLuster体系,需要用到5台服务器,但是我们做实验时没有这么多机器,可以 ...
- MySQL Cluster搭建与测试
MySQL Cluster是一个基于NDB Cluster存储引擎的完整的分布式数据库系统.不仅仅具有高可用性,而且可以自动切分数据,冗余数据等高级功能.和Oracle Real Cluster Ap ...
- MySQL Cluster 集群
本文转载 http://www.cnblogs.com/gomysql/p/3664783.html MySQL Cluster是一个基于NDB Cluster存储引擎的完整的分布式数据库系统.不仅仅 ...
随机推荐
- 微信公众号开发——获取access_token(PHP版)
access_token是调用微信接口的唯一凭据,每两小时刷新一次,我们需要每两小时就获取一次access_token. <?php class TokenUtil { //获取access_t ...
- HDU 2914 Triangle (Fibnacci 数)
题意:给你一个长度为 n 的木棒,求至少拿掉几根使得剩余的木棒构成不了三角形. 析:为了保证不形成三角形,所以保证两边之和等于最大边是最优,这不就是Fibnacci 数么,由于 n 很小,if-els ...
- ubuntu12.04中极品五笔简体繁体切换
不小心切换成了繁体,按Ctrl+:,可以切换回来.
- PCB Polar SI9000阻抗模型图片文字识别方法
用过Polar SI9000的都知道,阻抗模型图片可以进行用户鼠标交互,那么它的是如何实现的呢,下面就讲一下如何实现此功能的方法 一.看看Polar SI9000阻抗模型图片交互效果 鼠标点击阻抗 ...
- E20180207-ts
crumb n. 碎屑(尤指面包屑或糕饼屑); 面包心; 些许,少许; <俚>可鄙的人物;
- 'ALTER TABLE SWITCH' 语句失败。表'MGXXX.dbo.user_XXX' 已分区,但 索引'ix_user_XXX_user_id' 未分区。
问题描述: 今天在做分区切换的时候把旧log数据切到clear表,遇到了这个问题,顺便做下笔记记录一下解决方法 'ALTER TABLE SWITCH' 语句失败.表'MGXXX.dbo.user_X ...
- 关于element-ui的diallog拖动的实现
先给下载地址 https://files.cnblogs.com/files/maruihua/el-dragDialog.rar 需要注意的是如果给模态框加入拖动指令,一些定位样式会出问题,需谨慎 ...
- 专 linux命令之set x详解
set -x与set +x指令 用于脚本调试.set是把它下面的命令打印到屏幕 set -x 是开启 set +x是关闭 set -o是查看 (xtrace),set去追中一段代码的显示情况. 执 ...
- .NET通过字典给类赋值
/// <summary> /// /// </summary> /// <typeparam name="T"></typeparam& ...
- iOS开发 - CoreData框架 数据持久化
Core Data Core Data是iOS5之后才出现的一个框架,它提供了对象-关系映射(ORM)的功能,即能够将OC对象转化成数据,保存在SQLite数据库文件中,也能够将保存在数据库中的数据还 ...