当前位置:七道奇文章资讯数据防范MySQL防范
日期:2011-01-25 22:43:00  来源:本站整理

在同一台机运行多个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防范]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • 在同一台机运行多个Mysql 服务
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .