Welcome 微信登录

首页 / 数据库 / MySQL / Linux下同时部署多个版本的MySQL

在同一台Linux服务器上部署多个MySQL服务,可以有效提高机器利用率。而且,将不同内容分属不同服务上,也相对更安全些。 MySQL提供了mysqld_multi,但实际应用中没有人用它。弊端: 1,暂停、重启,会导致所有服务都停下来。 2,配置文件冗长,拆分、迁移时麻烦。 业内比较常用的方法是,将数据库数据文件和配置文件,以及开启关闭脚本,共同放在一个目录下。启动服务时,作为一个单独的服务;关闭时对其他服务没有影响。搬迁时,只要将这个目录迁移到目标机器上就OK了。 一个典型的例子:   10.10.82.83 [server2]$ cat start.sh
#!/bin/sh
rundir="/opt/server2";
echo $rundir;
/usr/local/mysql/bin/mysqld_safe --defaults-file="$rundir"/my.cnf --pid-file="$rundir"/mysql.pid --datadir="$rundir"/var --socket="$rundir"/mysql.sock --log-error="$rundir"/err.log --log-slow-queries="$rundir"/slow_query.log& 上例中使用的MySQL是按照官方建议安装在/usr/local/mysql下的。 有时候需要在同一台服务器上使用多个不同版本,比如,测试新版本等。按照以上逻辑,将新MySQLD安装在 /usr/local/mysql-new下,修改 start.sh 为 /usr/local/mysql-new/bin/mysqld_safe。数据库可以正常启动,但是,观察发现并不是新版本。原因何在? 官方的解释是:需要下载源代码版本,编译时指定运行目录。其实并非必须如此。 研究mysqld_safe文件,发现其逻辑为: A,从命令行取配置参数 B,从配置文件取配置参数 C,对于mysqld的目录(basedir)和数据文件目录(datadir),如果以上都没有在配置中指定,则先检查当前目录是否可用,否则设置/usr/local/mysql为默认。 所以,虽然使用的是mysql-new下的mysqld_safe,但运行的还是/usr/local/mysql/bin/mysqld,也就是旧版本。需要相应修改启动脚本,或者是配置文件: #!/bin/sh
rundir="/opt/server0";
echo $rundir;
/usr/local/mysql-new/bin/mysqld_safe --defaults-file="$rundir"/my.cnf --ledir=/usr/local/mysql-new/bin --basedir=/usr/local/mysql-new --pid-file="$rundir"/mysql.pid --datadir="$rundir"/var --socket="$rundir"/mysql.sock --log-error="$rundir"/err.log --log-slow-queries="$rundir"/slow_query.log& 这样就可以在同一台机器上同时运行多个版本的Mysql了。 ##--------------------------下面部份是我偶实验出来滴...上面部分和我自己的做法有点不同,但原理都是一样,我在服务器上直接就用这样一句 /usr/local/mysql5/bin/mysqld_safe --defaults-file=/etc/my5.cnf & 里面的那些参数全都设置到 my5.cnf文件里了,所以看起来短一些,其实最重要的是--defaults-file,这个参数了,开始不知道有这东东,害偶走了很多弯路.faint.
  • 1
  • 2
  • 下一页
Linux下基于裸设备建立oracle 10g数据库Linux下启动oracle10g的em和isqlplus相关资讯      mysql 
  • 数据库服务器 MySQL  (08/15/2013 06:50:23)
  • MySQL 5.6 GA 及逃亡潮  (02/08/2013 14:36:35)
  • MySQL 5.5.22、5.1.62、5.0.96全线  (03/22/2012 19:03:49)
  • MySQL Administrator连接VMWare下  (05/24/2013 09:20:58)
  • MySQL 5.1.68 发布  (02/05/2013 08:37:47)
  • CentOS 5.2+MySQL+Heartbeat双机互  (01/29/2012 11:16:55)
本文评论 查看全部评论 (0)
表情: 姓名: 字数