部署--前篇
上午将MySQL多实例部署完成,由于有公司特定一些需求,需要源码安装,现在需要批量部署,如果一台台部署,就太过麻烦,而且浪费时间,这个时候自动化部署 就体现出价值了
我们将MysqL制作定制化rpm包,然后放到我们的yum仓库中,在将yum所有客户端,都指向yum源,之后就是喝喝茶,看看片,轻松批量部署了,废话不多说,开干。
如果MysqL多实例还没配置的,或不了解软件的安装方式 的
请参考:http://qiuyt.blog.51cto.com/1229789/1920686
# 博主新的博客地址: https://www.dgstack.cn/ 进入有惊喜哦~~ 欢迎收藏
一、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 http://gems.ruby-china.org --remove http://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=http://172.16.1.101/yum enable=1 gpgcheck=0 EOF yum clean all ##清空缓存 如果yum仓库中,一个软件有多个版本,可以采用如下方法安装,(你需要的版本) 1,yum list|grep 关键字 2,将软件版本 复制 3,yum install 复制内容
[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安全的帖子,请您多多支持,多多关注,谢谢。 如有问题随时留言,沟通,感谢!!!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。