前言:(1)该脚本可在任意路径运行,只需能够连接外网,会自动下载所需软件包并安装。
            (2)该脚本内mysql版本为mysql-5.6.25。
            (3)为提高脚本自由度,该脚本部署中,需要手动指定IP、同步用户名、同步密码,安装中按照提示输入即可。
        别的就不多说啦,大家自己体验吧,欢迎意见和批评 !

图解如下:
     (1)主菜单
     主菜单选项如下图,共7个选项,可输入该选项内容分别执行选项中的内容。其中可输入help查看帮助,可输入q退出脚本。
      

     Mysql主从搭建脚本_第1张图片

      (2)然后是install选项,该选项为软件包的下载与安装。输入install回车,脚本会自行下载所需软件包进行安装,由于mysql安装时间比较长,这里并没有隐藏安装过程,更方便查看安装进度。

      Mysql主从搭建脚本_第2张图片 

      (3)mysql服务调整
  这里输入server,脚本会自行修改mysql一些配置信息,将mysql加入系统服务,并对mysql进行初始化。为实验方便这里暂时关闭了防火墙。

      Mysql主从搭建脚本_第3张图片

      注:2、3两个步骤需在master端和slave端都执行。
      (4)master部署
        该步骤需在master端执行,进行master的部署,期间需要手动输入slave端IP地址,需要授权的用户名和密码。
        需记下mysql-bin的编号(即后边的数字000001)和POS点(即410)。
    

      Mysql主从搭建脚本_第4张图片

    
      (5)slave部署
      这一步,输入slave后需要手工指定master端IP,及master端的mysql-bin编号及POS点数据。并输入同步用户名及秘密(需于master设置的用户名及密码一致)。

      Mysql主从搭建脚本_第5张图片


      (6)查看状态:
        master及slave都建立好后,可以在slave上查看slave状态,来确定是否部署成功及状态是否正常。


      Mysql主从搭建脚本_第6张图片

      (7)测试:
      我们在master端数据库内创建一个新数据库
      
Mysql主从搭建脚本_第7张图片
 
      然后查看slave端数据库,新数据库已自动同步到slave上,mysql主从同步建立成功!
      
 
     Mysql主从搭建脚本_第8张图片

脚本代码如下:


#!/bin/bash

#by LiuPengfang -----2015/08/07

#Auto-mysql_master-slave

#---------------------------------菜单--------------------------------------

echo "----------------------------------------------------"

echo -e "\033[36m----------欢迎使用Mysql主从自动搭建平台-------------\033[0m"

echo "----------------------------------------------------"

echo "请按照选项进行安装及部署:"

echo "----------------------------------------------------"

echo "|【install】| 软件包下载及安装                     |"

echo "----------------------------------------------------"

echo "|【server】 | Mysql服务调整                        |"

echo "----------------------------------------------------"

echo "|【master】 | Master部署                           |"

echo "----------------------------------------------------"

echo "|【slave】  | Slave部署                            |"

echo "----------------------------------------------------"

echo "|【monitor】| 查看监控状态                         |"

echo "----------------------------------------------------"

echo "|【help】   | 帮助                                 |"

echo "----------------------------------------------------"

echo "|【q】      | 退出                                 |"

echo "----------------------------------------------------"

#---------------------------------下载安装------------------------

function HELP (){

echo -e "\033[33m

-------------------------------------------------------------------------

(1)该脚本可在任意路径运行。

(2)可手动按需求选择选项进行安装及状态查看。

(3)该脚本安装的mysql默认无密码,可在脚本安装后自行设定mysql密码。

(4)该脚本安装的mysql版本为-5.6.25,若需要其他版本请更改脚本内的软件源。

(5)该脚本需要手动指定IP、同步用户名、同步密码,按照提示输入即可

-------------------------------------------------------------------------\033[0m"


}

#------------------------------------help--------------------------

function INSTALL (){

mkdir /mysqldir ; cd /mysqldir

echo -e "\033[35m正在下载软件包,请等待……\033[0m"

wget http://mirrors.sohu.com/mysql/MySQL-5.6/mysql-5.6.25.tar.gz &>/dev/null

if [ $? -eq 0 ];then

echo -e "\033[35m软件包下载成功!\033[0m"

else

echo -e "\033[35m软件包下载失败,请检查网络或下载源!\033[0m"

exit

fi

echo -e "\033[35m正在解压软件包……\033[0m"

tar vxf mysql-5.6.25.tar.gz &>/dev/null

if [ $? -eq 0 ];then

echo -e "\033[35m解压成功!\033[0m"

else

echo -e "\033[35m解压失败!\033[0m"

exit

fi

cd mysql-5.6.25

echo -e "\033[35m正在安装cmake软件包……\033[0m"

yum install cmake -y &>/dev/null

if [ $? -eq 0 ];then

        echo -e "\033[35mcmake安装成功!\033[0m"

else

        echo -e "\033[35mcmake安装失败!\033[0m"

        exit

fi

echo -e "\033[35m正在安装mysql,时间较长请耐心等待……\033[0m"

cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql5.6 &>/dev/null

if [ $? -eq 0 ];then

        echo -e "\033[35mmysql预编译成功!\033[0m"

else

        echo -e "\033[35mmysql预编译失败!\033[0m"

        exit

fi

make && make install

if [ $? -eq 0 ];then

        echo-e  "\033[35mmysql安装成功!\033[0m"

else

        echo-e  "\033[35mmysql安装失败!\033[0m"

        exit

fi

}

#---------------------------------服务调整-----------------------------------

function SERVER (){

echo -e "\033[35m添加mysql用户……\033[0m"

useradd mysql

echo -e "\033[35m正在进行mysql服务调整……\033[0m"

chown -R mysql.mysql /usr/local/mysql5.6

cp /usr/local/mysql5.6/support-files/mysql.server /etc/rc.d/init.d/mysql

chkconfig --add mysql

chkconfig --level 35 mysql on

\cp /usr/local/mysql5.6/support-files/my-default.cnf /etc/my.cnf

cd /usr/local/mysql5.6/

echo -e "\033[35mmysql初始化mysql……\033[0m"

scripts/mysql_install_db --user=mysql &>/dev/null

if [ $? -eq 0 ];then

        echo -e "\033[35mmysql初始化成功!\033[0m"

else

        echo -e "\033[35mmysql初始化失败!\033[0m"

        exit

fi

echo -e "\033[35m重启mysql服务……\033[0m"

service mysql start &>/dev/null

if [ $? -eq 0 ];then

        echo -e "\033[35mmysql服务启动成功!\033[0m"

else

        echo -e "\033[35mmysql服务启动失败!\033[0m"

        exit

fi

alias mysql='/usr/local/mysql5.6/bin/mysql'

echo -e "\033[35m关闭防火墙……\033[0m"

service iptables stop &>/dev/null

}

#---------------------------------Master部署----------------------------------

function MASTER (){

cat /etc/my.cnf |grep "log-bin=mysql-bin"

if [ $? -eq 0 ];then

echo -e "\033[35m配置信息已存在。\033[0m"

else

sed -i 's/\[mysqld\]/&\nlog-bin=mysql-bin\nserver-id = 1/' /etc/my.cnf

echo -e "\033[35m配置信息导入成功!\033[0m"

fi

echo -e "\033[35m重启mysql服务……\033[0m"

service mysql restart &>/dev/null

if [ $? -eq 0 ];then

        echo -e "\033[35mmysql服务启动成功!\033[0m"

else

        echo -e "\033[35mmysql服务启动失败!\033[0m"

        exit

fi

read -p "请输入slave服务器IP:" i

read -p "请输入同步使用的用户名:" USER_MY

read -p "请输入同步使用的密码:" PASS_MY


/usr/local/mysql5.6/bin/mysql -uroot -e "grant replication slave on *.* to '$USER_MY'@'$i' identified by '$PASS_MY';"

/usr/local/mysql5.6/bin/mysql -uroot -e "flush privileges;"

MY_BIN=`/usr/local/mysql5.6/bin/mysql -uroot -e "show master status;"|grep "mysql-bin."|awk '{print $1}'|awk -F "." '{print $2}'`

MY_POS=`/usr/local/mysql5.6/bin/mysql -uroot -e "show master status;"|grep "mysql-bin."|awk '{print $2}'`

echo -e "\033[36m您的mysql-编号为:$MY_BIN\033[0m"

echo -e "\033[36m您的mysql-POS点为:$MY_POS\033[0m"

}

#---------------------------------Slave部署-----------------------------------

function SLAVE (){

cat /etc/my.cnf |grep "server-id = 2"

if [ $? -eq 0 ];then

echo -e "\033[35mmysql配置信息已存在。\033[0m"

else

sed -i 's/\[mysqld\]/&\nserver-id = 2/' /etc/my.cnf

echo -e "\033[35mmysql配置信息导入成功!\033[0m"

fi

echo -e "\033[35m重启mysql服务……\033[0m"

service mysql restart &>/dev/null

if [ $? -eq 0 ];then

        echo -e "\033[35mmysql服务启动成功!\033[0m"

else

        echo -e "\033[35mmysql服务启动失败!\033[0m"

        exit

fi

read -p "请输入master服务IP:" i

read -p "请输入master mysql-编号:" MY_BIN

read -p "请输入master mysql-POS:" MY_POS

read -p "请输入同步使用的用户名:" USER_MY

read -p "请输入同步使用的密码:" PASS_MY

/usr/local/mysql5.6/bin/mysql -uroot -e "change master to master_host='$i',master_user='$USER_MY',master_password='$PASS_MY',master_log_file='mysql-bin.$MY_BIN',master_log_pos=$MY_POS;"

/usr/local/mysql5.6/bin/mysql -uroot -e "flush privileges;"

/usr/local/mysql5.6/bin/mysql -uroot -e "start slave;"

}

#---------------------------------监控同步状态-------------------------------

function MONITOR (){

SLAVE_IO=`/usr/local/mysql5.6/bin/mysql -uroot -e "show slave status\G;"|grep "Slave_IO_Running:"|sed 's/ //g'|awk -F ":" '{print $2}'`

SLAVE_SQL=`/usr/local/mysql5.6/bin/mysql -uroot -e "show slave status\G;"|grep "Slave_SQL_Running:"|sed 's/ //g'|awk -F ":" '{print $2}'`



if [[ $SLAVE_IO = Yes ]];then

echo -e "\033[36mThe Slave_IO is Yes!\033[0m"

elif [[ $SLAVE_IO = Connecting ]];then

echo -e "\033[36m请检查您的防火墙配置!\033[0m"

else

echo -e "\033[36mThe Slave_IO is NO!\033[0m"

exit

fi

if [[ $SLAVE_SQL = Yes ]];then

echo -e "\033[36mThe Slave_IO is Yes!\033[0m"

elif [[ $SLAVE_SQL = Connecting ]];then

echo -e "\033[36m请检查您的防火墙配置!\033[0m"

else

echo -e "\033[36mThe Slave_IO is NO!\033[0m"

exit

fi

if [[ $SLAVE_IO = Yes && $SLAVE_SQL = Yes ]];then

echo -e "\033[35mMysql主从同步建立成功!\033[0m"

else

echo -e "\033[35mMysql主从同步建立失败!\033[0m"

fi


}

#--------------------------------模块调用-------------------------------------

read -p "请输入您要进行的选项:" i

PATH_AUTO=$(pwd)

case $i in

install)

INSTALL

cd $PATH_AUTO ; sh auto_mysql_M-S.sh

;;

server)

SERVER

cd $PATH_AUTO ; sh auto_mysql_M-S.sh

;;

master)

MASTER

cd $PATH_AUTO ; sh auto_mysql_M-S.sh

;;

slave)

SLAVE

cd $PATH_AUTO ; sh auto_mysql_M-S.sh

;;

monitor)

MONITOR

cd $PATH_AUTO ; sh auto_mysql_M-S.sh

;;

help)

HELP

cd $PATH_AUTO ; sh auto_mysql_M-S.sh

;;

q)

exit

;;

*)

echo -e "\033[36m请输入正确选项!\033[0m"

cd $PATH_AUTO ; sh auto_mysql_M-S.sh

;;

esac