MySQL 5.5.x 单机多实例配置实践
转自:http://heylinux.com/archives/1689.html
背景/需求:
在一台服务器上通过源码编译安装一个版本为5.5以上的MySQL数据库;
将所有配置文件与数据等均存放在/opt/mysql,便于今后实现快速迁移、整体备份和快速复制;
在同一个MySQL中运行两个实例,一个绑定在端口3306,另一个绑定在端口3307;
绑定在3306端口的实例,不开启binlog,数据存放在/opt/mysql/data;
绑定在3307端口的实例,开启binlog,数据存放在/opt/mysql/data2;
两个实例均采用InnoDB作为默认的存储引擎,字符编码采用UTF-8;
两个实例均采用相同的性能优化配置参数;
实践/方案:
在编译安装时,将数据库的配置文件my.cnf以及data目录等均指向到/opt/mysql目录;
通过mysqld_multi的方式来管理两个不同的实例,采用相同的配置文件共享性能优化配置参数;
在同一个配置文件中,利用[mysqld1]与[mysqld2]标签实现不同实例的差异化配置配置步骤:
一、编译安装MySQL
1.安装cmake
MySQL从5.5版本开始,通过./configure进行编译配置方式已经被取消,取而代之的是cmake工具。
因此,我们首先要在系统中源码编译安装cmake工具,因为这个工具类似于系统环境增强,所以默认安装即可.
# wget http://www.cmake.org/files/v2.8/cmake-2.8.4.tar.gz
# tar zxvf cmake-2.8.4.tar.gz
# cd cmake-2.8.4
# ./configure
# make
# make install
2.确保以下所需系统软件包已经被安装
通过 rpm -qa | grep name 的方式验证以下软件包是否已全部安装。
gcc* gcc-c++* autoconf* automake* zlib* libxml* ncurses-devel* libgcrypt* libtool*
如果缺少相关的软件包,可通过yum -y install 的方式在线安装,或直接从系统安装光盘中找到并通过rpm -ivh 的方式安装。
3. 安装前的系统设置
建立mysql安装目录及数据存放目录
# mkdir -p /export/servers/mysql/data
创建用户和用户组
# groupadd mysql
# useradd -g mysql mysql
赋予数据存放目录权限
# chown mysql:mysql -R /export/servers/mysql/data
4.开始编译安装 MySQL
通过http://www.mysql.com/downloads/mysql官方网址或国内的sohu镜像下载软件包,如目前最新的MySQL 5.5.20。
1 # wget http://mirrors.sohu.com/mysql/MySQL-5.5/mysql-5.5.20.tar.gz 2 3 # tar zxvf mysql-5.5.20.tar.gz 4 5 # cd mysql-5.5.20 6 # cmake -DCMAKE_INSTALL_PREFIX=/export/servers/mysql \ 7 -DSYSCONFDIR=/export/servers/mysql/etc \ 8 -DMYSQL_DATADIR=/export/servers/mysql/data \ 9 -DMYSQL_TCP_PORT=3306 \ 10 -DMYSQL_UNIX_ADDR=/tmp/mysqld.sock \ 11 -DMYSQL_USER=mysql \ 12 -DEXTRA_CHARSETS=all \ 13 -DWITH_READLINE=1 \ 14 -DWITH_SSL=system \ 15 -DWITH_EMBEDDED_SERVER=1 \ 16 -DENABLED_LOCAL_INFILE=1 \ 17 -DWITH_INNOBASE_STORAGE_ENGINE=1 18 19 # make 20 # make install
在make与make install的时候可以看到进度百分比,感觉这一点要比configure方式要好。
注意,如果提示:
Linking C shared module adt_null.so [ 65%] Built target audit_null Scanning dependencies of target vio [ 65%] Building C object vio/CMakeFiles/vio.dir/vio.c.o [ 65%] Building C object vio/CMakeFiles/vio.dir/viosocket.c.o [ 65%] Building C object vio/CMakeFiles/vio.dir/viossl.c.o /root/mysql-5.5.36/vio/viossl.c: In function ‘ssl_do’: /root/mysql-5.5.36/vio/viossl.c:175: error: ‘SSL_OP_NO_COMPRESSION’ undeclared (first use in this function) /root/mysql-5.5.36/vio/viossl.c:175: error: (Each undeclared identifier is reported only once /root/mysql-5.5.36/vio/viossl.c:175: error: for each function it appears in.) make[2]: *** [vio/CMakeFiles/vio.dir/viossl.c.o] Error 1 make[1]: *** [vio/CMakeFiles/vio.dir/all] Error 2 make: *** [all] Error 2
是因为openssl版本太低导致请升级之,参见: http://www.cnblogs.com/onmyway20xx/p/3654577.html
二、创建支持多实例的配置文件
进入MySQL主目录
# cd /export/servers/mysql
删除默认的data目录
# rm -rf data
创建需要的目录
# mkdir etc tmp run log binlogs data data2
# chown -R mysql:mysql tmp run log binlogs data data2
创建my.cnf配置文件
# vim etc/my.cnf,粘帖以下内容
三、初始化数据库
切换到mysql用户
# su - mysql
进入MySQL主目录
# cd /opt/mysql/
初始化实例[mysqld1]
# scripts/mysql_install_db --basedir=/opt/mysql --user=mysql --datadir=/opt/mysql/data/
初始化实例[mysqld2]
# scripts/mysql_install_db --basedir=/opt/mysql --user=mysql --datadir=/opt/mysql/data2/
返回到root
# exit
创建mysqld_multi.server脚本
# cp support-files/mysqld_multi.server /opt/mysql/init.d/
# vim /opt/mysql/init.d/mysqld_multi.server
#!/bin/sh # A simple startup script for mysqld_multi by Tim Smith and Jani Tolonen. # This script assumes that my.cnf file exists either in /etc/my.cnf or # /root/.my.cnf and has groups [mysqld_multi] and [mysqldN]. See the # mysqld_multi documentation for detailed instructions. # # This script can be used as /etc/init.d/mysql.server # # Comments to support chkconfig on RedHat Linux # chkconfig: 2345 64 36 # description: A very fast and reliable SQL database engine. # # Version 1.0 # 修改这个地方 为如下内容 basedir=/export/servers/mysql bindir=/export/servers/mysql/bin conf=/export/servers/mysql/etc/my.cnf #添加此行 export PATH=$PATH:$bindir if test -x $bindir/mysqld_multi then mysqld_multi="$bindir/mysqld_multi"; else echo "Can't execute $bindir/mysqld_multi from dir $basedir"; exit; fi case "$1" in 'start' ) "$mysqld_multi" --defaults-extra-file=$conf start $2 ;; 'stop' ) "$mysqld_multi" --defaults-extra-file=$conf stop $2 ;; 'report' ) "$mysqld_multi" --defaults-extra-file=$conf report $2 ;; 'restart' ) "$mysqld_multi" --defaults-extra-file=$conf stop $2 "$mysqld_multi" --defaults-extra-file=$conf start $2 ;; *) echo "Usage: $0 {start|stop|report|restart}" >&2 ;; esac
备份完成后,直接将mysql_5.5.20_full.tar.gz拿到其他服务器上,解压后便可以直接启用。
五、管理MySQL实例
同时 启动/关闭 实例 [mysqld1] 与 [mysqld2]:
# /opt/mysql/init.d/mysqld_multi.server start 1,2
然后,可以看到两个MySQL实例都已经成功的启动了。
# netstat -lntp | grep mysqld
同时 关闭 实例 [mysqld1] 与 [mysqld2]:
# /opt/mysql/init.d/mysqld_multi.server stop 1,2
仅 启动/关闭 实例[mysqld1]:
# /opt/mysql/init.d/mysqld_multi.server start 1
# /opt/mysql/init.d/mysqld_multi.server stop 1
六、登陆MySQL实例
在启动了实例[mysqld1]与[mysqld2]后,通过以下方式登陆不同的实例:
在启动了实例[mysqld1]与[mysqld2]后,通过以下方式登陆不同的实例:
登陆[mysqld1]:
# mysql -S /export/servers/mysql/run/mysqld.sock1 -u root -p
登陆[mysqld2]:
# mysql -S /export/servers/mysql/run/mysqld.sock1 -u root –p
注意,此处由于我们自定义了sock的位置,所以需要加上S的参数来指定对应的sock位置.
七、其他初始化设置
1. 为MySQL的root帐户设置初始密码
# /opt/mysql/bin/mysqladmin -u root -h127.0.0.1 -P3306 password 'new-password'
# /opt/mysql/bin/mysqladmin -u root -h127.0.0.1 -P3307 password 'new-password'
2. 删除匿名连接的空密码帐号
分别登陆实例[mysqld1]与[mysqld2],执行以下命令:
mysql>use mysql; //选择系统数据库mysql
mysql>select Host,User,Password from user; //查看所有用户
mysql>delete from user where password="";
mysql>flush privileges; //刷新权限
mysql>select Host,User,Password from user; //确认密码为空的用户是否已全部删除
mysql>exit;
八、经验总结
1.采用源码编译安装MySQL,可能在第一次会花费较多的时间,但却是非常值得的,因为我们可以自己组织所有MySQL相关文件的位置;并且经过源码编译安装后的MySQL,
可以直接复制到其它服务器上运行,大大方便了我们今后的迁移、备份和新服务器的配置;
2.本文中仅仅用了两个实例[mysqld1]与[mysqld2]来举例,实际上我们可以通过这样的方式,实现[mysqld3],[mysqld4],[mysqld5]...等更多的实例;
3.MySQL自带了几个不同的配置文件,放置在/opt/mysql/support-files目录下,分别是my-huge.cnf,my-innodb-heavy-4G.cnf,my-large.cnf,my-medium.cnf,my-small.cnf,通过名称我们可以很直观的了解到他们是针对不同的服务器配置的,本文中仅有的一点关于InnoDB的配置,是取自于my-small.cnf的,因为我是在虚拟机上进行的设置;在生产环境中,我们可以通过参考my-huge.cnf或my-innodb-heavy-4G.cnf中的部分参数配置,来对服务器进行优化;
4.关于MySQL缓存参数的优化,主要用于提升I/O能力,可以参考这里:http://heylinux.com/archives/1389.html
5.在单机运行多实例的情况下,切忌使用 mysql -hlocalhost 或 直接忽略-h参数 登陆服务器,这应该算是MySQL的一个bug,就是如果使用localhost或忽略-h参数,而不是指定127.0.0.1的话,即使选择的端口是3307,还是会登陆到3306中去,因此应尽量避免这种混乱的产生,统一用127.0.0.1绑定端口 或 采用socket 来登陆;