本次配置采用cmake编译安装的mysql进行多实例的配置,使用不同的配置文件进行的配置,大体步骤分为以下:
安装MySQL软件
创建多实例数据文件目录
创建多实例的配置文件
修改多实例的文件权限
初始化mysql多实例
mysql多实例的连接及密码添加
mysql多实例的启动及关闭
打开远程连接访问
添加到开机启动
操作系统版本
CentOS release 6.5 (Final) x86_64
MySQL版本
5.5.45
1.安装MySQL软件
参照cmake安装mysql
2.创建多实例数据文件目录
[root@mysql ~]# pkill mysqld [root@mysql ~]# rm /etc/init.d/mysqld [root@mysql ~]# mkdir -p /data/{3306,3307}/data [root@mysql ~]# tree /data/ [root@mysql ~]# rm /etc/my.cnf
3.创建多实例配置文件
[root@mysql ~]# /bin/cp /soft/mysql-5.5.45/support-files/my-small.cnf /data/3306/my.cnf [root@mysql ~]# /bin/cp /soft/mysql-5.5.45/support-files/my-small.cnf /data/3307/my.cnf
编辑修改配置文件
注意的参数有端口号、socket、各实例相关的文件位置以及server-id
vi /data/3306/my.cnf
[client] #password = your_password port = 3306 socket = /data/3306/mysql.sock # The MySQL server [mysqld] port = 3306 socket = /data/3306/mysql.sock skip-external-locking key_buffer_size = 16K max_allowed_packet = 1M table_open_cache = 4 sort_buffer_size = 64K read_buffer_size = 256K read_rnd_buffer_size = 256K net_buffer_length = 2K thread_stack = 128K datadir = /data/3306/data log-error = /data/3306/mysql_3306.err log-slow-queries = /data/3306/slow.log pid-file = /data/3306/mysql.pid log-bin = /data/3306/mysql-bin relay-log = /data/3306/relay-bin relay-log-info-file = /data/3306/relay-log.info #skip-networking server-id = 1 [mysqldump] quick max_allowed_packet = 16M [mysql] no-auto-rehash [myisamchk] key_buffer_size = 8M sort_buffer_size = 8M [mysqlhotcopy] interactive-timeout
vi /data/3307/my.cnf
[client] #password = your_password port = 3307 socket = /data/3307/mysql.sock # The MySQL server [mysqld] port = 3307 socket = /data/3307/mysql.sock skip-external-locking key_buffer_size = 16K max_allowed_packet = 1M table_open_cache = 4 sort_buffer_size = 64K read_buffer_size = 256K read_rnd_buffer_size = 256K net_buffer_length = 2K thread_stack = 128K datadir = /data/3307/data log-error = /data/3307/mysql_3307.err log-slow-queries = /data/3307/slow.log pid-file = /data/3307/mysql.pid log-bin = /data/3307/mysql-bin relay-log = /data/3307/relay-bin relay-log-info-file = /data/3307/relay-log.info #skip-networking server-id = 3 [mysqldump] quick max_allowed_packet = 16M [mysql] no-auto-rehash [myisamchk] key_buffer_size = 8M sort_buffer_size = 8M [mysqlhotcopy] interactive-timeout
4.修改多实例的文件权限
[root@mysql ~]# chown -R mysql.mysql /data/ [root@mysql ~]# find /data/ -name mysql [root@mysql ~]# find /data/ -name mysql -exec chmod 700 {} \; [root@mysql ~]# find /data -name mysql -exec ls -l {} \;
5.初始化数据库
[root@mysql ~]# cd /app/mysql/scripts [root@mysql scripts]# ./mysql_install_db --basedir=/app/mysql --datadir=/data/3306/data --user=mysql [root@mysql scripts]# ./mysql_install_db --basedir=/app/mysql --datadir=/data/3307/data --user=mysql [root@mysql ~]$ tree /data/
6.mysql多实例的连接及密码添加
mysql多实例的连接需要指定sock,oracle多实例连接时指定的是SID
[root@mysql ~]# mysql -S /data/3306/mysql.sock [root@mysql ~]# mysql -S /data/3307/mysql.sock [root@mysql ~]# mysqladmin -u root -S /data/3307/mysql.sock password '123456' [root@mysql ~]# mysqladmin -u root -S /data/3306/mysql.sock password '123456'
7.MySQL多实例的启动、连接及关闭
启动多实例,可以使用单独的脚本启动,也可以使用mysqld_safe指定配置文件启动,也可以使用mysqld_multi进行启动,但是这种方式就不是各个实例单独的配置文件了,此次使用命令及单独的脚本进行操作。其实本质也就是mysql_safe以及mysqladmin的操作,只是使用脚本方便而已。
7.1 mysql_safe命令启动以及关闭
[root@mysql ~]# mysqld_safe --defaults-file=/data/3307/my.cnf 2>&1 > /dev/null & [root@mysql ~]# mysqld_safe --defaults-file=/data/3306/my.cnf 2>&1 > /dev/null & [root@mysql ~]# netstat -lntup | grep 330 tcp 0 0 0.0.0.0:3307 0.0.0.0:* LISTEN 36549/mysqld tcp 0 0 0.0.0.0:3306 0.0.0.0:* LISTEN 35835/mysqld [root@mysql ~]# mysqladmin -uroot -p123456 -S /data/3307/mysql.sock shutdown [root@mysql ~]# mysqladmin -uroot -p123456 -S /data/3306/mysql.sock shutdown [root@mysql ~]# netstat -lntup | grep 330
7.2 使用各自的脚本进行启动、关闭
vi /data/3306/mysql
需要注意的是mysqld_safe、mysqladmin命令全路径
#!/bin/bash ##### mysql_port=3306 mysql_username="root" mysql_password="123456" function_start_mysql() { printf "Starting MySQL...\n" /bin/sh /app/mysql/bin/mysqld_safe --defaults-file=/data/${mysql_port}/my.cnf 2>&1 > /dev/null & } function_stop_mysql() { printf "Stoping MySQL...\n" /app/mysql/bin/mysqladmin -u ${mysql_username} -p${mysql_password} -S /data/${mysql_port}/mysql.sock shutdown } function_restart_mysql() { printf "Restarting MySQL...\n" function_stop_mysql function_start_mysql } function_kill_mysql() { kill -9 $(ps -ef | grep 'bin/mysqld_safe' | grep ${mysql_port} | awk '{printf $2}') kill -9 $(ps -ef | grep 'libexec/mysqld' | grep ${mysql_port} | awk '{printf $2}') } case $1 in start) function_start_mysql;; stop) function_stop_mysql;; kill) function_kill_mysql;; restart) function_stop_mysql function_start_mysql;; *) echo "Usage: /data/${mysql_port}/mysqld {start|stop|restart|kill}";; esac
vi /data/3307/mysql
#!/bin/bash ##### mysql_port=3307 mysql_username="root" mysql_password="123456" function_start_mysql() { printf "Starting MySQL...\n" /bin/sh /app/mysql/bin/mysqld_safe --defaults-file=/data/${mysql_port}/my.cnf 2>&1 > /dev/null & } function_stop_mysql() { printf "Stoping MySQL...\n" /app/mysql/bin/mysqladmin -u ${mysql_username} -p${mysql_password} -S /data/${mysql_port}/mysql.sock shutdown } function_restart_mysql() { printf "Restarting MySQL...\n" function_stop_mysql function_start_mysql } function_kill_mysql() { kill -9 $(ps -ef | grep 'bin/mysqld_safe' | grep ${mysql_port} | awk '{printf $2}') kill -9 $(ps -ef | grep 'libexec/mysqld' | grep ${mysql_port} | awk '{printf $2}') } case $1 in start) function_start_mysql;; stop) function_stop_mysql;; kill) function_kill_mysql;; restart) function_stop_mysql function_start_mysql;; *) echo "Usage: /data/${mysql_port}/mysqld {start|stop|restart|kill}";; esac
添加可执行权限
chmod +x /data/3306/mysql chmod +x /data/3307/mysql
使用脚本启动、关闭MySQL多实例
[root@mysql ~]# /data/3306/mysql start Starting MySQL... [root@mysql ~]# lsof -i:3306 COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME mysqld 4617 mysql 13u IPv4 14657 0t0 TCP *:mysql (LISTEN) [root@mysql ~]# [root@mysql ~]# /data/3307/mysql start Starting MySQL... [root@mysql ~]# lsof -i:3307 COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME mysqld 4937 mysql 13u IPv4 14933 0t0 TCP *:opsession-prxy (LISTEN) [root@mysql ~]# /data/3307/mysql stop Stoping MySQL... [root@mysql ~]# lsof -i:3307 [root@mysql ~]# /data/3306/mysql stop Stoping MySQL... [root@mysql ~]# lsof -i:3306
8.打开远程连接访问
[root@mysql ~]# mysql -uroot -p123456 -S /data/3306/mysql.sock Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 1 Server version: 5.5.45-log Source distribution Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'192.168.10.%' IDENTIFIED BY '123456' WITH GRANT OPTION ; Query OK, 0 rows affected (0.00 sec) mysql> flush privileges ; Query OK, 0 rows affected (0.00 sec) mysql> exit Bye [root@mysql ~]# mysql -uroot -p123456 -S /data/3307/mysql.sock Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 2 Server version: 5.5.45-log Source distribution Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'192.168.10.%' IDENTIFIED BY '123456' WITH GRANT OPTION ; Query OK, 0 rows affected (0.00 sec) mysql> flush privileges ; Query OK, 0 rows affected (0.00 sec) mysql>
9.添加到开机启动
vi /etc/rc.d/rc.local /data/3306/mysql start /data/3307/mysql start