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/mysqlmakemake install服务的启动和停止================1 复制缺省的mysql/var/mysql到 /database/app_1/目录下,2 MYSQLD的启动脚本:start_mysql.sh#!/bin/shrundir=`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/shrundir=`dirname "$0"`echo "$rundir"/home/mysql/bin/mysqladmin -u mysql -S"$rundir"/mysql.sock shutdown