MySQL数据库入门多实例配置

网友投稿 973 2023-05-13

MySQL数据库入门多实例配置

MySQL数据库入门多实例配置

前面介绍了相关的基础命令操作:MySQL数据库基础篇之入门基础命令

所有的操作都是基于单实例的,mysql多实例在实际生产环境也是非常实用的,因为必须要掌握。

1、什么是多实例

多实例就是一台服务器上开启多个不同的服务端口(默认3306),运行多个mysql的服务进程,这此服务进程通过不同的socket监听不同的服务端口来提供各在的服务,所有实例之间共同使用一套MYSQL的安装程序,但各自使用不同的配置文件、启动程序、数据文件,在逻辑上是相对独立的。

多实例主要作用是:充分利用现有的服务器硬件资源,为不同的服务提供数据服务,但是如果某个实例并发比较高的,同样是会影响到其它实例的性能

2、安装多实例环境准备

安装前需要先安装mysql,但是只需将安装过程进行到make install即可(编译安装),如果使用免安装程序,只需解压软件包即可,今天的环境是通过免安装包来安装mysql主程序(其它的安装可以参考前面的安装过程自行测试)

系统环境

[root@centos6 ~]# cat /etc/redhat-release   CentOS release 6.5 (Final)  [root@centos6 ~]# uname -r  2.6.32-431.el6.x86_64

安装程序

mysql-5.5.52-linux2.6-x86_64.tar.gz

首先将软件下载到本地

创建安装用户

[root@centos6 ~]#groupadd mysql  [root@centos6 ~]#useradd mysql -s /sbin/nologin -g mysql -M  [root@centos6 ~]#tail -1 /etc/passwd  mysql:x:500:500::/home/mysql:/sbin/nologin

创建多实例的数据目录

[root@centos6 tools]# mkdir -p /data/{3306,3307}  [root@centos6 tools]# tree /data/  /data/  +-- 3306  +-- 3307  2 directories, 0 files

3、安装MYSQL多实例

接下来进行安装mysql的多实例操作

解压软件

[root@centos6 tools]# ll mysql-5.5.52-linux2.6-x86_64.tar.gz   -rw-r--r--. 1 root root 185855000 Aug 26 21:38 mysql-5.5.52-linux2.6-x86_64.tar.gz  [root@centos6 tools]# tar zxf mysql-5.5.52-linux2.6-x86_64.tar.gz

拷贝配置文件

[root@centos6 mysql-5.5.52-linux2.6-x86_64]# cp support-files/my-small.cnf /data/3306/my.cnf  [root@centos6 mysql-5.5.52-linux2.6-x86_64]# cp support-files/mysql.server /data/3306/mysql  [root@centos6 mysql-5.5.52-linux2.6-x86_64]# cp support-files/my-small.cnf /data/3307/my.cnf  [root@centos6 mysql-5.5.52-linux2.6-x86_64]# cp support-files/mysql.server /data/3307/mysql

为一规范安装路径,将免安装包拷贝到应用程序目录下

[root@centos6 tools]# mv mysql-5.5.52-linux2.6-x86_64 /application/mysql  [root@centos6 tools]# ll /application/mysql  total 72  drwxr-xr-x.  2 root root   4096 Dec  9 17:15 bin  -rw-r--r--.  1 7161 31415 17987 Aug 26 19:24 COPYING  drwxr-xr-x.  3 root root   4096 Dec  9 17:15 data  drwxr-xr-x.  2 root root   4096 Dec  9 17:15 docs  drwxr-xr-x.  3 root root   4096 Dec  9 17:15 include  -rw-r--r--.  1 7161 31415   301 Aug 26 19:24 INSTALL-BINARY  drwxr-xr-x.  3 root root   4096 Dec  9 17:15 lib  drwxr-xr-x.  4 root root   4096 Dec  9 17:15 man  drwxr-xr-x. 10 root root   4096 Dec  9 17:15 mysql-test  -rw-r--r--.  1 7161 31415  2496 Aug 26 19:24 README  drwxr-xr-x.  2 root root   4096 Dec  9 17:15 scripts  drwxr-xr-x. 27 root root   4096 Dec  9 17:15 share  drwxr-xr-x.  4 root root   4096 Dec  9 17:15 sql-bench  drwxr-xr-x.  2 root root   4096 Dec  9 17:15 support-files

修改配置文件与启动文件

因为是多实例,其中参数需要修改,修改后的配置文件如下:配置文件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 = /application/mysql  datadir = /data/3307/data  #log_long_format  #log-error = /data/3307/error.log  #log-slow-queries = /data/3307/slow.log  pid-file = /data/3307/mysql.pid  server-id = 3      [mysqld_safe]  log-error=/data/3307/mysql3307.err  pid-file=/data/3307/mysqld.pid

启动程序文件mysql

[root@backup 3307]# cat mysql  #!/bin/sh  init port=3307  mysql_user="root"  mysql_pwd="migongge"  CmdPath="/application/mysql/bin"  mysql_sock="/data/${port}/mysql.sock"  #startup  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 "Restarting 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 {start|stop|restart}\n"  esac

其它的配置可参考配置文件进行修改即可

多实例初始化操作

初始化成功后,会在数据目录下产生一个数据目录data和一些文件

[root@centos6 3306]# ll /data/3306/data/  total 1136  drwx------. 2 mysql root     4096 Dec  9 18:02 mysql  -rw-rw----. 1 mysql mysql   27693 Dec  9 18:02 mysql-bin.000001  -rw-rw----. 1 mysql mysql 1114546 Dec  9 18:02 mysql-bin.000002  -rw-rw----. 1 mysql mysql      38 Dec  9 18:02 mysql-bin.index  drwx------. 2 mysql mysql    4096 Dec  9 18:02 performance_schema  drwx------. 2 mysql root     4096 Dec  9 18:02 test

另一个实例的初始化请参考上述操作进行,操作过程不再一一介绍

[root@centos6 3307]# ll /data/3307/data/  total 1136  drwx------. 2 mysql root     4096 Dec  9 18:40 mysql  -rw-rw----. 1 mysql mysql   27693 Dec  9 18:40 mysql-bin.000001  -rw-rw----. 1 mysql mysql 1114546 Dec  9 18:40 mysql-bin.000002  -rw-rw----. 1 mysql mysql      38 Dec  9 18:40 mysql-bin.index  drwx------. 2 mysql mysql    4096 Dec  9 18:40 performance_schema  drwx------. 2 mysql root     4096 Dec  9 18:40 test

4 、启动多实例并登录

启动服务

[root@backup 3307]# /data/3306/mysql start  Starting MySQL...  [root@backup 3307]# lsof -i :3306  COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME  mysqld 19986 mysql 10u IPv4 90967 0t0 TCP *:mysql (LISTEN)  [root@backup 3307]# /data/3307/mysql  start Starting MySQL...  [root@backup 3307]# lsof -i :3307  COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME  mysqld 21648 mysql 11u IPv4 92899 0t0 TCP *:opsession-prxy (LISTEN)

检查端口

[root@backup 3307]# netstat -lntup|grep mysql  tcp 0 0 0.0.0.0:3307 0.0.0.0:* LISTEN 21648/mysqld tcp 0 0 0.0.0.0:3306 0.0.0.0:* LISTEN 19986/mysqld

登陆多实例数据库

成功登陆,并在3306实例中创建数据库,但是3307实例上查看并没有创建过的数据,说明两个实例是独立的

注:如果再需要新增一个实例,基本的配置步骤同上述一样,只需要相应修改配置文件与启动程序文件中的端口号与数据目录的路径即可,最后可以将多实例数据库启动命令加入开机自启动。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:MySQL数据库基础篇之入门基础命令
下一篇:数据库缓存最终一致性的四种方案
相关文章