设为首页 收藏本站
查看: 962|回复: 0

[经验分享] centos6与centos7自动化安装mariadb脚本

[复制链接]

尚未签到

发表于 2018-4-21 07:54:55 | 显示全部楼层 |阅读模式
默认软件包在当前目录下。执行该脚本即可。
交互式安装请参考http://amelie.blog.51cto.com/12850951/1971534。另请注意centos6与centos7的微妙差别哦。


#!/bin/bash
# ------------------------------------------
# Filename: mariadb.sh
# Revision: 1.0
# Date: 2017-10-11
# Author: zhangsan
# Email: 798761864@qq.com
# http://www.ardusty.com/
# boke://amelie.blog.51cto.com/
# Description:
# ------------------------------------------
#定义版本变量
ver=`cat /etc/redhat-release |grep -o [0-9]|head -n1`
#初始化安装环境
[ $ver -eq 7 ] && { yum remove mariadb -y &> /dev/null; }
[ $ver -eq 6 ] && { yum remove mysql -y &> /dev/null; }
pkill -9 -U mysql &> /dev/null
userdel -r mysql &> /dev/null
#创建系统用户
useradd -d /app/mysqldb -r -m -s /sbin/nologin mysql
#解压缩到指定文件夹,创建软链接
file=`cd;ls mariadb-*`
cd;tar xf $file -C /usr/local/ &> /dev/null
cd /usr/local
file1=`ls mariadb-* -d`
rm -rf mysql &> /dev/null
ln -s $file1 mysql
#配置配置文件
mkdir /etc/mysql &> /dev/null
cp /usr/local/mysql/support-files/my-huge.cnf /etc/mysql/my.cnf
sed -r -i "/^\[mysqld\]/s/.*/[mysqld] \ndatadir = \/app\/mysqldb \ninnodb_file_per_table = on \nskip_name_resolve = on \n/" /etc/mysql/my.cnf
cd /usr/local/mysql/
./scripts/mysql_install_db --user=mysql --datadir=/app/mysqldb &> /dev/null
#启动服务
cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld
chkconfig --add mysqld
[ $ver -eq 7 ] && { mkdir /var/log/mariadb &> /dev/null; touch /var/log/mariadb/mariadb.log; chown mysql /var/log/mariadb/mariadb.log; chown mysql /var/log/mariadb; }
[ $ver -eq 6 ] && { touch /var/log/mysqld.log; chown mysql /var/log/mysqld.log; }
service mysqld start &> /dev/null
#PATH变量及安全环境初始化
echo 'PATH=/usr/local/mysql/bin:$PATH' > /etc/profile.d/mysql.sh
echo -e "\ny\nwww.ardusty.com\nwww.ardusty.com\ny\nn\nn\n\y\n"| /usr/local/mysql/bin/mysql_secure_installation &> /dev/null
unset ver file file1  

脚本执行结束后,需要执行. /etc/profile.d/mysql.sh重读下配置文件。阿拉有尝试把这条命令添加到脚本里,但因为脚本执行是子进程,所以脚本结束后,PATH变量的值其实还没有更新。
记得执行. /etc/profile.d/mysql.sh哦。否则会出现以下报错哦。
[root@CentOS6 ~]# mysql
-bash: mysql: command not found  
当然,重读配置文件后我们的基础环境就算配置好了。再执行mysql就不能匿名登录的,正确示例如下。

[root@CentOS6 ~]# mysql
ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: N  
[root@CentOS6 ~]# mysql -uroot -p
Enter password:
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 8
Server version: 5.5.57-MariaDB MariaDB Server
Copyright (c) 2000, 2017, Oracle, MariaDB Corporation Ab and others.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
MariaDB [(none)]> quit
Bye阿拉给默认密码设置为www.ardusty.com了,有需要的可以直接修改脚本里倒数第二行的代码。当然也可以执行数据库命令修改密码。那又是另一个大知识了。
www.ardusty.com是阿拉的个人网站,目前正在建设中。。请先期待一下吧。哈哈。
好了,这次就是这样了。加纳。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-449804-1-1.html 上篇帖子: Centos 6.8 配置DHCP服务器 下篇帖子: CentOS6.X 安装多实例的Tomcat
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表