shell学习二十三--case语句编写mysql启动脚本
2017-11-21 21:11
726 查看
六、例子:开发mysql单实例或者多实例启动脚本
已知mysql多实例启动命令为:
mysqld_safe --deafaults-file=/data/3306/my.cnf &
停止命令
mysqladmin -u root -p123 -S /data/3306/mysql.sock shutdown
请完成mysql单实例或者多实例启动脚本编写。
要求:用函数、case语句等实现。
[root@node01 day10]# vi start_db.sh
#!/bin/sh
# chkconfig: 2345 35 67
# description: start rsync and stop rsync scripts.
. /etc/init.d/functions
path=/usr/bin/
pass=123
user=root
function usage(){
echo "$0 {start|stop|restart}"
exit 1
}
[ $# -ne 1 ] && usage
function start_mysql(){
$path/mysqld_safe --user=mysql >/dev/null 2>&1 &
if [ $? -eq 0 ]
then
action "start mysql" /bin/true
else
action "start mysql" /bin/false
fi
}
function stop_mysql(){
mysqladmin -u$user -p$pass shutdown >/dev/null 2>&1
if [ $? -eq 0 ]
then
action "stop mysql" /bin/true
else
action "stop mysql" /bin/false
fi
}
case "$1" in
start)
start_mysql
RETVAL=$?
;;
stop)
stop_mysql
RETVAL=$?
;;
restart)
stop_mysql
sleep 2
start_mysql
RETVAL=$?
;;
*)
usage
esac
[root@node01 day10]# sh start_db01.sh start
start mysql [ OK ]
[root@node01 day10]# sh start_db01.sh stop
stop mysql [ OK ]
[root@node01 day10]# sh start_db01.sh restart
stop mysql [FAILED]
start mysql [ OK ]
[root@node01 day10]# mysql -uroot -p123
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 1
Server version: 5.1.73 Source distribution
Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql>
已知mysql多实例启动命令为:
mysqld_safe --deafaults-file=/data/3306/my.cnf &
停止命令
mysqladmin -u root -p123 -S /data/3306/mysql.sock shutdown
请完成mysql单实例或者多实例启动脚本编写。
要求:用函数、case语句等实现。
[root@node01 day10]# vi start_db.sh
#!/bin/sh
# chkconfig: 2345 35 67
# description: start rsync and stop rsync scripts.
. /etc/init.d/functions
path=/usr/bin/
pass=123
user=root
function usage(){
echo "$0 {start|stop|restart}"
exit 1
}
[ $# -ne 1 ] && usage
function start_mysql(){
$path/mysqld_safe --user=mysql >/dev/null 2>&1 &
if [ $? -eq 0 ]
then
action "start mysql" /bin/true
else
action "start mysql" /bin/false
fi
}
function stop_mysql(){
mysqladmin -u$user -p$pass shutdown >/dev/null 2>&1
if [ $? -eq 0 ]
then
action "stop mysql" /bin/true
else
action "stop mysql" /bin/false
fi
}
case "$1" in
start)
start_mysql
RETVAL=$?
;;
stop)
stop_mysql
RETVAL=$?
;;
restart)
stop_mysql
sleep 2
start_mysql
RETVAL=$?
;;
*)
usage
esac
[root@node01 day10]# sh start_db01.sh start
start mysql [ OK ]
[root@node01 day10]# sh start_db01.sh stop
stop mysql [ OK ]
[root@node01 day10]# sh start_db01.sh restart
stop mysql [FAILED]
start mysql [ OK ]
[root@node01 day10]# mysql -uroot -p123
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 1
Server version: 5.1.73 Source distribution
Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql>
相关文章推荐
- shell学习二十一--使用if编写mysql启动脚本
- shell脚本编程之case语句学习笔记
- shell脚本编程之case语句学习笔记
- shell语句编写nginx的启动脚本
- shell学习十四--编写监控mysql脚本
- mysql5.6.7多实例安装、配置的详细讲解分析及shell启动脚本的编写
- 【Shell脚本学习17】Shell case esac语句
- Shell 脚本应用(for、while、case语句应用)
- Shell脚本入门(七) - 条件控制语句: case
- 用shell编写启动脚本模板
- Shell脚本中执行mysql语句
- shell脚本学习笔记(三)mysql与ARP表的绑定源码
- 学习 shell —— 编写基本脚本
- shell脚本执行mysql语句
- CentOS下编写shell脚本来监控MySQL主从复制
- NO3.Shell脚本学习——编写Shell脚本
- CentOS下编写shell脚本来监控MySQL主从复制的教程_MySQL
- 2个简单shell脚本(if,while,case语句)
- 学习编写shell脚本(一)
- Linux-shell脚本-if语句/case语句