Linux企业级——自动化部署工具SaltStack

116 篇文章 0 订阅
114 篇文章 0 订阅

Linux企业级——SaltStack

1.SaltStack简介

Saltstack是基于Python开发的一套C/S架构,具备Puppet、Ansible功能于一身的配置管理工具,功能十分强大,各模块融合度及复用性极高;使用号称世界上最快的消息队列ZeroMQ使得Saltstack能够秒级在数万台服务器上进行各种操作,而且使用RAS Key方式确认身份,传输采用AES加密,安全性能更高。通过部署SaltStack,我们可以在成千万台服务器上做到批量执行命令,根据不同业务进行配置集中化管理、分发文件、采集服务器数据、操作系统基础及软件包管理等,SaltStack是运维人员提高工作效率、规范业务配置与操作的利器。

SaltStack服务端 master 和客户端 minions ;Saltstack 和 Puppet 很像,可以说 Saltstatck 整合了 Puppet 和 Chef 的功能,更加强大,更适合大规模批量管理服务器,并且它比 Puppet 更容易配置。

三大功能: 远程命令执行,配置管理(服务,文件,cron,用户,组),云管理。

2.SaltStack安装部署

实验环境
主机名ip服务
server1172.25.1.1服务端 salt-master
server2172.25.1.2客户端 salt-minion
server3172.25.1.3客户端 salt-minion
2.1 saltstack安装部署
2.1.1 配置yum源
注:三台虚拟机均配置
vim salt.repo
[salt]
name=salt
baseurl=http://172.25.66.250/2019
gpgcheck=0

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

2.1.2 安装服务
server1上:
yum install salt-master -y				#安装服务端

在这里插入图片描述

server2上:
yum install salt-minion -y				#安装用户端
vim /etc/salt/minion					#修改配置文件
	16 master: 172.25.66.1

在这里插入图片描述

在这里插入图片描述

server3上:
yum install salt-minion -y				#安装用户端
vim /etc/salt/minion					#修改配置文件
	16 master: 172.25.66.1

在这里插入图片描述
在这里插入图片描述

2.1.3 开启服务
server1上:
systemctl start salt-master			#启动服务
systemctl enable salt-master		#设置开机自启动
systemctl status salt-master		#查看服务状态

在这里插入图片描述

server2和server3上:
systemctl start salt-minion			#启动服务
systemctl enable salt-minion		#设置开机自启动
systemctl status salt-minion		#查看服务状态

在这里插入图片描述
在这里插入图片描述

2.1.4 查看认证
server2和server3上:
cd /etc/salt/pki/minion/		#进入存放目录
ls

在这里插入图片描述

在这里插入图片描述

2.1.5 查看端口
yum install -y lsof.x86_64 0:4.87-5.el7		#下载lsof工具包

在这里插入图片描述

lsof -i :4505			#查看saltstack的消息发布系统端口
lsof -i :4506			#查看saltstack客户端与服务端通信的端口

在这里插入图片描述

2.1.6 master端做认证
salt-key -L				#查看所有minion-key
salt-key -A				#接受所有等待认证的key

在这里插入图片描述

2.1.7 检测链接
salt server2 test.ping
salt server3 test.ping

在这里插入图片描述

2.1.8 查看主机的public key
cd /etc/salt/pki/master/
tree .   #查看当前目录的树形结构

在这里插入图片描述

2.1.9 查看对应文件md5值
server1:
md5sum server2

在这里插入图片描述

server2:
public key的md5值:
md5sum minion.pub

在这里插入图片描述

此时发现这两个的md5值是相同的
server1:
md5sum server3

在这里插入图片描述

server3:
public key的md5值:
md5sum minion.pub

在这里插入图片描述

2.2 查看服务开启进程名称
yum install python-setproctitle -y   #下载该服务,可以查看saltstack服务开启进程的名称
systemctl restart salt-master  #重启salt-master服务
ps aux  #查看进程

在这里插入图片描述

3.apache的部署

3.1 添加/srv/salt/apache.sls文件:
apache-install:   #声明
  pkg.installed:  #模块
    - pkgs:        #方法
      - httpd      #传参
      - httpd-tools

  file.managed:    #file模块managed方法
    - name: /etc/httpd/conf/httpd.conf   #name:位置
    - source: salt://apache/files/httpd.conf  #source:来源  salt服务端基于目录/srv/salt

  service.running:  #service运行服务
    - name: httpd  #name:服务名称
    - reload: true  #重启,每次修改配置文件,都会触发重启,可以声明以reload方式重启。
    - watch:   #监控文件,如果有变化则服务重启
      - file: apache-install  #到apache-install唯一性文件声明中找file定义

在这里插入图片描述

3.2 拷贝配置文件
3.2.1 创建相关目录
cd /srv/salt/apache		#进入目录
mkdri files			#存放.sls文件中添加服务需要用到的文件

在这里插入图片描述

3.2.2 拷贝文件
server3:
yum install -y httpd		#安装apache服务
scp /etc/httpd/conf/httpd.conf root@server1:/srv/salt/apache/files		#传送文件

在这里插入图片描述

在这里插入图片描述

server1:
cd /srv/salt/apache/files	#进入目录
ls		#查看

在这里插入图片描述

3.3 执行apache.sls
salt server2 state.sls apache.apache  #调用状态模块的sls方法,执行apache目录下的apache文件,appache.sls文件的sls后缀可不写

在这里插入图片描述
在这里插入图片描述

3.3.1 在server2中测试
systemctl status httpd			#查看apache服务状态

在这里插入图片描述

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Linux 多tomcat服务 统一安装 统一部署 工具 shell编写 1 引言 基于JAVA开发项目,随着服务的越来越多,配置文件更是眼花缭乱,每次不知道因为配置问题浪费多少时间,更不知道因为配置问题出过多少问题。多台服务器来回切换,如果服务需要依赖,启动更是问题。 1.1 目的 一次修改,统一安装;操作简单,实用高效。 1.2 范围 本项目使用范围包括: * 基于JAVA开发项目 * 项目相关服务繁多 * 服务启动有依赖关系 1.3 读者 本需求规格说明书的阅读者或其他文档干系人有平台总监、产品经理、项目总监、项目经理、开发人员、测试人员、用户体验设计人员等。 2 项目总体描述 2.1 系统总体功能框架 2.2 系统功能列表 Exec 建立信任、初始命令 初始 Tools 提供服务与服务列表 扫描提供服务列表,获取配置信息 Conf 自动获取需要修改配置 自动生成 Bin 执行脚本 提供总执行与单一执行脚本 New 存放修改后配置文件 与bak保留文件成反比 Bak 存放原始配置文件 便于问题分析 Temp 存放临时文件 临时文件将及时删除无任何冗积 Workapp 存放war包 上传war包 3 功能描述 3.1 获取配置文件 通过本系统获取配置文件非常简单,只需用户提供服务列表,其他无需操作。服务列表如下: name ip serve 服务名称 192.168.0.1 /home/tomcat_服务名称 服务名称 192.168.1.2 /home/tomcat_服务名称 服务名称 192.168.1.2 /home/tomcat_服务名称 名词解释: name :服务名称,需与war包名称一致。 ip :服务器ip地址。 serve :Tomcat部署路径。 执行脚本,“.. /unifyDeploy/conf”自动生成用户所需修改配置文件,配置文件是通过筛选后生成,所以一个服务不管需要配置多少文件,这里只生成一个,方便修改与管理。 3.2 自动化统一安装部署 自动化统一安装部署,包括:上传解压war包、同步配置、启动服务、监控服务等。 list.ll one.sh pass.war startup.sh syn.cn two.sh 部署支持统一安装于分布式安装,每个脚本可以拆分开任意组合使用,比如: 1) 一套新环境tomcat中还未部署服务,只需调整上传war包脚本顺序,先上传war后,后续操作正常执行。 2) 迭代更新,功能稍作修改,原配置项无需修改,也只需调整上传war包脚本顺序,先获取原有配置,再上传更新war包,后续操作正常执行。 3.3 优缺点描述 优点描述: * 适用于统一安装部署,也适用于单独服务安装部署。 * 保留原始备份,方便部署前后配置对比。 * 操作简单、需求扩展能力强。 不足描述: * 暂时只适用于基于tomcat服务器项目。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值