MySQL多实例介绍及配置

    在以前的一篇文章中,已经有介绍到怎么安装和配置MySQl了(https://blog.51cto.com/superpcm/2092357)。接下来,MySQL中多实例的配置。mysql

1.什么是MySQL多实例sql

    简单来讲,MySQL多实例就是在一台服务器上同时开启多个不一样服务端口,同时运行多个MySQL服务进程,这些服务进程经过不一样的socket监听不一样的服务器端口来提供服务。这些MySQL多实例共用一套MySQL安装程序,使用不一样的my.cnf(也能够相同)配置文件,启动程序 (也能够相同)和数据文件。在提供服务时,多实例MySQL在逻辑上看起来是各自独立的,它根据配置文件的对应设定值,得到服务器相应数量的硬件资源。
数据库

    多实例的好处在于它能有效利用服务器的资源,节约服务器资源,弊端会存在资源的相互抢占的问题。当某个数据库实例并发很高或有SQL慢查询时,整个实例会消耗大量的系统CPU、磁盘I/O等资源,致使服务器上的其余数据库实例提供服务的质量一块儿降低。不一样实例获取的资源是相对独立的,没法像虚拟化同样彻底隔离。
vim

2.配置MySQL多实例安全

    MySQL的多实例配置能够是单一文件、单一启动程序的部署方案,可是不推荐,风险过高了。这里部署的是多配置文件,多启动的部署方案。在前面,咱们已经搭建了MySQL的服务,也就是存在了一个默认的实例,端口为3306。在这里,咱们多增长一个实例,端口为3307.
bash

blob.png

    (1)建立多实例的数据文件目录,目录本身肯定就行
服务器

mkdir -p /data/3307/data

    (2)建立MySQL多实例的配置文件,vim /data/3307/my.cnf,内容以下
并发

[client]
port	= 3307
socket	= /data/3307/mysql.sock

[mysql]
no-auto-rehash

[mysqld]
user	= mysql
port	= 3307
socket	= /data/3307/mysql.sock
basedir	= /usr/local/mysql
datadir	= /data/3307/data
open_files_limit	= 1024
read-only
back_log	= 600
max_connections	= 800
max_connect_errors	= 3000
#table_cache	= 614
external-locking	= FALSE
max_allowed_packet	= 8M
sort_buffer_size	= 1M
join_buffer_size	= 1M
thread_cache_size	= 100
thread_concurrency	= 2
query_cache_size	= 2M
query_cache_limit	= 1M
query_cache_min_res_unit	= 2K
#default_table_type	= InnoDB
thread_stack	= 192K
#transaction_isolation	= READ-COMMITTED
tmp_table_size	= 2M
max_heap_table_size	= 2M
long_query_time	=1 
pid-file	= /data/3307/mysql.pid
relay-log	= /data/3307/relay-bin
relay-log-info-file = /data/3307/relay-log.info
binlog_cache_size	= 1M
max_binlog_cache_size	= 1M
max_binlog_size	= 2M
key_buffer_size	= 16M
read_rnd_buffer_size	= 1M
bulk_insert_buffer_size	= 1M
lower_case_table_names	= 1
skip-name-resolve
slave-skip-errors	= 1032,1062
replicate-ignore-db=mysql

server-id	= 3        #不一样实例的server-id不同的,3306端口的server_id我设置为52了,这里不能是52

#innodb_additional_mem_pool_size	= 4M
innodb_buffer_pool_size	= 32M
innodb_data_file_path	 = ibdata1:128M:autoextend
innodb_file_io_threads	= 4
#innodb_threads_concurrency	= 8
innodb_flush_log_at_trx_commit	= 2
innodb_log_buffer_size	= 2M
innodb_log_file_size	= 4M
innodb_log_files_in_group	= 3 
innodb_max_dirty_pages_pct	= 90
innodb_lock_wait_timeout	= 120
innodb_file_per_table	= 0
[mysqldump]
quick
max_allowed_packet	= 2M

[mysql_safe]
log-error=/data/3307/mysql_pcm3307.err
pid-file=/data/3307/mysqld.pid

    (3)建立MySQL多实例的启动文件,vim /data/3307/mysql ,内容以下
socket

#!/bin/bash

#init
port=3307
mysql_user="root"
mysql_pwd="pcm123456"
CmdPath="/usr/local/mysql/bin"
mysql_sock="/data/${port}/mysql.sock"

#startup function
function_start_mysql(){
	if [ ! -e "$mysql_sock" ];then
		printf "Starting Mysql...\n"
		/bin/sh	${CmdPath}/mysqld_safe --defaults-file=/data/${port}/my.cnf 2>&1 >/dev/null &    #启动命令
	else
		printf "Mysql is running...\n"
	exit
	fi
}

#stop function
function_stop_mysql(){
	if [ ! -e "$mysql_sock" ];then
		printf "Mysql is stopped...\n"
		exit 
	else
		printf "Stoping Mysql...\n"
		${CmdPath}/mysqladmin -u ${mysql_user} -p${mysql_pwd} -S /data/${port}/mysql.sock shutdown    #中止命令
	fi
}

#restart function
function_restart_mysql(){
	printf "Restart Mysql...\n"
	function_stop_mysql
	sleep 2
	function_start_mysql
}

case $1 in
start)
	function_start_mysql
	;;
stop)
	function_stop_mysql
	;;
restart)
	function_restart_mysql
	;;
*)
	printf "Usage:/data/${port}/mysql.sh {start|stop|restart}\n"
esac

    (4)配置MySQL多实例的文件权限
ide

chown -R mysql:mysql /data/
find /data -name mysql.sh |xargs chmod 700    #修改权限为700,由于里面有数据库的密码,要求较高的安全性

blob.png

    (5)初始化MySQL多实例的数据库文件

/usr/local/mysql/scripts/mysql_install_db --basedir=/usr/local/mysql/ --datadir=/data/3307/data/ --user=mysql

    查看3307目录下data目录,能够看到多出了很多的数据文件

blob.png

    (6)启动MySQL多实例数据库,检查看到3307的端口已经启动

/data/3307/mysql.sh start

blob.png

    PS:一开始个人启动是失败了的,后来把data目录下的ibdata1,ib_logfile0,ib_logfile0这三个文件删除以后才正常启动。应该是由于我以前搭建MySQL服务的时候初始化了一次,再次这样初始化生成的文件和后来的配置不符合。

3.登录管理MySQL多实例数据库

    (1)登录MySQL数据库

mysql -S /data/3307/mysql.sock        #须要指定sock文件,否则使用默认的3306

blob.png

    (2)上面看到MySQL的root的密码仍是空的,咱们须要修改。

mysqladmin -u root password 'pcm123456' -S /data/3307/mysql.sock

blob.png

    到这里,MySQL的多实例配置就完成了。若是要远程登录多实例的MySQL的话,记得加上端口号。

相关文章
相关标签/搜索