乐趣区

关于mysql:一键编译部署Mysql

#!/bin/bash
# 一键装置 mysql5.7.35

#安装包下载目录
MYSQL_DOWNLOAD_DIR=/data/software/
#数据包目录
MYSQL_INSTALL_DIR=/data/modules/

#数据库信息
info_mysql(){
    echo "======> MYSQL 装置信息 <======";
    echo "Mysql 版本:5.7.35";
    echo "下载目录:/data/software/";
    echo "装置目录:/data/modules/";
}

#旧版 mysql
uninstall_mysql(){
    echo "\n======> MYSQL 装置筹备 <======";
    echo "残留 Mysql 检测......."
    echo "卸载旧版 mysql......."
    echo [+] Uninstall Mysql
    yum remove mysql* -y
    yum remove mariadb* -y
    if [-f "/etc/my.cnf"];then
        rm -rf /etc/my.cnf
    fi

    if [-f "/root/.mysql_sercret"];then
        rm -rf /root/.mysql_sercret
    fi

    if [-d "/var/lib/mysql"];then
        rm -rf /var/lib/mysql
    fi
 
    if [-d "/usr/lib64/mysql"];then
        rm -rf /usr/lib64/mysql
    fi
 
    if [-d "/usr/share/mysql"];then
        rm -rf /usr/share/mysql
    fi
    echo "卸载实现!"
}
 
#下载 mysql
IS_CINTINUE='y';
download_mysql(){
    echo "装置目录检测......."
    if [! -d "/data/software"]; then
        echo "创立下载目录......."
        mkdir -p /data/software/
    fi
    if [! -d "/data/modules/mysql/"]; then
        echo "创立数据目录......."
        mkdir -p /data/modules/
    fi
    echo "目录准备就绪 !";
    echo "======> MYSQL 装置过程 <======";
    cd /data/software/
    read -p "确认是否装置?【y/n】" IS_CINTINUE
    if [[$IS_CINTINUE == 'y']]; then
        echo "请稍等, 大概须要 20 分钟, 正在下载 MYSQL.......";
        cd /data/software/
        file="/data/software/mysql-boost-5.7.35.tar.gz"
        if [! -f $file]; then
            echo "File not found!"
            yum install -y wget && wget -c https://cdn.mysql.com/archives/mysql-5.7/mysql-boost-5.7.35.tar.gz;
            echo "下载实现, 正在解压.......";
            tar -zxvf mysql-boost-5.7.35.tar.gz -C /data/modules/
            cd /data/modules/
            mv /data/modules/mysql-5.7.35/ mysql
            exit 0
        fi
        echo "解压实现, 执行装置.......";
        
        #yum install -y wget && wget -c https://cdn.mysql.com/archives/mysql-5.7/mysql-5.7.35-el7-x86_64.tar.gz;
    else
        echo "请您自行下载安装包!";
        exit;
    fi

}

#装置 mysql
install_mysql(){
    echo "======> 装置 mysql 依赖....... <======";
    yum -y install gcc gcc-devel gcc-c++ gcc-c++-devel autoconf* automake* zlib* libxmlncurses-devel ncurses libgcrypt libtool* cmake openssl openssl-devel bisonbison-devel perl-Data-Dumper boost boost-doc boost-devel
    yum -y install gcc make cmake ncurses-devel libxml2-devel libtool-ltdl-devel gcc-c++ autoconf automake bison zlib-devel
    echo "======> 装置前的设置 <======";
    sleep 2s
    cd /data/modules/mysql/
    mkdir data
    sleep 2s
    cmake -DCMAKE_INSTALL_PREFIX=/data/modules/mysql/ \
    -DMYSQL_DATADIR=/data/modules/mysql/data \
    -DSYSCONFDIR=/etc \
    -DWITH_MYISAM_STORAGE_ENGINE=1 \
    -DWITH_INNOBASE_STORAGE_ENGINE=1 \
    -DWITH_MEMORY_STORAGE_ENGINE=1 \
    -DWITH_READLINE=1 \
    -DMYSQL_UNIX_ADDR=/tmp/mysqld.sock \
    -DMYSQL_TCP_PORT=3306 \
    -DWITH_BOOST=/data/modules/mysql/boost \
    -DENABLED_LOCAL_INFILE=1 \
    -DWITH_PARTITION_STORAGE_ENGINE=1 \
    -DEXTRA_CHARSETS=all \
    -DDEFAULT_CHARSET=utf8 \
    -DDEFAULT_COLLATION=utf8_general_ci
    echo "======> 创立 mysql 用户和组 <======";
    cd /data/modules/mysql/
    sleep 2s
    make && make install
    groupadd mysql && useradd mysql -g mysql -M -s /sbin/nologin && chown mysql:mysql /data/modules/mysql/
    # if [$? -eq 0];then
    #         echo "======> 设置胜利!开始编译装置,大概须要 20 分钟,急躁期待...<======";
    #         sleep 2s
    #         make && make install
    #         if [$? -eq 0]; then
    #             cd ~
    #             echo "======> 编译胜利!开始设置组和用户!<======";
    #             sleep 2s
    #             groupadd mysql && useradd mysql -g mysql -M -s /sbin/nologin && chown mysql:mysql /data/modules/mysql/
    #         else
    #             echo "======> 编译失败!<======";
    #             exit;
    #         fi
    #     else
    #             echo "======> 设置失败!<======";
    #             exit;
    # fi
    echo "======> 装置实现! <======";
}

#配置 Mysql
configuration_mysql(){

echo "======> 配置 mysql <======";
cd /data/modules/mysql/
touch mysql.pid
echo "10254" > /data/modules/mysql/mysql.pid
touch mysql.err
touch mysqld.sock
chown mysql:mysql /data/modules/mysql/mysql.pid
chown mysql:mysql /data/modules/mysql/mysql.err
chown mysql:mysql /data/modules/mysql/data/mysqld.sock
cat > /etc/my.cnf<<EOF
[client]
port            = 3306
socket          = /data/modules/mysql/data/mysqld.sock
[mysqld]
#server-id  = 6878                           #运行 ID
bind-address=0.0.0.0                        #绑定地址运行近程连贯
port=3306                                   #Mysql 凋谢的端口
user=mysql                                  #数据库登录用户
basedir=/data/modules/mysql/                #Mysql 装置的绝对路径
datadir=/data/modules/mysql/data            #Mysql 数据寄存的绝对路径
socket=/data/modules/mysql/data/mysqld.sock #套接字文件
log-error=/data/modules/mysql/mysql.err     #mysql 生成的谬误日志寄存的门路
pid-file=/data/modules/mysql/mysql.pid      #为 mysqld 程序指定一个寄存过程 ID 的文件
character_set_server=utf8                   #数据库字符编码
symbolic-links=0                            #是否开启链接符号
explicit_defaults_for_timestamp=true        #数据库 timestamp 类型的列自动更新  
EOF


sleep 2s
echo "初始化 mysql.......";
cd /data/modules/mysql/bin
./mysqld --defaults-file=/etc/my.cnf --basedir=/data/modules/mysql/ --datadir=/data/modules/mysql/data/ --user=mysql --initialize
ln -s  /data/modules/mysql/bin/mysql    /usr/bin
}

#将 mysql 设置成为服务启动
service_mysql(){
    echo "======> 制作服务启动 <======";
    cd /data/modules/mysql
    /bin/cp -rf support-files/mysql.server /etc/init.d/mysqld
    chmod a+wrx /etc/init.d/mysqld
    if [$? -eq 0]; then
        echo "======> 服务设置胜利!<======";
        cd ~
        service mysqld start
        sleep 2s
        service mysqld stop
        sleep 2s
    else
        echo "======> 服务设置失败!<======";
    fi

    echo "======> 增加到开机启动项!<======";
    chkconfig --add mysqld
    if [$? -eq 0]; then
        echo "======> 设置开机启动项胜利!<======";
    else
        echo "======> 设置开机启动项失败!<======";
    fi
    service mysqld stop
    echo "======> 配置环境变量 <======";
    echo "export PATH=$PATH:/data/modules/mysql/bin/" >>/etc/profile
    source /etc/profile
    echo "启动 mysql 服务.......";service mysqld start
    echo "Mysql 曾经启动.......";}


#启动数据库设置明码
# mysql_password='123456'
# up_mysql(){
#     cd /data/modules/mysql/
#     echo "======> 请输出数据库明码: <======";
#     read -p "输出明码:" -s mysql_password echo
#     echo password read, is "$mysql_password"
#     # read -p "确认是否装置?【y/n】" IS_CINTINUE
#     # ./bin/mysqladmin -u root password "123456"
#     if [$? -eq 0];then
#         echo "设置 root 明码胜利!";
#     else
#         echo "设置 root 明码失败!";
#     fi
#     source /etc/profile
# }

#完结装置
end_mysql(){
    echo "运行端口: 3306"
    echo "数据库用户: mysql"
    echo "数据库 root 明码 (root@localhost 前面):"
    cat /data/modules/mysql/mysql.err | grep root@localhost:
    echo "数据库装置门路: /data/modules/mysql/"
    echo "数据库数据门路: /data/modules/mysql/data"
    mysql -uroot -p
}

#装置流程
mysql(){
    #数据库信息
    info_mysql
    #旧版数据库卸载
    uninstall_mysql
    #下载数据库
    download_mysql
    #装置数据库
    install_mysql
    #配置数据库
    configuration_mysql
    #数据库以服务启动
    service_mysql
    #启动 MySQL 设置明码
    #显示数据库信息
    info_mysql
    end_mysql

}
mysql
退出移动版