欢迎光临
我们一直在努力

发布MySQL集群自动安装脚本1.0!-数据库专栏,MySQL

建站超值云服务器,限时71元/月

经过几天的测试,终于可以发布了!

1. 在mysql源代码目录下新建脚本 install.sh,把下面的代码添加到这个脚本中:

#!/bin/bash####################################################### title: mysql 4.1 cluster installation script #### version: 1.0 #### date: 2004-11-11 #### author: yipsilon #### email: yipsilon@163.com #### license: general public license (gpl) #### copyright(c) 2004, yipsilon all rights reserved ######################################################### changelog ######################################################### installation guide #### 1. copy the script file into mysql source path #### 2. change script files permission to 755 #### 3. execute it and wait for… ############################################################################################################ mysql server config ###########################################################determine to install mysql server#”0″ means do not install server programsinst_server=1#mysql installation pathinst_path=”/usr/local/mysql”#define the ports of mysql installation, intput strings of port with whitespace separated.#e.g. “3306 3307″ means install two mysql servers:# the first server will be installed to $inst_path/1 and listen 3306 port.# the second server will be installed to $inst_path/2 and listen 3307 port.# … …inst_ports=”3306″#the management server informationmgm_host=”192.168.1.253″mgm_port=”2200″#################################################### mysql cluster config ########################################################determine to install cluster#”0” means do not install cluster programsinst_cluster=1#define computers in config.ini, intput strings of hostname with whitespace separated.#the id attribute is auto increment and start with 1.#e.g. “192.168.1.253 192.168.252” will generate the following code# [computer]# id=1# hostname=192.168.1.253# [computer]# id=2# hostname=192.168.1.252computers=”192.168.1.253 192.168.1.252″#define mgms in config.ini, intput strings of hostname with whitespace separated.#e.g. “192.168.1.253 192.168.252” will generate the following code# [mgm]# hostname=192.168.1.253# [mgm]# hostname=192.168.1.252mgms=”192.168.1.253″#define dbs in config.ini, intput ids of executeoncomputer with whitespace separated.#e.g. “1 2” will generate the following code# [db]# executeoncomputer=1# [db]# executeoncomputer=2dbs=”1″#define apis in config.ini, intput ids of executeoncomputer with whitespace separated.#e.g. “1 0 1 2” will generate the following code# [api]# executeoncomputer=1# [api]# [api]# executeoncomputer=1# [api]# executeoncomputer=2apis=”1 0 2 2″################################################################################ starting to install programs, do not modify them! ###############################################################################echo “starting to install programs” > install.log#find installation pathif [ $# -gt 0 ] then inst_path=”$1″else inst_path=”/usr/local/mysql”fiif [ 0 -lt $inst_server ]then echo “now, installing the mysql servers…” #loop to install mysql servers installed_server_count=1 for port in $inst_ports do #define the current mysql server installation path mysl_path=$inst_path/$installed_server_count #configure mysql server echo “exec ./configure –prefix=$mysl_path –with-pthread –with-unix-socket-path=$mysl_path/var/mysql.sock –with-mysqld-user=root –with-tcp-port=$port –with-charset=gbk –with-ndbcluster” >> install.log ./configure –prefix=$mysl_path –with-pthread –with-unix-socket-path=$mysl_path/var/mysql.sock –with-mysqld-user=root –with-tcp-port=$port –with-charset=gbk –with-ndbcluster #make mysql server echo “exec make && make install” >> install.log make && make install #create var directory for mysql data mkdir -p $mysl_path/var #create my.cnf echo “create $mysl_path/var/my.cnf” >> install.log echo “[client]” > $mysl_path/var/my.cnf echo “port=$port” >> $mysl_path/var/my.cnf echo “socket=$mysl_path/var/mysql.sock” >> $mysl_path/var/my.cnf echo “” >> $mysl_path/var/my.cnf echo “[mysqld]” >> $mysl_path/var/my.cnf echo “ndbcluster” >> $mysl_path/var/my.cnf echo “ndb_connectstring=host=$mgm_host:$mgm_port” >> $mysl_path/var/my.cnf echo “user=root” >> $mysl_path/var/my.cnf echo “port=$port” >> $mysl_path/var/my.cnf echo “basedir=$mysl_path/” >> $mysl_path/var/my.cnf echo “datadir=$mysl_path/var/” >> $mysl_path/var/my.cnf echo “socket=$mysl_path/var/mysql.sock” >> $mysl_path/var/my.cnf echo “default-character-set=gbk” >> $mysl_path/var/my.cnf echo “default-storage-engine=innodb” >> $mysl_path/var/my.cnf echo “max_connections=500” >> $mysl_path/var/my.cnf echo “” >> $mysl_path/var/my.cnf echo “query_cache_size=33m” >> $mysl_path/var/my.cnf echo “table_cache=1520” >> $mysl_path/var/my.cnf echo “tmp_table_size=16m” >> $mysl_path/var/my.cnf echo “thread_cache=38” >> $mysl_path/var/my.cnf echo “” >> $mysl_path/var/my.cnf echo “#myisam specific options” >> $mysl_path/var/my.cnf echo “#skip-myisam” >> $mysl_path/var/my.cnf echo “” >> $mysl_path/var/my.cnf echo “#innodb specific options” >> $mysl_path/var/my.cnf echo “#skip-innodb” >> $mysl_path/var/my.cnf chmod 755 $mysl_path/var/my.cnf #install mysql database echo “exec $mysl_path/bin/mysql_install_db” >> install.log $mysl_path/bin/mysql_install_db #create mysql control script if [ -e $mysl_path/share/mysql/mysql.server ] then #use default mysql control script #create mysql server start script echo “create $mysl_path/start” >> install.log echo “$mysl_path/share/mysql/mysql.server start” > $mysl_path/start echo “chmod 755 $mysl_path/start” >> install.log chmod 755 $mysl_path/start #create mysql server stop script echo “create $mysl_path/stop” >> install.log echo “$mysl_path/share/mysql/mysql.server stop” > $mysl_path/stop echo “chmod 755 $mysl_path/stop” >> install.log chmod 755 $mysl_path/stop #create mysql server restart script echo “create $mysl_path/restart” >> install.log echo “$mysl_path/share/mysql/mysql.server restart” > $mysl_path/restart echo “chmod 755 $mysl_path/restart” >> install.log chmod 755 $mysl_path/restart else #use custom mysql control script #create mysql server start script echo “create $mysl_path/start” >> install.log echo “$mysl_path/libexec/mysqld &” > $mysl_path/start echo “chmod 755 $mysl_path/start” >> install.log chmod 755 $mysl_path/start #create mysql server stop script echo “create $mysl_path/stop” >> install.log echo “$mysl_path/bin/mysqladmin -u root -p shutdown” > $mysl_path/stop echo “chmod 755 $mysl_path/stop” >> install.log chmod 755 $mysl_path/stop #create mysql server restart script echo “create $mysl_path/restart” >> install.log echo “$mysl_path/bin/mysqladmin -u root -p shutdown” > $mysl_path/restart echo “$mysl_path/libexec/mysqld &” >> $mysl_path/restart echo “chmod 755 $mysl_path/restart” >> install.log chmod 755 $mysl_path/restart fi #clean mysql server to get ready for the next installation echo “exec make clean” >> install.log make clean installed_server_count=$(($installed_server_count + 1)) done echo “configurations! mysql servers has been installed successfully.” echo “” echo “1. to start mysql server, use the following command:” echo ” cd <mysql_installation_path>” echo ” ./start” echo “” echo “2. to stop mysql server, use the following command:” echo ” cd <mysql_installation_path>” echo ” ./stop” echo “” echo “3. to restart mysql server, use the following command:” echo ” cd <mysql_installation_path>” echo ” ./restart”fi#install cluster programsif [ 0 -lt $inst_cluster ]then if [ -e $inst_path/1 ] then echo “now, installing the cluster programs…” #define the cluster installation path clst_path=$inst_path/cluster #create cluster directory echo “exec mkdir -p $clst_path” >> install.log mkdir -p $clst_path #copy cluster binaries echo “exec cp $inst_path/1/bin/ndb* $clst_path/” >> install.log cp $inst_path/1/bin/ndb* $clst_path/ echo “exec cp $inst_path/1/libexec/ndb* $clst_path/” >> install.log cp $inst_path/1/libexec/ndb* $clst_path/ #create config.ini echo “create $clst_path/config.ini” >> install.log #write default global configuration echo “[tcp default]” >> $clst_path/config.ini echo “” >> $clst_path/config.ini echo “[mgm default]” >> $clst_path/config.ini echo “” >> $clst_path/config.ini echo “[db default]” >> $clst_path/config.ini echo ” noofreplicas=1″ >> $clst_path/config.ini echo “” >> $clst_path/config.ini echo “[api default]” >> $clst_path/config.ini echo “” >> $clst_path/config.ini #write computers configuration computer_id=1 for computer in $computers do echo “[computer]” >> $clst_path/config.ini echo ” id=$computer_id” >> $clst_path/config.ini echo ” hostname=$computer” >> $clst_path/config.ini echo “” >> $clst_path/config.ini computer_id=$(($computer_id + 1)) done #write management server configuration for mgm in $mgms do echo “[mgm]” >> $clst_path/config.ini echo ” hostname=$mgm” >> $clst_path/config.ini echo “” >> $clst_path/config.ini done #write storage nodes configuration for db in $dbs do echo “[db]” >> $clst_path/config.ini echo ” executeoncomputer=$db” >> $clst_path/config.ini echo “” >> $clst_path/config.ini done #write mysql servers configuration for api in $apis do echo “[api]” >> $clst_path/config.ini if [ 0 -ne $api ] then echo ” executeoncomputer=$api” >> $clst_path/config.ini fi echo “” >> $clst_path/config.ini done #create ndb.cfg echo “create $clst_path/ndb.cfg” >> install.log echo “host=$mgm_host:$mgm_port” >> $clst_path/ndb.cfg echo “” >> $clst_path/ndb.cfg echo “configurations! cluster programs has been installed successfully.” echo “” echo “1. to start management server(mgm), use the following command:” echo ” cd $clst_path” echo ” ./ndb_mgmd” echo “” echo “2. to start stroage node(db), use the following command:” echo ” cd $clst_path” echo ” ./ndbd” echo “” echo “3. to manage the cluster, use the following command:” echo ” cd $clst_path” echo ” ./ndb_mgm” echo “” echo “4. else, nothing to do.;)” echo “” echo “enjoy yourself.” else echo “cluster installation has been stopped, the reason is:”; echo ” no database server installed.” echo “so you can not use cluster programs in this machine!” fifi

2. 设置脚本权限,让它可执行:chmod 755 install.sh
3. 执行该脚本:./install.sh 或者 ./install <mysql安装目录>

具体使用说明,英语好的看脚本注释吧;英语不好的,那就再等等,过几天会release出来。

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » 发布MySQL集群自动安装脚本1.0!-数据库专栏,MySQL
分享到: 更多 (0)