学海荡舟手机网
导航

主页 > 电子设备技术 > 电器电路基础 > > 详细内容

MYSQL服务维护笔记

使用MY服务的一些经验,主要从以下几个方面考虑的MYSQL服务规划设计。

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

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

3 备份和系统快速恢复;

MYSQL服务器的规划

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

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

/

/usr <== 操作系统 }==> 硬盘1

/home/mysql <== mysql应用程序

...

/database/app_1/ <== 应用数据和脚本 }==> 硬盘2

/database/app_2/

/database/app_3/

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.al文件中加入:

/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


相关文章