使用mysqld_multi管理mysql的单机多实例

  • 下载mysql5.6.49源码,选source code和generic linux的。


  • 安装编译需要的包,之前源码编译redis的时候,已经安装了Development Tools,但是mysql还需要额外的一些包,下面这条命令中有些包已经安过就不会安装了
yum -y install make bison-devel ncures-devel libaio perl-Data-Dumper net-tools bison bison-devel gcc-c++ cmake ncurses ncurses-devel
  • 现在的mysql源码已经不通过./configure配置了,都用cmake配置,进入源码目录执行:

事先在/usr/local/mysql-5.6.40下创建3306、3307文件夹,存放两个实例的数据文件

cmake \
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql-5.6.40 \
-DMYSQL_DATADIR=/usr/local/mysql-5.6.40/3306 \
-DSYSCONFDIR=/usr/local/mysql-5.6.40 \
-DWITH_MYISAM_STORAGE_ENGINE=1 \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_MEMORY_STORAGE_ENGINE=1 \
-DWITH_READLINE=1 \
-DMYSQL_UNIX_ADDR=/usr/local/mysql-5.6.40/mysql.sock \
-DMYSQL_TCP_PORT=3306 \
-DENABLED_LOCAL_INFILE=1 \
-DWITH_PARTITION_STORAGE_ENGINE=1 \
-DEXTRA_CHARSETS=all \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci

# 参数含义:
# -DCMAKE_INSTALL_PREFIX=                   \    #安装路径  
# -DMYSQL_DATADIR=                          \    #默认数据文件存放位置  
# -DSYSCONFDIR=                             \    #默认my.cnf路径  
# -DWITH_MYISAM_STORAGE_ENGINE=1            \    #支持MyIASM引擎  
# -DWITH_INNOBASE_STORAGE_ENGINE=1          \    #支持InnoDB引擎  
# -DWITH_MEMORY_STORAGE_ENGINE=1            \    #支持Memory引擎  
# -DWITH_READLINE=1                         \    #快捷键功能(我没用过)  
# -DMYSQL_UNIX_ADDR=                        \    #默认连接数据库socket路径  
# -DMYSQL_TCP_PORT=3306                     \    #默认端口  
# -DENABLED_LOCAL_INFILE=1                  \    #允许从本地导入数据  
# -DWITH_PARTITION_STORAGE_ENGINE=1         \    #安装支持数据库分区  
# -DEXTRA_CHARSETS=all                      \    #安装所有的字符集  
# -DDEFAULT_CHARSET=utf8                    \    #默认字符  
# -DDEFAULT_COLLATION=utf8_general_ci  
  • make && make install,漫长的等待,安装完成后将/usr/local/mysql-5.6.40/bin加入PATH
  • 初始化两个实例的数据文件
./scripts/mysql_install_db --basedir=/usr/local/mysql-5.6.40 --datadir=/usr/local/mysql-5.6.40/3306 --user=mysql
./scripts/mysql_install_db --basedir=/usr/local/mysql-5.6.40 --datadir=/usr/local/mysql-5.6.40/3307 --user=mysql
  • 将support-files/my-default.cnf复制一份并改名为my.cnf到安装目录下,修改内容:

按照官网文档的配置是有问题的,官网里用password=root来指定root用户的密码,这样没法通过mysqld_multi stop关闭mysql实例,这是mysql的bug,15年就有人提出来了,现在也没修复,最后一条评论指出了用pass代替password的办法,具体可以来看mysql的bugs home。但是问题不大,就算用不了mysqls_multi控制多实例的关闭,可以一个一个关mysqladmin -u root shutdown -S 3306/mysql.sock -proot

[mysqld_multi]
mysqld = /usr/local/mysql-5.6.40/bin/mysqld_safe
mysqladmin = /usr/local/mysql-5.6.40/bin/mysqladmin
user = root
pass=root
log=/usr/local/mysql-5.6.40/mysql_multi.log 

[mysqld1]
basedir = /usr/local/mysql-5.6.40
datadir = /usr/local/mysql-5.6.40/3306
port = 3306
# server_id = .....
socket = /usr/local/mysql-5.6.40/3306/mysql.sock
pid-file = /usr/local/mysql-5.6.40/3306/mysql.pid
log_error = /usr/local/mysql-5.6.40/3306/error.log
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES 
character_set_server=utf8mb4
# 下面这三个参数mysql5.6默认很好,启动会占400m内存,对我的2g腾讯云压力太大了,设置成这样内存只占70m,而且网站流量不大,也够用了
performance_schema_max_table_instances=600
table_definition_cache=400
table_open_cache=256
[mysqld2]
basedir =  /usr/local/mysql-5.6.40
datadir = /usr/local/mysql-5.6.40/3307
port = 3307
# server_id = .....
socket = /usr/local/mysql-5.6.40/3307/mysql.sock
pid-file = /usr/local/mysql-5.6.40/3307/mysql.pid
log_error = /usr/local/mysql-5.6.40/3307/error.log
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
character_set_server=utf8mb4
performance_schema_max_table_instances=600
table_definition_cache=400
table_open_cache=256
  • 启动、关闭、查看状态
mysqld_multi start/stop/report 1,2
  • 成功启动之后要修改root的密码,登录的时候需要指定使用的sock文件
# 刚安完的mysql没有密码,直接回车就行
mysql -uroot -proot -S 3306/mysql.sock
# 登陆后设置root的密码
set password=password('你的密码');
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,744评论 6 502
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,505评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,105评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,242评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,269评论 6 389
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,215评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,096评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,939评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,354评论 1 311
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,573评论 2 333
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,745评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,448评论 5 344
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,048评论 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,683评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,838评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,776评论 2 369
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,652评论 2 354