所谓多实例,就是在一台服务器上搭建、运行多个mysql实例,每个实例使用不同的服务端口,通过不同的socket监听;物理上,每个实例
所谓多实例,就是在一台服务器上搭建、运行多个mysql实例,每个实例使用不同的服务端口,通过不同的socket监听;物理上,每个实例拥有独立的参数配置文件及数据库。
通常情况下,一台服务器是不建议运行多个mysql实例的,尤其是生产环境,因为这会造成资源相互强占问题。但在一些高可用环境中,却有这样的需求,比如:利用heartbeat搭建的故障转移集群环境,若主备服务器只运行一个mysql实例,则备用服务器平常处于闲置状态,造成了资源浪费;若各自运行一个mysql实例,则在一方故障时,要求另一方接管其任务,即同时运行两个mysql实例。基于这个需求,应合理配置mysql服务器,使其具备同时运行多个实例的能力。
如何才能在一台服务器上搭建、运行多个mysql实例,其关键在于如何为每个实例分配独立的参数文件,以下是几种常用的多实例方案,分别来学习、熟悉一下。
ubuntu 14.04下安装mysql
《mysql权威指南(原书第2版)》清晰中文扫描版 pdf
ubuntu 14.04 lts 安装 lnmp nginx\php5 (php-fpm)\mysql
ubuntu 14.04下搭建mysql主从服务器
ubuntu 12.04 lts 构建高可用分布式 mysql 集群
ubuntu 12.04下源代码安装mysql5.6以及python-mysqldb
系统环境
os:centos 5.8 (x86_64) 内核:2.6.18-308.el5 db:mysql 5.5.17
一. 采用源码包安装mysql实现多实例
源码包是最灵活的安装包,可定制编译一些路径参数,可安装到任何路径,因此可在一台服务器搭建多个mysql实例。本例安装两个mysql实例,步骤如下:
1. 准备工作
从mysql 5.5开始,改用cmake工具来编译源码包,所以要首先安装它,可参考其它文档,此处不做讲解。另外,编译之前还需安装ncurses-devel、bison两个依赖包,否则会编译失败。
――安装依赖包
# rpm -ivh ncurses-devel-5.5-24.20060715.x86_64.rpm
# rpm -ivh bison-2.3-2.1.x86_64.rpm
――创建mysql系统组及用户
# groupadd -g 497 mysql
# useradd –u 499 -g mysql mysql
――解压安装包
# tar -zxvf mysql-5.5.17.tar.gz
# cd mysql-5.5.17
2. 编译、安装
l mysql实例1:
(端口:3306,安装目录:/usr/local/mysqla,数据文件目录:/data/lib/mysqla)
――定制编译
# cmake -dcmake_install_prefix=/usr/local/mysqla-dmysql_tcp_port=3306 -dmysql_datadir=/data/lib/mysqla-dmysql_unix_addr=/data/lib/mysqla/mysql.sock -dsysconfdir=/usr/local/mysqla-dwith_myisam_storage_engine=1 -dwith_innobase_storage_engine=1-dwith_archive_storage_engine=1 -dwith_blackhole_storage_engine=1-dwith_partition_storage_engine=1 -denabled_local_infile=1 -dwith_readline=1-dwith_ssl=yes -ddefault_charset=utf8 -ddefault_collation=utf8_general_ci-dextra_charsets=all
# make
# make install
――创建系统数据库及系统表
# cd /usr/local/mysqla/
# scripts/mysql_install_db --user=mysql--basedir=/usr/local/mysqla --datadir=/data/lib/mysqla
l mysql实例2:
(端口:3307,安装目录:/usr/local/mysqlb,数据文件目录:/data/lib/mysqlb)
――删除旧的缓存及对象文件
再次编译之前,要清除原来的缓存信息及对象文件,,如下:
# cd mysql-5.5.17
# make clean
# rm -rf cmakecache.txt
――定制编译
# cmake -dcmake_install_prefix=/usr/local/mysqlb-dmysql_tcp_port=3307 -dmysql_datadir=/data/lib/mysqlb-dmysql_unix_addr=/data/lib/mysqlb/mysql.sock -dsysconfdir=/usr/local/mysqlb-dwith_myisam_storage_engine=1 -dwith_innobase_storage_engine=1-dwith_archive_storage_engine=1 -dwith_blackhole_storage_engine=1-dwith_partition_storage_engine=1 -denabled_local_infile=1 -dwith_readline=1-dwith_ssl=yes -ddefault_charset=utf8 -ddefault_collation=utf8_general_ci-dextra_charsets=all
# make
# make install
――创建系统数据库及系统表
# cd /usr/local/mysqlb/
# scripts/mysql_install_db --user=mysql--datadir=/data/lib/mysqlb
更多详情见请继续阅读下一页的精彩内容: