mysql搭建多个实例(mysqld_multi的使用)

Mysql中有一mysqld_multi命令,可用于在一台物理服务器运行多个Mysql服务。 

操作系统: Redhat Enterprise AS 3-U8
数据库   : Mysql 5.0.40


规划:在一个 Mysql 上运行2个实例,运行端口分别是33063307

一.在LINUX 系统下安装Mysql5

安装mysql数据库。(采用源码安装)

shell> groupadd mysql

shell> useradd -g mysql mysql

shell> tar zxvf mysql-5.0.40.tar.gz

shell> cd mysql-5.0.40

shell> ./configure --prefix=/usr/local/mysql  --sysconfdir=/etc  

shell> make

shell> make install

shell> cp support-files/my-medium.cnf /etc/my.cnf   ----修改相应的参数

shell> cd /usr/local/mysql

shell> chown -R mysql:mysql  mysql

shell> bin/mysql_install_db --user=mysql    ----安装初始数据库

shell> chown -R root mysql

shell> chown -R mysql :mysql   var

shell> bin/mysqld_safe --user=mysql &   -------开启mysqld服务

 
二到此可以先测试一下单个数据库实例有没有安装成功

二.配置mysqld2.

我们在一台服务器上运行多个mysql的实例时,如果安装的是同一个版本的mysql,不用安装多次,只安装一次就可以了。主要区别的是数据存放的位置,可以把已经安装好的mysql数据库存放数据的文件复制几份就可以,同时要修改其权限。如下:

[mysqld1]是一个默认的,在我们安装mysql时已经有了,所以不用管它
[mysqld2],
只要根据配置就的路径为它建立一个目录就可以了.将把该目录改为mysql 管理 

[root@mysql mysql]#cd /usr/local/mysql

[root@mysql mysql]#cp –R var var1

[root@mysql mysql]#chown mysql:mysql var1

 

三.mysqld_multi 介绍:

    根据Mysql管理手册中提到:每个Mysql的服务都可为独立的,所以它都调用一个my.cnf中各自不同的启动选项--就是下文中将提到的GNR,使用不同的端口,生成各自的套接文件,服务的数据库都是独立的(更多可查阅mysql官方网站的英文管理手册).

    mysqld_multi是管理多个mysqld的服务进程,这些服务进程程序不同的unix socket或是监听于不同的端口。他可以启动、停止和监控当前的服务状态。

    程序在my.cnf(或是在--config-file自定义的配置文件)中搜索[mysqld#]段,"#"可以是任意的正整数。这个正整数就是在下面提及的段序列,即GNR。段的序号做为mysqld_multi的参数,来区别不同的段,这样你就可以控制特定mysqld进程的启动、停止或得到他的报告信息。这些组里的参数就像启动一个mysqld所需要的组的参数一样。但是,如果使用多服务,必须为每个服务指定一个unix socket或端口

 

配置/etc/my.cnf(具体配置如下)

[mysqld_multi]

mysqld = /usr/local/mysql/bin/mysqld_safe

mysqladmin = /usr/local/mysql/bin/mysqladmin

user = guzh

password = mysql

 

[mysqld1]

port            = 3306

socket          = /tmp/mysql.sock

pid-file = /usr/local/mysql/var/mysql.pid

datadir = /usr/local/mysql/var

skip-locking

key_buffer = 16M

max_allowed_packet = 1M

table_cache = 64

sort_buffer_size = 512K

net_buffer_length = 8K

read_buffer_size = 256K

read_rnd_buffer_size = 512K

myisam_sort_buffer_size = 8M

 

[mysqld2]

port            = 3307

socket           = /tmp/mysql2.sock

pid-file = /usr/local/mysql/var1/mysql2.pid

datadir = /usr/local/mysql/var1

skip-locking

key_buffer = 16M

max_allowed_packet = 1M

table_cache = 64

sort_buffer_size = 512K

net_buffer_length = 8K

read_buffer_size = 256K

read_rnd_buffer_size = 512K

myisam_sort_buffer_size = 8M

 

 

从以上配置可以看出,我的配置文件中有mysqld1mysqld2两个实例。就是说我将启动2mysql服务在同一服务器的不同端口--33063307,每个datadir所指定的数据库文件路径都是不相同的

四、利用 Mysqld_multi 启动/停止 多实例 Mysql

说明:
使用如下参数来启动mysqld_multi: (:该命令在mysqlbin目录中,根据上面所提到./configure --prefix=/usr/local/mysql ,所以该文件应该在 /usr/local/mysq/bin, 这得根据你安装时所指定的路径 )
db-app:/ # mysqld_multi [options] {start|stop|report} [GNR[,GNR]...]

start,stopreport是指你想到执行的操作。你可以在单独的服务或是多服务上指定一个操作,区别于选项后面的GNR列表。如果没有指定GNR列表,那么mysqld_multi将在所有的服务中根据选项文件进行操作。

每一个GNR的值是组的序列号或是一个组的序列号范围。此项的值必须是组名字最后的数字,比如说如果组名为mysqld17,那么此项的值则为17.如果指定一个范围,使用"-"(破折号)来连接二个数字。如GNR的值为10-13,则指组mysqld10到组mysqld13。多个组或是组范围可以在命令行中指定,使用","(逗号)隔开。不能有空白的字符(如空格或tab),在空白字符后面的参数将会被忽略。 (:GNR值就是我们定义my.cnfmysqld#中的值,我这里只有1-2)

启动 mysql
[root@mysql bin]#/usr/local/mysql/bin/musqld_multi  start 1-2

停止 mysql

[root@mysql/usr/local/mysql/bin/mysqld_multi stop 1-2
[mysql@gc1:/var/lib/mysql]$ mysqladmin -uroot -pmysql -P3306 -h127.0.0.1 shutdown
[mysql@gc1:/var/lib/mysql]$ mysqladmin -uroot -pmysql -P3307 -h127.0.0.1 shutdown

查看 mysql

[root@mysql/usr/local/mysql/bin/mysqld_multi report 1-2


 



五.启动数据库,然后对用户进行授权。

 

用一个帐号来启动所有的mysql服务器,因为是用一相同的帐号。那个么这帐号必须都是每个mysql服务都要用的帐号,最好是管理帐号,下面的口令相同
guzh
mysql下的用户,非linux下的用户

#
这个mysql要通过 root 给它赋权限,让它具有shutdown start mysql 的权限
#grant shutdown on *.* to 'guzh' IDENTIFIED BY 'mysql'

[root@gc1 var]# mysql -p -uroot -P3306 -S /tmp/mysql.sock
mysql> GRANT SHUTDOWN ON *.* to 'guzh'@'localhost' identified by 'mysql';

注:两个实例都要做相同的操作。


六、客户端访问

说明:
任何客户端访问都需要指定访问端口。方才能进入指定数据库服务.否则将使用到Mysql默认的端口(3306)所服务的MYSQL,如:

[root@mysql bin]#/usr/local/mysql/bin/mysql -uguzh -pmysql -P3306 -h127.0.0.1


[root@mysqlbin]#/usr/local/mysql/bin/mysql  -uguzh -pmysql -P3307  -h127.0.0.1

 

用sock也可以连接上去  但是一般不用
mysql -u root -p -P3306 -h127.0.0.1
mysql> show variables like 'datadir';
+---------------+-----------------------+
| Variable_name | Value                 |
+---------------+-----------------------+
| datadir       | /usr/local/mysql/var/ |
+---------------+-----------------------+


mysql -u root -p -P3307 -h127.0.0.1
mysql> show variables like 'datadir';
+---------------+------------------------+
| Variable_name | Value                  |
+---------------+------------------------+
| datadir       | /usr/local/mysql/var1/ |
+---------------+------------------------+




mysql -u root -p -P3306 -S /tmp/mysql.sock
mysql> show variables like 'datadir';
+---------------+-----------------------+
| Variable_name | Value                 |
+---------------+-----------------------+
| datadir       | /usr/local/mysql/var/ |
+---------------+-----------------------+


mysql -u root -p -P3307 -S /tmp/mysql2.sock
mysql> show variables like 'datadir';
+---------------+------------------------+
| Variable_name | Value                  |
+---------------+------------------------+
| datadir       | /usr/local/mysql/var1/ |
+---------------+------------------------+





七、常见问题: 

     a
/usr/bin/mysqld_multi 的启动错误



1. WARNING! my_print_defaults command not found!
....
2. FATAL ERROR: Tried to use mysqladmin in group [mysqld1], 
but no mysqladmin binary was found.Please add "mysqladmin=..." 
in group [mysqld_multi], or in group [mysqld1].
....

解决办法,#export PATH=$PATH:/usr/bin



     b
、启动 Mysql 客户端,老报 /var/lib/mysql/temp.sock 的错误


返回 /var/lib/mysql/temp.sock 的错误,一定要记住 加入-P -h才可以,如:

mysql -uboss -pboss -P3310 -h10.10.12.43
mysql -uboss -pboss -P3311 -h10.10.12.43

-h
:带ip,如本机是 127.0.0.1
-P
mysql 实例端口,如 3307

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29096438/viewspace-1409177/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/29096438/viewspace-1409177/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值