MySQL多实例实战案例

[root@localhost ~]# mkdir -p /data/{3306,3307}/data

[root@localhost ~]# tree /data/

/data/ 多实例根目录

|-- 3306 3306实例的目录

|   `-- data 3306实例的数据文件目录

`-- 3307 3307 实例的目录

    `-- data 3307实例的数据文件目录

 

4 directories, 0 files

[root@localhost ~]# unzip data.zip

Archive:  data.zip

   creating: data/

   creating: data/3306/

  inflating: data/3306/my.cnf       

  inflating: data/3306/mysql        

   creating: data/3307/

  inflating: data/3307/my.cnf       

  inflating: data/3307/mysql        

[root@localhost ~]# cp data/3306/my.cnf /data/3306/

[root@localhost ~]# cp data/3307/my.cnf /data/3307/

[root@localhost ~]# cp data/3306/mysql /data/3306/

[root@localhost ~]# cp data/3307/mysql /data/3307/

[root@localhost ~]# tree /data

/data

|-- 3306

|   |-- data

|   |-- my.cnf

|   `-- mysql

`-- 3307

    |-- data

    |-- my.cnf

    `-- mysql

 

4 directories, 4 files

多实例启动文件的mysql服务实质

mysqld_safe --defaults-file=/data/3306/my.cnf 2&1 > /dev/null &

mysqld_safe --defaults-file=/data/3307/my.cnf 2&1 > /dev/null &

多实例启动文件的停止服务实质

mysqladmin -uroot -p1 -S /data/3306/mysql.sock shutdown

mysqladmin -uroot -p1 -S /data/3307/mysql.sock shutdown

授权相关文件

[root@localhost ~]# chown -R mysql.mysql /data

[root@localhost ~]# find /data/ -type f -name "mysql" | xargs chmod 750

[root@localhost ~]# find /data/ -type f -name "mysql" | xargs ls -l

-rwxr-x--- 1 mysql mysql 1301 Jul 31 22:54 /data/3306/mysql

-rwxr-x--- 1 mysql mysql 1300 Jul 31 22:54 /data/3307/mysql

初始化数据库

[root@localhost ~]# cd /usr/local/mysql/scripts/

[root@localhost scripts]# ./mysql_install_db --basedir=/usr/local/mysql --datadir=/data/3306/data --user=mysql

Installing MySQL system tables...

OK

Filling help tables...

OK

[root@localhost scripts]# ./mysql_install_db --basedir=/usr/local/mysql --datadir=/data/3307/data --user=mysql

Installing MySQL system tables...

OK

Filling help tables...

OK

启动服务

[root@localhost ~]# /data/3306/mysql start

Starting MySQL...

[root@localhost ~]# /data/3307/mysql start

Starting MySQL...

[root@localhost ~]# netstat -anutp | grep 330

tcp        0      0 0.0.0.0:3306      0.0.0.0:*   LISTEN      37099/mysqld       

tcp        0      0 0.0.0.0:3307      0.0.0.0:*   LISTEN      37818/mysqld

测试登录

[root@localhost ~]# mysql -S /data/3306/mysql.sock

mysql>       

[root@localhost ~]# mysql -S /data/3307/mysql.sock

mysql>

设定密码

[root@localhost ~]# mysqladmin -uroot -S /data/3306/mysql.sock password '1'

[root@localhost ~]# mysqladmin -uroot -S /data/3307/mysql.sock password '1'

测试停止服务

[root@localhost ~]# /data/3306/mysql stop

Stoping MySQL...

[root@localhost ~]# /data/3307/mysql stop

Stoping MySQL...

实战增加第三个实例

[root@localhost ~]# mkdir /data/3308/data -p

[root@localhost ~]# cp /data/3306/my.cnf /data/3308/

[root@localhost ~]# cp /data/3306/mysql /data/3308/

[root@localhost ~]# ls /data/3308/

data  my.cnf  mysql

[root@localhost ~]# chown -R mysql.mysql /data/3308/

[root@localhost ~]# vim /data/3308/my.cnf

[root@localhost ~]# vim /data/3308/mysql

[root@localhost ~]# cd /usr/local/mysql/scripts/

[root@localhost scripts]# ./mysql_install_db \

> --basedir=/usr/local/mysql/ \

> --datadir=/data/3308/data \

> --user=mysql

Installing MySQL system tables...

OK

Filling help tables...

OK

[root@localhost ~]# /data/3308/mysql start

Starting MySQL...

[root@localhost 3308]# netstat -anutp | grep 330

tcp        0      0 0.0.0.0:3306            0.0.0.0:*               LISTEN      39537/mysqld       

tcp        0      0 0.0.0.0:3307            0.0.0.0:*               LISTEN      40254/mysqld       

tcp        0      0 0.0.0.0:3308            0.0.0.0:*               LISTEN      42028/mysqld       

[root@localhost ~]# mysqladmin -uroot -S /data/3308/mysql.sock password '1'

[root@localhost ~]# mysql -uroot -p1 -S /data/3308/mysql.sock

mysql> quit

Bye

[root@localhost ~]# /data/3308/mysql stop

Stoping MySQL...

MySQL启动基本原理说明

/etc/init.d/mysqld 是一个shell启动脚本,启动后最终会调用mysqld_safe脚本,最后调用mysqld服务启动mysql

初始化数据库时MySQL系统输出给出的启动方法:

mysqld_safe --user=mysql &

提示:

1.   当找回root密码时,会经常使用mysqld_safe --user=mysql &带参数启动

2.   我们自己开发脚本启动数据库时可能会用到这个启动方法。

3.   /etc/init.d/mysqld和mysqld_safe --user=mysql &的启动实质是一样的。

MySQL关闭基本原理

优雅关闭

1.   mysqladmin方法

[root@localhost ~]# mysqladmin -uroot -p123 shutdown

2.   自带的脚本

/etc/init.d/mysqld stop

3.   kill、killall、pkill等进程管理命令(不建议使用,特别是生产环境,高并发情况会导致数据丢失,甚至无法启动)


觉得本文章不错的可以分享给您的朋友或订阅我,后期会分享更多的Linux技术文章