shell脚本安装mysql_Shell学习成果之一键自动安装Mysql8.0

实验环境

系统:CentOS7.7.1908

MySql:mysql-8.0.18-el7-x86_64.tar.gz

一键安装脚本如下(可直接复制粘贴为shell脚本,与MySQL安装包放到同一目录;如果没有下载安装包就取消第26行的注释会自动下载MySQL安装包)

*************************************************************************START************************************************************************

#!/bin/bash

#auto install mysql8.0

#by 网络小虾米 2019-11-19

olddb=`rpm -qa|grep mariadb` &&rpm -e --nodeps $olddb ;

useradd -M -s /sbin/nologin mysql &&

mkdir -p /usr/local/mysql &&

mkdir -p /usr/local/mysql/data &&

mkdir -p /usr/local/mysql/log &&

mkdir -p /usr/local/mysql/log/binlog &&

mkdir -p /usr/local/mysql/log/tmp &&

touch /usr/local/mysql/log/mysqld.log &&

chmod -R 777 /usr/local/mysql/log/ &&

chmod -R 777 /usr/local/mysql/data &&

chown -R mysql:mysql /usr/local/mysql/

if [ $? -eq 0 ];then

echo -e "\033[32mMysql environment Great Sueecssfully!\033[0m"

else

echo -e "\033[32mMysql environment Great Failed,Please check it.\033[0m"

exit

fi

#wget -c  https://cdn.mysql.com//Downloads/MySQL-8.0/mysql-8.0.18-el7-x86_64.tar.gz ;

tar -xzvf mysql-8.0.18-el7-x86_64.tar.gz &&

mv mysql-8.0.18-el7-x86_64/* /usr/local/mysql/ ;

cd /usr/local/mysql &&/usr/local/mysql/bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql/ --datadir=/usr/local/mysql/data/ --log-error=/usr/local/mysql/log/mysqld.log ;

if [ $? -eq 0 ];then

echo -e "\033[32mMysql8.0 install complete!\033[0m"

else

echo -e "\033[32mMysql8.0 install Failed.please check it.\033[0m"

exit

fi

touch /etc/my.cnf ;

echo "

[client]

port=3306

default-character-set=utf8

[mysqld]

port=3306

basedir=/usr/local/mysql

datadir=/usr/local/mysql/data

user=mysql

default-storage-engine=INNODB

character-set-server=utf8

bind-address=0.0.0.0

[mysqld_safe]

log-error=/usr/local/mysql/log/mysqld.log" >> /etc/my.cnf ;

chmod 644 /etc/my.cnf &&chown -R mysql:mysql /etc/my.cnf ;

cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld ;

sed -i '46s/basedir=/basedir=\/usr\/local\/mysql/g' /etc/init.d/mysqld &&sed -i '47s/datadir=/datadir=\/usr\/local\/mysql/g' /etc/init.d/mysqld ;

chmod +x /etc/init.d/mysqld &&service mysqld start

if [ $? -eq 0 ];then

echo -e "\033[32mMysql 8.0 auto install successfully!\033[0m"

else

echo -e "\033[32mMysql8.0 auto install Failed,Please check it.\033[0m"

exit

fi

echo 'export PATH=$PATH:/usr/local/mysql/bin' >>/etc/profile &&source /etc/profile ;

chkconfig  --add mysqld &&chkconfig mysqld on

exit

**************************************************************************END*************************************************************************

脚本运行完成后,MySql安装完成并启动,然后修改默认密码

#cat /usr/local/mysql/log/mysqld.log

一般在日志的第二行,找到[Server] A temporary password is generated for root@localhost: d5iGg/rg0ogC  //冒号后面的是默认密码

#mysql -uroot -p

#Enter password:d5iGg/rg0ogC 根据实际密码进行输入

#alter user 'root'@'localhost' identified by 'qwe123!@#';

#flush privileges;

设置远程访问

>use mysql;

>select host, user, plugin from user;

41f0352e434773a0bc0b9a1c94a744f1.png

>alter user 'root'@'localhost' identified with mysql_native_password by 'qwe123!@#';

>update user set host='%' where user='root';

>flush privileges;

>grant all privileges on *.* to 'root'@'%' with grant option;

>flush privileges;

>select host, user, authentication_string, plugin from user;

3931ee644e8b3336f687d1ea60c67f7f.png

>exit;

659455044e32742496d7abbb08cb5c88.png

排错

### /usr/local/mysql/bin/mysqld safe--defaults-file=/etc/my.cnf --user=mysql###安全模式启动mysql

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值