在同一台机运行多个Mysql 服务[MySQL防范]
本文“在同一台机运行多个Mysql 服务[MySQL防范]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
*****************************************
第一部份, 在一台服务器构建多mysql 服务.
*****************************************
一,绪言
在Mysql中有一mysqld_multi号令,可用于在一台物理服务器运行多个Mysql服务,本日参考一些文档,亲身测试并通过,真高兴,现将操作历程同享给大家!
操作系统:Linux 2.6.13 (Slackware),别的版的Linux应当也差不多.
数据库:Mysql 4.0.17 源程序安装(相信最新的5.1.*也差不多,过些天再试试)
筹划:运行4个mysql服务:
假定服务器名:db-app (IP为192.168.0.100),
假定服务器名:db-app2 (IP为192.168.0.101),
下文直到第二部份,均为报告db-app中的mysql,
二,预备
用mysql源程序安装,假定在安装时用的configura挑选项氯?
./configure --prefix=/usr/local/mysql --datadir=/usr/local/mysql/data1 --sysconfdir=/etc
备注:--prefix将MYSQL安装到/usr/local/mysql,
--datadir将数据库生成/usr/local/mysql/data1
sysconfdir是指定mysql利用到的my.cnf配置文件的搜索途径为/etc
其他mysql安装历程略.
按照Mysql管理手册中提到:每个Mysql的服务都可为独立的,所以它都调用一个my.cnf中各自差别的启动选项--就是下文中将提到的GNR值,利用差别的端口,生成各自的套接文件,服务的数据库都是独立的(更多可查阅mysql官方网站的英文管理手册).
mysqld_multi是管理多个mysqld的服务进程,这些服务进程程序差别的unix socket或是监听于差别的端口.他可以启动、终止和监控当前的服务状况.
----程序在my.cnf(或是在--config-file自定义的配置文件)中搜索[mysqld#]段,"#"可以是肆意的正整数.这个正整数就是在下面说起的段序列,即GNR.段的序号做为mysqld_multi的参数,来辨别差别的段,这样你便可以掌握特定mysqld进程的启动、终止或得到他的报告信息.这些组里的参数就像启动一个mysqld所需求的组的参数一样.但是,假如利用多服务,必须为每个服务指定一个unix socket或端口(摘自http://mifor.4dian.org中的利用mysqld_multi程序管理多个MySQL服务 ).
从上述文字可看到多Mysql服务中最重要的就是my.cnf配置文件了.
现我贴出我的my.cnf文件.-----------------------
[mysqld_multi]
mysqld = /usr/local/mysql/bin/mysqld_safe
mysqladmin = /usr/local/mysql/bin/mysqladmin
user = mysql (用一个帐号来启动全部的mysql服务器,因为是用一相同的帐号.那个么这帐号必须都是每个mysql服务都要用的帐号,最好是管理帐号,下面的口令与相同)
password = mypaswd
[mysqld1]
port = 3306
socket = /tmp/mysql.sock1
pid-file=/usr/local/mysql/data1/db-app1.pid
log=/usr/local/mysql/data1/db-app.log
datadir = /usr/local/mysql/data
user = mysql
[mysqld2]
port = 3307
socket = /tmp/mysql.sock2
pid-file = /usr/local/mysql/data2/db-app2.pid
datadir = /usr/local/mysql/data2
log=/usr/local/mysql/data2/db-app.log
user = mysql
[mysqld3]
port = 3308
socket = /tmp/mysql.sock3
pid-file = /usr/local/mysql/data3/db-app3.pid3
datadir = /usr/local/mysql/data3
log=/usr/local/mysql/data3/db-app.log
user = mysql
[mysqld4]
port = 3309
socket = /tmp/mysql.sock4
pid-file = /usr/local/mysql/data3/db-app4.pid
datadir = /usr/local/mysql/data4
log=/usr/local/mysql/data4/db-app.log
user = mysql
[mysqldump]
quick
max_allowed_packet = 16M
[mysql]
no-auto-rehash
[isamchk]
key_buffer = 128M
sort_buffer_size = 128M
read_buffer = 2M
write_buffer = 2M
[myisamchk]
key_buffer = 128M
sort_buffer_size = 128M
read_buffer = 2M
write_buffer = 2M
[mysqlhotcopy]
interactive-timeout
我的配置文件中有mysqld1,mysqld2,mysqld3,mysqld4.就是说我将启动4个mysql服务在同一服务器的差别端口——3306-3309,每datadir所指定的数据库文件途径都是不相同的,都有各自差别的日记文件.别的一些设置可用my.cnf 本来的内容.
ok, 重要的my.cnf编好的,目前为配置中差别mysql 服务成立各自文件夹和初始数据库等.
[mysqld1]是一个默许的,在我们安装mysql时已经有了,所以不用管它.
[mysqld2],只要按照配置就的途径为它成立一个目录便可以了.将把该目录改成mysql管理权
db-app:/ # mkdir /usr/local/mysql/data2
建数据库,我们可以把默许的mysql数据库复制过来,以操纵别的的mysql帐号,别的数据库按照利用再成立.
db-app:/ # cp /usr/local/mysql/data1/mysql /usr/local/mysql/data2 -R
db-app:/ # chmod mysql.mysql /usr/local/mysql/data2 -R
[mysqld3],[mysqld4], 相同.
我们大概看看这些目录能否都存在.
db-app:/ # ls -l /usr/local/mysql/
drwxr-xr-x 6 mysql mysql 4096 Apr 9 17:54 data4
drwxr-x--- 2 mysql mysql 4096 Apr 9 17:14 data1
drwxr-xr-x 3 mysql mysql 4096 Apr 9 17:54 data2
drwxr-xr-x 3 mysql mysql 4096 Apr 9 17:54 data3
目前可以通过mysqld_multi启动了.
三,mysqld_multi号令.
利用以下参数来启动mysqld_multi: (注:该号令在mysql的bin目录中,按照上面所提到./configure --prefix=/usr/local/mysql ,所以该文件应当在 /usr/local/mysq/bin, 这得按照你安装时所指定的途径 )
db-app:/ # mysqld_multi [options] {start|stop|report} [GNR[,GNR]...]
start,stop和report是指你想到履行的操作.你可以在单独的服务或是多服务上指定一个操作,辨别于选项背面的GNR列表.假如没有指定GNR列表,那么mysqld_multi将在全部的服务中按照选项文件举行操作.
每一个GNR的值是组的序列号或是一个组的序列号范围.此项的值必须是组名字最后的数字,比方说假如组名为mysqld17,那么此项的值则为17.假如指定一个范围,利用"-"(破折号)来衔接二个数字.如GNR的值为10-13,则指组mysqld10到组mysqld13.多个组或是组范围可以在号令行中指定,利用","(逗号)离隔.不能有空白的字符(如空格或tab),在空白字符背面的参数将会被忽视. (注:GNR值就是我们定义my.cnf中mysqld#中的值,我这里只有1-4).
以上是“在同一台机运行多个Mysql 服务[MySQL防范]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |