mysql 多实例案例实战

其实Mysql多实例就是在一个 mysql 服务上面启动三个实例,相当于三个分离开来的数据库,至于为什么要做这个,你也可以选择分别安装三个MySQL,只是过于麻烦,多实例中只需要一个配置档my.cnf,并且通过mysql_330x.sock 便于管理数据库。

其实MySQL多实例之后也可以做主从同步及读写分离,跟原来是一样的,只是同步的时候端口有变化而已~

下面我来做MySQL多实例的环境搭建,至于如何用,怎么用,那就看你需求了



安装简介

  • 用户名:mysql
  • 安装目录:/usr/local/mysql
  • 实例1数据目录 : /usr/local/mysql/data/dbdata_3306
  • 实例2数据目录 : /usr/local/mysql/data/dbdata_3307
  • 实例3数据目录 : /usr/local/mysql/data/dbdata_3308

安装前步骤

一、添加MySQL用户
groupadd mysql
useradd -g mysql -s /sbin/nologin mysql

二、yum安装依赖包
autoconf automake bc bind-utils bzip2 bzip2-devel curl curl-devel dmidecode e2fsprogs-devel expat expat-devel freetype* gcc gcc-c++ gettext gettext-devel glib2 glib2-devel glibc glibc-devel hdparm krb5-devel libaio libaio-devel libidn-devel libjpeg libpng libxml2 libxml2-devel lrzsz mlocate ncurses ncurses-devel net-snmp net-snmp-devel net-snmp-libs net-snmp-utils ntp openssh-clients openssl-devel pam-devel rsync rsyslog-relp screen smartmontools strace sysstat telnet vim* vixie-cron wget yum-fastestmirror zip zlib-devel

三、解包
tar zxf mysql-5.6.14.tar.gz -C /usr/src
cd /usr/src/mysql-5.6.14

四、创建数据目录
mkdir -p /usr/local/mysql/data

五、cmake配置
cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_MYISAM_STORAGE_ENGING=1 -DWITH_INNOBASE_STORAGE_ENGING=1 -DWITH_SSL=yes

六、编译及安装
make && make install

七、拷贝配置文件
cp support-files/my-default.cnf /usr/local/mysql/data/my.cnf

八、初始化数据库

/usr/local/mysql/scripts/mysql_install_db --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data/dbdata_3306 --user=mysql/usr/local/mysql/scripts/mysql_install_db --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data/dbdata_3307 --user=mysql/usr/local/mysql/scripts/mysql_install_db --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data/dbdata_3308 --user=mysql

九、设置链接
ln -s /usr/local/mysql/bin/* /usr/local/bin/
ln -s /usr/local/mysql/include/mysql/* /usr/include/
ln -s /usr/local/mysql/lib/* /usr/lib/
rm -rf /etc/my.cnf
ln -s /usr/local/mysql/data/my.cnf /etc/

十、设置权限
chown -R mysql:mysql /usr/local/mysql/data/dbdata_3306
chown -R mysql:mysql /usr/local/mysql/data/dbdata_3307
chown -R mysql:mysql /usr/local/mysql/data/dbdata_3308

十一、修改my.cnf配置

#!/bin/bash[mysqld_multi]mysqld = /usr/local/mysql/bin/mysqld_safemysqladmin = /usr/local/mysql/bin/mysqladminuser = rootpassword = yunjee0515ueopro1234[mysqld1]basedir = /usr/local/mysqlcharacter-set-server = utf8port = 3306socket = /tmp/mysql_3306.sockdatadir = /usr/local/mysql/data/dbdata_3306pid-file = /usr/local/mysql/data/dbdata_3306/mysql.pidlog-error = /usr/local/mysql/data/dbdata_3306/mysql.errserver-id = 1skip-character-set-client-handshake                                     #忽略应用程序想要设置的其他字符集init-connect=‘SET NAMES utf8‘                                           #连接时执行的SQLcharacter-set-server=utf8                                               #服务端默认字符集wait_timeout=1800                                                       #请求的最大连接时间interactive_timeout=1800                                                #和上一参数同时修改才会生效sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES                     #sql模式log-bin = mysql-bin                                                     #打开二进制功能,MASTER主服务器必须打开此项relay-log = mysql-bin                                                   #文件名格式relay-log-index = mysql-bin.index                                       #index文件名##MySQL 5.6.10版本提供了更方便的基于GTID的复制功能,MySQL可以通过GTID自动识别上次同步的点,极大地方便了运维人员,减少出错的几率。binlog-format=ROW                                                       #binlog格式log-slave-updates=true                                                  #表示如果一个MASTER挂掉的话,另外一个马上接管gtid-mode=on                                                            #用于启动GTID及满足附属的其它需求enforce-gtid-consistency=true                                           ##report-port=port                           #从属服务器的端口#report-host=host                           #从属服务器的主机名master-info-repository=TABLE                                            #启用此两项,可用于实现在崩溃时保证二进制及从服务器安全的功能relay-log-info-repository=TABLE                                         #sync-master-info=1                                                      #启用之可确保无信息丢失slave-parallel-workers=2                                                #设定从服务器的SQL线程数;0表示关闭多线程复制功能binlog-checksum=CRC32                                                   #master-verify-checksum=1                                                #slave-sql-verify-checksum=1                                             #启用复制有关的所有校验功能binlog-rows-query-log_events=1                                          ###MySQL 5.6.10版本提供了更方便的基于GTID的复制功能,MySQL可以通过GTID自动识别上次同步的点,极大地方便了运维人员,减少出错的几率。expire_logs_day=5                           #超过5天的binlog删除  max_binlog_size=104857600#replicate-ignore-db = mysql                        #忽略不同步主从的数据库#replicate-ignore-db = information_schema#replicate-ignore-db = performance_schema#replicate-ignore-db = test#replicate-ignore-db = zabbix#replicate-ignore-db = sysbench#replicate-ignore-db = db_3306##slave-skip-errors=0                           #主从忽略错误数##注释掉,使用默认设置#skip-external-locking##innodb_force_recovery = 1key_buffer_size = 256Mmax_allowed_packet = 100M#table_open_cache = 1024#sort_buffer_size = 128M#net_buffer_length = 8K#read_buffer_size = 128M#read_rnd_buffer_size = 256M#myisam_sort_buffer_size = 32M#character-set-server = utf8skip-name-resolvemax_connections = 10000##慢查询设置slow-query-log=onlong_query_time = 2#log-queries-not-using-indexes##注释掉,使用默认设置## For InnoDBinnodb_buffer_pool_size = 1G#innodb_additional_mem_pool_size = 128M## Set .._log_file_size to 25 % of buffer pool size#innodb_log_file_size = 128M#innodb_log_buffer_size = 8Minnodb_flush_log_at_trx_commit = 1#innodb_lock_wait_timeout = 50#innodb_file_per_table=1[mysqld2]basedir = /usr/local/mysqlcharacter-set-server = utf8port = 3307socket = /tmp/mysql_3307.sockdatadir = /usr/local/mysql/data/dbdata_3307pid-file = /usr/local/mysql/data/dbdata_3307/mysql.pidlog-error = /usr/local/mysql/data/dbdata_3307/mysql.errserver-id = 1skip-character-set-client-handshake                                     #忽略应用程序想要设置的其他字符集init-connect=‘SET NAMES utf8‘                                           #连接时执行的SQLcharacter-set-server=utf8                                               #服务端默认字符集wait_timeout=1800                                                       #请求的最大连接时间interactive_timeout=1800                                                #和上一参数同时修改才会生效sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES                     #sql模式log-bin = mysql-bin                                                     #打开二进制功能,MASTER主服务器必须打开此项relay-log = mysql-bin                                                   #文件名格式relay-log-index = mysql-bin.index                                       #index文件名#MySQL 5.6.10版本提供了更方便的基于GTID的复制功能,MySQL可以通过GTID自动识别上次同步的点,极大地方便了运维人员,减少出错的几率。binlog-format=ROW                                                       #binlog格式log-slave-updates=true                                                  #表示如果一个MASTER挂掉的话,另外一个马上接管gtid-mode=on                                                            #用于启动GTID及满足附属的其它需求enforce-gtid-consistency=true                                           ##report-port=port                                                       #从属服务器的端口#report-host=host                                                       #从属服务器的主机名master-info-repository=TABLE                                            #启用此两项,可用于实现在崩溃时保证二进制及从服务器安全的功能relay-log-info-repository=TABLE                                         #sync-master-info=1                                                      #启用之可确保无信息丢失slave-parallel-workers=2                                                #设定从服务器的SQL线程数;0表示关闭多线程复制功能binlog-checksum=CRC32                                                   #master-verify-checksum=1                                                #slave-sql-verify-checksum=1                                             #启用复制有关的所有校验功能binlog-rows-query-log_events=1                                          ###MySQL 5.6.10版本提供了更方便的基于GTID的复制功能,MySQL可以通过GTID自动识别上次同步的点,极大地方便了运维人员,减少出错的几率。expire_logs_day=5                                                       #超过5天的binlog删除max_binlog_size=104857600#replicate-ignore-db = mysql                                             #忽略不同步主从的数据库#replicate-ignore-db = information_schema#replicate-ignore-db = performance_schema#replicate-ignore-db = test#replicate-ignore-db = zabbix#replicate-ignore-db = sysbench#replicate-ignore-db = db_3307##slave-skip-errors=0                                                   #主从忽略错误数##注释掉,使用默认设置#skip-external-locking##innodb_force_recovery = 1key_buffer_size = 256Mmax_allowed_packet = 100M#table_open_cache = 1024#sort_buffer_size = 128M#net_buffer_length = 8K#read_buffer_size = 128M#read_rnd_buffer_size = 256M#myisam_sort_buffer_size = 32M#character-set-server = utf8skip-name-resolvemax_connections = 10000##慢查询设置slow-query-log=onlong_query_time = 2#log-queries-not-using-indexes##注释掉,使用默认设置## For InnoDBinnodb_buffer_pool_size = 1G#innodb_additional_mem_pool_size = 128M## Set .._log_file_size to 25 % of buffer pool size#innodb_log_file_size = 128M#innodb_log_buffer_size = 8Minnodb_flush_log_at_trx_commit = 1#innodb_lock_wait_timeout = 50#innodb_file_per_table=1[mysqld3]basedir = /usr/local/mysqlcharacter-set-server = utf8port = 3308socket = /tmp/mysql_3308.sockdatadir = /usr/local/mysql/data/dbdata_3308pid-file = /usr/local/mysql/data/dbdata_3308/mysql.pidlog-error = /usr/local/mysql/data/dbdata_3308/mysql.errserver-id = 1skip-character-set-client-handshake                                     #忽略应用程序想要设置的其他字符集init-connect=‘SET NAMES utf8‘                                           #连接时执行的SQLcharacter-set-server=utf8                                               #服务端默认字符集wait_timeout=1800                                                       #请求的最大连接时间interactive_timeout=1800                                                #和上一参数同时修改才会生效sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES                     #sql模式log-bin = mysql-bin                                                     #打开二进制功能,MASTER主服务器必须打开此项relay-log = mysql-bin                                                   #文件名格式relay-log-index = mysql-bin.index                                       #index文件名#MySQL 5.6.10版本提供了更方便的基于GTID的复制功能,MySQL可以通过GTID自动识别上次同步的点,极大地方便了运维人员,减少出错的几率。binlog-format=ROW                                                       #binlog格式log-slave-updates=true                                                  #表示如果一个MASTER挂掉的话,另外一个马上接管gtid-mode=on                                                            #用于启动GTID及满足附属的其它需求enforce-gtid-consistency=true                                           ##report-port=port                                                       #从属服务器的端口#report-host=host                                                       #从属服务器的主机名master-info-repository=TABLE                                            #启用此两项,可用于实现在崩溃时保证二进制及从服务器安全的功能relay-log-info-repository=TABLE                                         #sync-master-info=1                                                      #启用之可确保无信息丢失slave-parallel-workers=2                                                #设定从服务器的SQL线程数;0表示关闭多线程复制功能binlog-checksum=CRC32                                                   #master-verify-checksum=1                                                #slave-sql-verify-checksum=1                                             #启用复制有关的所有校验功能binlog-rows-query-log_events=1                                          ###MySQL 5.6.10版本提供了更方便的基于GTID的复制功能,MySQL可以通过GTID自动识别上次同步的点,极大地方便了运维人员,减少出错的几率。expire_logs_day=5                                                       #超过5天的binlog删除max_binlog_size=104857600#replicate-ignore-db = mysql                                             #忽略不同步主从的数据库#replicate-ignore-db = information_schema#replicate-ignore-db = performance_schema#replicate-ignore-db = test#replicate-ignore-db = zabbix#replicate-ignore-db = sysbench#replicate-ignore-db = db_3308##slave-skip-errors=0                                                   #主从忽略错误数##注释掉,使用默认设置#skip-external-locking##innodb_force_recovery = 1key_buffer_size = 256Mmax_allowed_packet = 100M#table_open_cache = 1024#sort_buffer_size = 128M#net_buffer_length = 8K#read_buffer_size = 128M#read_rnd_buffer_size = 256M#myisam_sort_buffer_size = 32M#character-set-server = utf8skip-name-resolvemax_connections = 10000##慢查询设置slow-query-log=onlong_query_time = 2#log-queries-not-using-indexes##注释掉,使用默认设置## For InnoDBinnodb_buffer_pool_size = 1G#innodb_additional_mem_pool_size = 128M## Set .._log_file_size to 25 % of buffer pool size#innodb_log_file_size = 128M#innodb_log_buffer_size = 8Minnodb_flush_log_at_trx_commit = 1#innodb_lock_wait_timeout = 50#innodb_file_per_table=1[mysqldump]quickmax_allowed_packet = 256M[mysql]no-auto-rehashprompt=\\[email protected]\\d \\R:\\m># Remove the next comment character if you are not familiar with SQL#safe-updates[myisamchk]key_buffer_size = 512Msort_buffer_size = 512Mread_buffer = 8Mwrite_buffer = 8M[mysqlhotcopy]interactive-timeout

十二、启动所有实例

/usr/local/mysql/bin/mysqld_multi start 1

/usr/local/mysql/bin/mysqld_multi start 2

/usr/local/mysql/bin/mysqld_multi start 3

登录MySQL多实例
mysql -uroot -S /tmp/mysql_3306.sock

mysql -uroot -S /tmp/mysql_3307.sock

mysql -uroot -S /tmp/mysql_3308.sock

并且修改各自的密码为my.cnf配置档中[mysqld_multi]中指定的密码。

[email protected](none) 16:09>grant all privileges on *.* to [email protected]‘localhost‘ identified by ‘password‘;[email protected](none) 16:09>grant all privileges on *.* to [email protected]‘127.0.0.1‘ identified by ‘password‘;[email protected](none) 16:09>grant all privileges on *.* to [email protected]‘%‘ identified by ‘password‘;

其实这里有一点问题,就是[mysqld_multi]中设置的账户,其实它是用来管理mysqld_multi(多实例进程的启动与关闭)的,如果这边的账户和当前库(实例中的所有库)的账户不匹配,则会发生一些奇怪的问题,例如你可以开启这个mysql多实例进程,但无法关闭,甚至是kill ${PID}之后它又会重新启动。

那么,以后就可以通过下面方式来连接MySQL了

mysql -uroot -ppassword -S /tmp/mysql_3306.sockmysql -uroot -ppassword -S /tmp/mysql_3307.sockmysql -uroot -ppassword -S /tmp/mysql_3308.sock

原文地址:https://www.cnblogs.com/jpfss/p/8143564.html

时间: 2024-10-10 15:54:19

mysql 多实例案例实战的相关文章

02.mysql多实例安装实战

2.1 什么是mysql多实例? 简单的说,mysql 多实例就是在一台服务器上同时开启多个不同的服务端口(如 3306. 3307),同时运行多个 mysql 服务进程,这些服务进程通过不同的 socket 监听不同的服务端 口来提供服务 这些 mysql 多实例公用一套 mysql 安装程序,使用不同的 my.cnf(也可以相同)配置 文件.启动程序(也可以相同)和数据文件,在提供服务时,多实例 mysql 在逻辑上看来是各自独立的,他们根据配置文件的对应设定值,获得服务器相应数量的硬件资源

Innobackup mysql 多实例环境搭建主从同步

Innobackup mysql 多实例环境搭建主从同步 该实验是在mysql多实例环境下做的:如果需要部署 mysql 多实例环境,则移步: mysql 多实例案例实战: http://blog.csdn.net/wanglei_storage/article/details/49305239 mysql 的主从搭建大家有很多种方式,传统的 mysqldump 方式是很多人的选择之一.但对于较大的数据库则该方式并非理想的选择.使用 Xtrabackup 可以快速轻松的构建 mysql 主从架构

MySQL多实例-精典故障案例

很久以前搭建过MySQL多实例,记得当时很顺利,呵呵!今天公司因为业务需要,我再一次搭建多实例.安装完MySQL后,初始化两个实例时,出现如下报错: 150915  1:10:36 [ERROR] COLLATION 'utf8_general_ci' is not valid for CHARACTER SET 'latin1'      150915  1:10:36 [ERROR] Aborting 乍一看,是字符编码问题,着实在my.cnf配置文件上面设置了字符编码如下: [client

MySQL单机多实例配置实战

本文主要介绍在CentOS6.9下快速安装和部署MySQL多实例 基本流程: 1.Mysql多实例介绍 2.安装MySQL多实例 3.创建MySQL多实例的数据文件目录以及配置文件 4.创建MySQL多实例的启动文件 5.配置文件权限和软链接 6.初始化MySQL多实例的数据库文件 7.启动MySQL多实例数据库 8.配置和管理MySQL多实例数据库 流程一:Mysql多实例介绍 简单的说,Mysql多实例就是在一台服务器上同时开启多个不同的服务端口(如 : 3306/3307/3308)同时运

MySQL数据库基础(3)多实例应用实战

一.什么是MySQL多实例? 简单的说,就是在一台机器上开启多个不同的服务端口(如:3306,3307),运行多个MySQL服务进程,这些服务进程通过不同的socket监听不同的服务端口来提供各自的服务. 共用一套MySQL安装程序 使用不同(也可以相同)的my.cnf配置文件.启动程序.数据文件 作个比喻,MySQL多实例相当于房子的多个卧室一样,每个势力可以看做一个卧室,整个服务器就是一套房子.逻辑上是独立的,但是互相会有影响. 二.多实例的作用与问题 1.有效利用服务器资源 当单个服务器资

精通MySQL多实例配置

MySQL多实例实战案例 [[email protected] ~]# mkdir -p /data/{3306,3307}/data [[email protected] ~]# tree /data/ /data/ 多实例根目录 |-- 3306 3306实例的目录 |   `-- data 3306实例的数据文件目录 `-- 3307 3307 实例的目录 `-- data 3307实例的数据文件目录 4 directories, 0 files [[email protected] ~]

Power BI教程_Power BI数据分析快速上手及案例实战

Power BI数据分析快速上手及案例实战 课程学习地址:http://www.xuetuwuyou.com/course/194 课程出自学途无忧网:http://www.xuetuwuyou.com 课程简介 本课程在<Power BI 数据分析快速上手>基础上结合大量的实例,深入讲解PowerBI中看似难懂的各种概念.操作, 并结合行业中的典型案例贯穿了从初级的数据透视表工具.数据透视表选项.数据透视表的刷新.数据透视表中的排序,到中级的动 态数据透视表的创建.数据透视表函数 GETPI

第85课:基于HDFS的SparkStreaming案例实战和内幕源码解密

一:Spark集群开发环境准备 启动HDFS,如下图所示: 通过web端查看节点正常启动,如下图所示: 2.启动Spark集群,如下图所示: 通过web端查看集群启动正常,如下图所示: 3.启动start-history-server.sh,如下图所示: 二:HDFS的SparkStreaming案例实战(代码部分) package com.dt.spark.SparkApps.sparkstreaming; import org.apache.spark.SparkConf; import o

mysql 多实例应用配置部署指南

一,Mysql 多实例的作用的问题 1,有效利用服务器的资源 当单个服务器资源有剩余的时候,可以充分利用剩余的资源以提供更多的服务 2,节约服务器的资源 当公司资源紧张,但是数据库各自需要独立提供服务,而且需要主从同步等技术时候,此时使用多实例是最好的. 3,资源互相抢占的问题 当某个服务实例并发很高或者有慢查询的时候,整个实例会消耗更多的CPU,内存,磁盘IO资源,导致服务器上其他的实例提供的服务质量大大下降,相当于一个大房子,多个卧室,大家共用一个卫生间,早餐起床,一个人上厕所,长期占用,其