shell腳本專題之-----------全自動編譯安裝mysql


  mysql的編譯安裝,在博客 開源服務專題之--------mysql的編譯安裝 中已經說明了,但是還是比較麻煩,尤其是一大堆命令,來手動執行,稍有不慎,就會出錯。生產上一般都是先在本地測試環境進行自動化測試,如果ok,那么就在生產上進行自動化安裝,省事,省力,安全。

本文環境:

  CentOS6.5x64 ,mysql版本:mysql-5.6.26。 采用自動化編譯安裝。

相關准備工作:

  熟知sed 文本編譯命令,expect交互式腳本的使用。

提前將需要安裝的mysql安裝包放在/root下面,當然了,下載的過程也可以一並寫在腳本中,為了節約時間,下載過程一般不會寫在腳本中,而且好多生產環境是不能夠連接外網的。

[root@xiaolyu76 ~]# ls
anaconda-ks.cfg   install.log install.log.syslog mysql-5.6.26.tar.gz  mysql_install_auto.sh 

下面是我的腳本:mysql_install_auto.sh 的內容:

[root@xiaolyu76 ~]# cat mysql_install_auto.sh

 

#!/bin/bash
MYSQL_PASSWD="123456"
yum remove  -y mysql mysql-server
yum install -y cmake     ncurses-devel 
tar xf mysql-5.6.26.tar.gz -C /usr/local/src/ 
cd /usr/local/src/mysql-5.6.26
useradd -M -s /sbin/nologin mysql 
cmake \
 -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
 -DMYSQL_UNIX_ADDR=/tmp/mysql.sock \
 -DDEFAULT_CHARSET=utf8 \
 -DDEFAULT_COLLATION=utf8_general_ci \
 -DWITH_EXTRA_CHARSETS=all \
 -DWITH_MYISAM_STORAGE_ENGINE=1\
 -DWITH_INNOBASE_STORAGE_ENGINE=1\
 -DWITH_MEMORY_STORAGE_ENGINE=1\
 -DWITH_READLINE=1\
 -DENABLED_LOCAL_INFILE=1\
 -DMYSQL_DATADIR=/usr/local/mysql/data \
 -DMYSQL-USER=mysql
make -j 4 && make install
cd && chown -R mysql:mysql /usr/local/mysql/
cp /usr/local/mysql/support-files/my-default.cnf /etc/my.cnf  
cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld
sed  -i 's%^basedir=%basedir=/usr/local/mysql%' /etc/init.d/mysqld
sed  -i 's%^datadir=%datadir=/usr/local/mysql/data%' /etc/init.d/mysqld
chkconfig mysqld on
/usr/local/mysql/scripts/mysql_install_db \
 --defaults-file=/etc/my.cnf  \
 --basedir=/usr/local/mysql/  \
 --datadir=/usr/local/mysql/data/  \
 --user=mysql
ls /usr/local/mysql/data/
ln -s /usr/local/mysql/bin/* /bin/
service mysqld start
echo "now let's begin mysql_secure_installation "
if [ ! -e /usr/bin/expect ] 
 then  yum install expect -y 
fi
echo '#!/usr/bin/expect
set timeout 60
set password [lindex $argv 0]
spawn mysql_secure_installation
expect {
"enter for none" { send "\r"; exp_continue}
"Y/n" { send "Y\r" ; exp_continue}
"password" { send "$password\r"; exp_continue}
"Cleaning up" { send "\r"}
}
interact ' > mysql_secure_installation.exp 
chmod +x mysql_secure_installation.exp
./mysql_secure_installation.exp $MYSQL_PASSWD 

 

[root@xiaolyu76 ~]# sh  mysql_install_auto.sh    //直接執行該腳本即可。

腳本是shell腳本,最后mysql數據庫安全初始化的時候,生成一個expect的腳本:mysql_secure_installation.exp。

說明:為了增強腳本的整齊美觀和可讀性,去掉了很多if 判斷以及echo $?判斷腳本是否執行成功。

mysql編譯安裝中的相關命令和參數的說明在本人的博客:開源服務專題之--------mysql的編譯安裝 已經有了詳細說明,故本文不在贅述。

本文腳本經測試完全正確。

本文為作者原創博客,轉載請注明出處:http://www.cnblogs.com/jasmine-Jobs/p/6045469.html

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM