Welcome

首页 / 数据库 / MySQL / MYSQL服务维护笔记

MYSQL服务维护笔记2008-05-12使用MYSQL服务的一些经验,主要从以下几个方面考虑的MYSQL服务规划设计。

1 MYSQL服务的安装/配置的通用性;

2 系统的升级和数据迁移方便性;

3 备份和系统快速恢复;

MYSQL服务器的规划

=================

为了以后维护,升级备份的方便和数据的安全性,最好将MYSQL程序文件和数据分别安装在“不同的硬件”上。

 //usr <== 操作系统 
//opt/mysql<== mysql主目录,为了方便升级,这只是一个最新版本目录的链接
硬盘1==>|/opt/mysql-3.23.54/ <== 最新版本的mysql /home/mysql链接到这里
/opt/mysql-old/ <== 以前运行的旧版本的mysql
/etc/my.multi.cnf<== 多daemon配置文件

/ /data/app_3301/ <== 应用数据等,
硬盘2==>|/data/app_3302/
/data/app_3303/
mysql服务的安装和服务的启动:

MYSQL一般使用当前STABLE的版本,尽量不使用--with-charset=选项,我感觉with-charset只在按字母排序的时候才有用,这些选项会对数据的迁移带来很多麻烦。

configure --prefix=/home/mysql

make

make install

服务的启动和停止

================

1 复制缺省的mysql/var/mysql到 /database/app_1/目录下,

2 MYSQLD的启动脚本:start_mysql.sh

#!/bin/sh

rundir=`dirname "$0"`

echo "$rundir"

/home/mysql/bin/safe_mysqld --user=mysql --pid-file="$rundir"/mysql.pid --datadir="$rundir"/var "$@"

-O max_connections=500 -O wait_timeout=600 -O key_buffer=32M --port=3402 --socket="$rundir"/mysql.sock &

注释:

--pid-file="$rundir"/mysql.pid --socket="$rundir"/mysql.sock --datadir="$rundir"/var

目的都是将相应数据和应用临时文件放在一起;

-O 后面一般是服务器启动全局变量优化参数,有时候需要根据具体应用调整;

--port: 不同的应用使用PORT参数分布到不同的服务上去,一个服务可以提供的连接数一般是MYSQL服务的主要瓶颈;

修改不同的服务到不同的端口后,在rc.local文件中加入:

/database/app_1/start_mysql.sh

/database/app_2/start_mysql.sh

/database/app_3/start_mysql.sh

注意:必须写全路径

3 MYSQLD的停止脚本:stop_mysql.sh

#!/bin/sh

rundir=`dirname "$0"`

echo "$rundir"

/home/mysql/bin/mysqladmin -u mysql -S"$rundir"/mysql.sock shutdown