MySQL数据库之一键自动化部署(定制rpm包)
小标 2019-05-13 来源 : 阅读 1611 评论 0

摘要:本文主要向大家介绍了MySQL数据库之一键自动化部署(定制rpm包) ,通过具体的内容向大家展现,希望对大家学习MySQL数据库有所帮助。

本文主要向大家介绍了MySQL数据库之一键自动化部署(定制rpm包) ,通过具体的内容向大家展现,希望对大家学习MySQL数据库有所帮助。

MySQL数据库之一键自动化部署(定制rpm包)

部署--前篇   

    上午将MySQL多实例部署完成,由于有公司特定一些需求,需要源码安装,现在需要批量部署,如果一台台部署,就太过麻烦,而且浪费时间,这个时候自动化部署 就体现出价值了

    我们将MySQL制作定制化rpm包,然后放到我们的yum仓库中,在将yum所有客户端,都指向yum源,之后就是喝喝茶,看看片,轻松批量部署了,废话不多说,开干。


一、Yum安装介绍

   yum就是{Yellow dog Updater, Modified} ×××的狗,用来针对rpm包的管理器。

它的优点:简单、高效,解决依赖问题;缺点:前期定制包复杂


二、制作rpm包

FPM的作者是jordansissel

FPM的github:https://github.com/jordansissel/fpm 

FPM功能简单说就是将一种类型的包转换成另一种类型

rpm:redhat 包管理器,具有升级、查询、验证,安装,卸载等5大功能;

可通过rpm --help 获取帮助信息  ##--hep用来查看系统内置参数

 1,rpm 支持那些包的转换?

  源类型包:

    dir :将目录打包成rpm包,就是将编译安装好的目录,直接打包,到对端就相当于安装目录解压。
    rpm:对rpm进行转换
    gem:对rubygem进行转换
    pythom :将python包打包成相应的类型

  目标类型包:可以转发成什么类型的包

    rpm         转换为rpm包
    deb         转换为deb包
    solaris       转换为solaris包
    puppet       转换为puppet模块

 2,安装FPM打包工具

  1)安装ruby模块

yum -y install ruby rubygems ruby-devel
 gem sources list  # 查看当前使用的rubygems仓库

   2)更新yum源

 注:添加国内的 淘宝的Rubygems仓库,外国的源慢,移除原生的Ruby仓库

gem sources --add //gems.ruby-china.org --remove //rubygems.org/

   3)安装fpm及json依赖包

gem install json -v 1.8.3
gem install fpm -v 1.3.3

    gem从rubygem仓库安装软件类似yum从yum仓库安装软件。首先安装低版本的json,高版本的json需要ruby2.0以上,然后安装低版本的fpm,够用就行。

# 上面的2步安装仅适合CentOS6系统,CentOS7系统一步搞定,即gem install fpm

  4)验证

rpm --help  #如果有输出代表安装成功

3,FPM参数说明

详细使用见fpm –help

常用参数
-s          指定源类型  (例如dir 目录)
-t          指定目标类型,即想要制作为什么包 (比如想做个rpm包)
-n          指定包的名字 ,-name
-v          指定包的版本号  (用于区分rpm,有同名字但版本不同)
-C          指定打包的相对路径  Change directory to here before searching forfiles
-d          指定依赖于哪些包
-f          第二次打包时目录下如果有同名安装包存在,则强制覆盖它
-p          输出的安装包的目录,不想放在当前目录下就需要指定
--post-install      执行rpm包之后所要运行的脚本;同--after-install
--pre-install      软件包安装完成之前所要运行的脚本;同--before-install
--post-uninstall    软件包卸载完成之后所要运行的脚本;同--after-remove
--pre-uninstall     软件包卸载完成之前所要运行的脚本;同--before-remove

4,定制MySQL rpm包

用法:rpm包执行前运行的脚本 + rpm包 + rpm包执行后脚本

我们这个myslq 之前是编译安装的,所以rpm包运行前脚本没有,直接考虑哪些目录需要打包

1,确认打包目录

rpm需要打包的目录有哪些:(从你编译安装过程中查看哪些需要打包)

/data 目录 ##这个是多实例的数据存放目录
/application/mysql-5.5.32/   #这个是mysql安装目录

2,创建脚本

打包后需要执行的命令,放入脚本中(从你编译安装过程中查看哪些命令需要解压目录后执行)

确认后,创建脚本
mkdir -p /server/scripts && cd /server/scripts
cat >>mysql_rpm.sh<<EOF
#!/bin/bash
useradd -s /sbin/nologin mysql -M -u 503
ln -s /application/mysql-5.5.32/ /application/mysql   #创建软链接
find /data -type f -name "mysql"|xargs chmod +x #给mysql启动脚本+执行权限
chown -R mysql.mysql /data  #授权/data目录mysql 属主属组
cp /application/mysql/bin/* /usr/local/sbin/
/data/3306/mysql start    #启动多实例
/data/3307/mysql start
echo "# mysql multi instances" >>/etc/rc.local  #添加开机自启动
echo "/data/3306/mysql start " >>/etc/rc.local 
echo "/data/3307/mysql start " >>/etc/rc.local
EOF

3,生成rpm包

将目录打包(rpm包,包内包含脚本及目录)(前面是框  后面是苹果)

1)Mysql定制rpm包

[root@db02 scripts]# fpm -s dir -t rpm -n mysql -v5.5.32  --post-install /server/scripts/mysql_rpm.sh -f /data/ /application/mysql-5.5.32/
no value for epoch is set, defaulting to nil {:level=>:warn}
no value for epoch is set, defaulting to nil {:level=>:warn}
Created package {:path=>"mysql-5.5.32-1.x86_64.rpm"}
[root@db02 scripts]# ls
mysql-5.5.32-1.x86_64.rpm  mysql_rpm.sh
#-s 指定目录类型 -t 指定打包类型 -n指定rpm包名 -v 版本号  --post-install 打包后执行的脚本  -f 指定要打包的目录路径
#注意打包要使用相对路径问题

2)站点部署www bbs blog

fpm -s dir -t rpm -n three_web -v 1.0    -f /application/nginx/html/

3)LB负载均衡

fpm -s dir -t rpm -n lb -v 1.8.1 -d 'pcre-devel,openssl-devel' --post-install /server/scripts/install_LB.sh -f  /application/nginx-1.8.1/
lb-1.8.1-1.x86_64

三、查看rpm包内的信息

rpm -qp --scripts  mysql-5.5.32-1.x86_64.rpm     #查看包内脚本信息
rpm -qpl mysql-5.5.32-1.x86_64.rpm      ##查看rpm包内包含哪些文件及目录

注意:mysql这个目录比较大,用fpm打包耗时长。平时我们有可能需要对nginx或php做优化,这样又得重新打包。因此我们可以将mysql分离出来,分别打包。只需在制作nginx+php的rpm包时添加mysql的依赖即可。


四、放入YUM仓库,客户端一键安装测试

    1)上传rpm包到yum仓库

scp mysql-5.5.32-1.x86_64.rpm root@172.16.1.101:/application/yum/centos6.8/x86_64
#我这里yum仓库为内网使用IP地址:172.16.1.101,如果没有*** 可以考虑先给个外网IP10.0.0.101

   2) 更新yum仓库list

[root@Qiuyuetao x86_64]# createrepo --update /application/yum/centos6.8/x86_64/
rpm包名:mysql-5.5.32-1.x86_64.rpm

   3)一键部署Mysql(客户端)

#开启一台新的设备,配置yum仓库客户端
cd /etc/yum.repos.d
mkdir yum_bak && mv *repo yum_bak
cat >>oldboy.repo<<EOF
[oldboy]
name=Server
baseurl=//172.16.1.101/yum
enable=1
gpgcheck=0
EOF
yum clean all     
##清空缓存
如果yum仓库中,一个软件有多个版本,可以采用如下方法安装,(你需要的版本)
1,yum list|grep 关键字
2,将软件版本 复制
3,yum install  复制内容

测试MySQL 登录

[root@db01 ~]# netstat -lntup|grep 33
tcp        0      0 0.0.0.0:3306                0.0.0.0:*                   LISTEN      2812/mysqld        
tcp        0      0 0.0.0.0:3307                0.0.0.0:*                   LISTEN      2833/mysqld
[root@db01 ~]# mysql -uroot -S /data/3306/mysql.sock
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 1
Server version: 5.5.32-log Source distribution

Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| test               |
+--------------------+
4 rows in set (0.03 sec)

##为安全起见设置myslq密码 及 删除无用账户,权限最小化 设置等等都可自行配置了

本文由职坐标整理并发布,希望对同学们学习MySQL有所帮助,更多内容请关注职坐标数据库MySQL数据库频道!


本文由 @小标 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程