视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
MySQL5.5.40自动化安装脚本
2020-11-09 12:49:24 责编:小采
文档


学习了两周Linux Shell脚本,终于写出一个MySQL自动化安装脚本。加上今天一整天的测试,可以正常执行安装MySQL 5.5.40. 其他版本

学习了两周Linux Shell脚本,,终于写出一个MySQL自动化安装脚本。加上今天一整天的测试,可以正常执行安装MySQL 5.5.40. 其他版本还没有测试。现分享一下。也请高手指点一下。

执行该脚本的前提是:

环境介绍:

1、RedHat 6.3 x,最小化安装
2、RAM: 2G,HD:30G
3、关闭selinux
4、配置好yum源(我使用自己配置的源)
5、打开ssh,病配置好iptables,允许远程登录访问。
6、所需软件和文件:

cmake-2.8.10.1.tar.gz
bison-3.0.tar.gz
zlib-1.2.7.tar.gz
mysql-5.5.40.tar.gz
my.cnf //老师共享的文件

脚本内容:

#!/bin/bash

echo "step one: create folder and mount packages"

if [ -d /mnt/share ]

then

echo "find it,don't need to create it."


else

mkdir -p /mnt/share

if [[ $? = 0 ]]

then

echo "create it successfully!"

else

echo " can't create this folder!pls check out!"

fi

mount -t cifs -o username=swen02,password=autozhao01! //172.16.11.20/LAMP-all-software /mnt/share

fi


echo "step two: create mysql installation path"


if [ -d /project/class2 ]

then

echo "find it, don't need to create it."

else

mkdir -p /project/class2/

if [[ $? = 0 ]]

then

echo "create it successfully!"

else

echo " can't create this floder!pls check out!"

fi

fi


echo "step three: copy packages to the folder"


cp /mnt/share/cmake-2.8.10.1.tar.gz /project/class2/

cp /mnt/share/bison-3.0.tar.gz /project/class2/

cp /mnt/share/zlib-1.2.7.tar.gz /project/class2/

cp /mnt/share/mysql-5.5.40.tar.gz /project/class2/

cp /mnt/share/my.cnf /project/class2/


echo "step four: install base packages"


yum -y install gcc gcc-c++ gcc-g77 autoconf automake zlib* fiex* libxml* ncurses-devel libmcrypt* libtool-ltdl-devel*


cd /project/class2

tar -xzvf cmake-2.8.10.1.tar.gz

cd cmake-2.8.10.1

./bootstrap

make && make install

if [[ $? = 0 ]]

then

echo "good job!"

else

echo "sorry, pls check out!"

exit 1

fi

cd ..

tar -zxvf bison-3.0.tar.gz

cd bison-3.0

./configure

make && make install

if [[ $? = 0 ]]

then

echo "good job!"

else

echo "sorry, pls check out!"

exit 1

fi

cd ..

tar -zxvf zlib-1.2.7.tar.gz

cd zlib-1.2.7

./configure

make && make install

cd ..

if [[ $? = 0 ]]

then

echo "good job!"

else

echo "sorry, pls check out!"

exit 1

fi

echo "step five:configure system referenc"


FLAGS="-O3 -g -fno-exceptions -static-libgcc -fno-omit-frame-pointer -fno-strict-aliasing"

CXX=g++

CXXFLAGS="-O3 -g -fno-exceptions -fno-rtti -static-libgcc -fno-omit-frame-pointer -fno-strict-aliasing"

export CFLAGS CXX CXXFLAGS


echo "step six: begin to install mysql"


groupadd mysql

useradd -r -g mysql mysql

tar -zxvf mysql-5.5.40.tar.gz

cd mysql-5.5.40

cmake -DCMAKE_INSTALL_PREFIX=/project/class2/mysql

make

make install

if [[ $? = 0 ]]

then

echo "good job!"

else

echo "sorry, pls check out!"

exit 1

fi

cd ..


#create folder and initial new db

mkdir ./mysql/run

mkdir ./mysql/log

chown -R mysql.mysql /project/class2/mysql

rm -rf /project/class2/mysql/data/*

./mysql/scripts/mysql_install_db --datadir=/project/class2/mysql/data --user=mysql --basedir=/project/class2/mysql


#modify my.cnf and copy new one


sed 's/default-character-set=gbk/default-character-set=utf8/' my.cnf | sed 's/skip-ssl/#skip-ssl/' >./mysql/my.cnf

chown -R mysql.mysql /project/class2/mysql/my.cnf


#creat ln


ln -s /project/class2/mysql/run/mysql.sock /tmp/mysql.sock


mv /root/.bash_profile /root/.bash_profile.bak


/bin/sed '/export PATH/i\export PATH="$PATH":/project/class2/mysql/bin/' /root/.bash_profile.bak >/root/.bash_profile


#start mysql service

./mysql/bin/mysqld_safe --defaults-file=/project/class2/mysql/my.cnf &


#waitting for service to be started

signal=0

while [[ "$signal" = 0 ]]

do

if [ -z " `grep 'Source distribution' /project/class2/mysql/log/alert.log`" ]

then

echo "not found it"

sleep 30

else

echo "found it"

let signal+=1

fi

done


#logout and relogin, new PATH will be take effect.

kill -9 $PPID

--------------------------------------分割线 --------------------------------------

Ubuntu 14.04下安装MySQL

《MySQL权威指南(原书第2版)》清晰中文扫描版 PDF

Ubuntu 14.04 LTS 安装 LNMP Nginx\PHP5 (PHP-FPM)\MySQL

Ubuntu 14.04下搭建MySQL主从服务器

Ubuntu 12.04 LTS 构建高可用分布式 MySQL 集群

Ubuntu 12.04下源代码安装MySQL5.6以及Python-MySQLdb

MySQL-5.5.38通用二进制安装

--------------------------------------分割线 --------------------------------------

本文永久更新链接地址:

下载本文
显示全文
专题