自动化运维工具Saltstack学习笔记(一)

简介:

1.Saltstack简介
Saltstack是一个具备puppet与func功能为一身的集中化,轻量级的自动化运维管理工具,使用python编写,功能非常强大,可以使用EPEL快速安装。相比较puppet,安装和配置更加容易和简单。下面是Saltstack安装和基础配置文档。(官方文档:http://docs.saltstack.com/topics/installation/rhel.html)

2.物理环境

140719570.jpg

3.安装前准备

修改服务器的主机名和hosts,使其能相互解析和ping通,下面以saltmaster为例。

1
2
3
4
5
6
7
8
9
#修改主机名vim /etc/sysconfig/network
HOSTNAME=SaltMaster
#查看主机名
[root@saltmaster ~] # hostname
saltmaster
#修改/etc/hosts文件,添加如下内容
192.168.1.235 SaltMaster
192.168.1.248 WEB248
192.168.1.244 DB244

4.安装Saltstack

利用EPEL源安装saltstack。

1
2
3
4
5
6
#导入EPEL YUM源
rpm -Uvh http: //mirror .pnl.gov /epel/5/i386/epel-release-5-4 .noarch.rpm
#服务器master的安装
yum -y  install  salt-master
#客户端minon安装
yum -y  install  salt-minion

5.Saltstack配置

1
2
3
4
5
6
7
8
#服务器master的配置,vim /etc/salt/master添加master侦听的IP地址。
# The address of the  interface  to bind to
interface 192.168 . 1.235
#客户端minion的配置,vim /etc/salt/minion,添加master IP地址和minion ID号,ID建议用主机名来配置。。
# Set the location of the salt master server
master:  192.168 . 1.235
# clusters.
id: WEB2013- 10 - 023

6.启动Saltstack服务

1
2
3
4
5
6
#saltstack master启动和设置开机自动启动
/etc/init .d /salt-master  start
chkconfig salt-master on
#Saltstck minion启动和设置开机自动启动
/etc/init .d /salt-minion  start
chkconfig salt-minion on

7.Saltstack master认证Minion KEY

Saltstack使用公共密钥加密来保证master和minions的安全通信。安装的时候Salt自动生成这些证书,但需要在master端验证minion的证书来确认master和minion之间是授信的。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
[root@SaltMast ~] # salt-key list
Accepted Keys:
Unaccepted Keys:
DB2012-08-001
WEB2013-10-023
Rejected Keys:
#证书认证用命令salt-key -a id
[root@SaltMast ~] # salt-key -a DB2012-08-001
The following keys are going to be accepted:
Unaccepted Keys:
DB2012-08-001
Proceed? [n /Y ] y
Key  for  minion DB2012-08-001 accepted.
[root@SaltMast ~] # salt-key -a WEB2013-10-023
The following keys are going to be accepted:
Unaccepted Keys:
WEB2013-10-023
Proceed? [n /Y ] y
Key  for  minion WEB2013-10-023 accepted.
#查看认证通过的证书
[root@SaltMast ~] # salt-key list
Accepted Keys:
DB2012-08-001
WEB2013-10-023
Unaccepted Keys:
Rejected Keys:

8.Saltstack测试

1)连通性测试:Saltstack证书认证通过以后,就可以进行通信,在master通过test.ping命令来测试它们之间的连接。通配符"*"代表了所有minion。

130404671.jpg

2)利用salt远程执行命令:在Saltstack master端通过执行"salt id 系统命令"来返回minion执行结果。

132036816.jpg

9.Saltstack分组及其测试

1)为什么要分组?线上WEB,DB,IMG等安装配置相同或者相近的服务器可分为一组,方便批量安装和管理,编辑 /etc/salt/master 添加如下内容,每个组可以有N多服务,每个服务器用逗号分隔。

1
2
3
4
5
6
# nodegroups:
#   group1: 'L@foo.domain.com,bar.domain.com,baz.domain.com and bl*.domain.com'
#   group2: 'G@os:Debian and foo.domain.com'
nodegroups:
   wwwgroup:   'L@WEB2013-10-023,DB2012-08-001'
   dbgroup:   'DB2012-08-001'

2)分组测试

135057802.jpg

      总结:SaltStack安装和基本的配置已经完成,可以通过SaltStack批量执行系统命令,包括重启系统,重启服务,查看系统负载,添加/删除用户等等。我已经被salt的强大功能所折服,有时间我将研究一下Salt包的定制安装,文件分发等更强大的功能。

      salt key相关命令总结:   

1
2
3
4
5
  salt-key list   查看已经认证或未认证的客户端 id ,Accepted Keys为已认证清单,Unaccepted Keys为未认证的清单,Rejected Keys为拒绝的清单。
  salt-key -a  id   认证单个主机 id 证书请求。
  salt-key -A     认证所有主机 id 证书请求。
  salt-key -d  id   删除单个主机 id 证书。
  salt-key -D     删除所有认证主机 id 证书。









本文转自 sfzhang 51CTO博客,原文链接:http://blog.51cto.com/sfzhang88/1313019,如需转载请自行联系原作者

目录
相关文章
|
9天前
|
弹性计算 运维 监控
云资源运维难?阿里云免费工具来帮忙
阿里云推出免费运维工具——云服务诊断,帮助用户提升对云资源的运维效率、降低门槛、减轻负担。其核心功能包括「健康状态」和「诊断」。通过「健康状态」可实时查看云资源是否正常;「诊断」功能则能快速排查网络、配置、安全等问题,并提供修复建议,助您迅速恢复业务。体验评测活动火热进行中,参与即有机会赢取索尼头戴耳机、小米背包等好礼。活动链接:https://developer.aliyun.com/topic/cloud-health。
177 10
|
1月前
|
运维 Kubernetes Devops
自动化运维:从脚本到工具的演进之旅
在数字化浪潮中,自动化运维成为提升效率、保障系统稳定的关键。本文将探索自动化运维的发展脉络,从基础的Shell脚本编写到复杂的自动化工具应用,揭示这一技术变革如何重塑IT运维领域。我们将通过实际案例,展示自动化运维在简化工作流程、提高响应速度和降低人为错误中的重要作用。无论你是初学者还是资深专家,这篇文章都将为你提供宝贵的洞见和实用的技巧。
|
2月前
|
机器学习/深度学习 运维 监控
智能化运维:从自动化到AIOps的演进之路####
本文深入探讨了IT运维领域如何由传统手工操作逐步迈向高度自动化,并进一步向智能化运维(AIOps)转型的过程。不同于常规摘要仅概述内容要点,本摘要将直接引入一个核心观点:随着云计算、大数据及人工智能技术的飞速发展,智能化运维已成为提升企业IT系统稳定性与效率的关键驱动力。文章详细阐述了自动化工具的应用现状、面临的挑战以及AIOps如何通过预测性分析和智能决策支持,实现运维工作的质变,引领读者思考未来运维模式的发展趋势。 ####
|
2月前
|
机器学习/深度学习 数据采集 人工智能
智能化运维:从自动化到AIOps的演进与实践####
本文探讨了智能运维(AIOps)的崛起背景,深入分析了其核心概念、关键技术、应用场景及面临的挑战,并对比了传统IT运维模式,揭示了AIOps如何引领运维管理向更高效、智能的方向迈进。通过实际案例分析,展示了AIOps在不同行业中的应用成效,为读者提供了对未来智能运维趋势的洞察与思考。 ####
96 1
|
2月前
|
机器学习/深度学习 人工智能 运维
自动化运维之路:从脚本到工具的演进
在IT运维领域,效率和准确性是衡量工作成效的关键指标。随着技术的发展,自动化运维逐渐成为提升这两个指标的重要手段。本文将带领读者了解自动化运维的演变历程,从最初的简单脚本编写到现今复杂的自动化工具应用,展示如何通过技术提升运维效率。文章不仅介绍理论和实践案例,还提供了代码示例,帮助读者理解自动化运维的实际应用场景。
|
2月前
|
运维 Ubuntu 应用服务中间件
自动化运维工具Ansible的实战应用
【10月更文挑战第36天】在现代IT基础设施管理中,自动化运维已成为提升效率、减少人为错误的关键手段。本文通过介绍Ansible这一流行的自动化工具,旨在揭示其在简化日常运维任务中的实际应用价值。文章将围绕Ansible的核心概念、安装配置以及具体使用案例展开,帮助读者构建起自动化运维的初步认识,并激发对更深入内容的学习兴趣。
74 4
|
2月前
|
机器学习/深度学习 数据采集 人工智能
智能运维:从自动化到AIOps的演进与实践####
本文探讨了智能运维(AIOps)的兴起背景、核心组件及其在现代IT运维中的应用。通过对比传统运维模式,阐述了AIOps如何利用机器学习、大数据分析等技术,实现故障预测、根因分析、自动化修复等功能,从而提升系统稳定性和运维效率。文章还深入分析了实施AIOps面临的挑战与解决方案,并展望了其未来发展趋势。 ####
|
2月前
|
运维 监控 数据安全/隐私保护
自动化运维工具的设计与实现
【10月更文挑战第34天】在现代IT基础设施管理中,自动化运维工具扮演着至关重要的角色。它们不仅提高了运维效率,还确保了服务的连续性和稳定性。本文将深入探讨如何设计并实现一个自动化运维工具,从需求分析到功能实现,再到最终的测试与部署。我们将通过一个简单的代码示例来展示如何自动执行常见的运维任务,如日志清理和性能监控。文章旨在为读者提供一套完整的方法论,以便他们能够构建自己的自动化运维解决方案。
|
消息中间件 监控 网络协议
SaltStack安装Apache/Mysql/PHP部署Wordpress
SaltStack是一个服务器基础架构集中化管理平台,具备配置管理、远程执行、监控等功能,基于Python语言实现,结合轻量级消息队列(ZeroMQ)与Python第三方模块(Pyzmq、PyCrypto、Pyjinjia2、python-msgpack和PyYAML等)构建。 SaltStack 采用 C/S模式,server端就是salt的master,client端就是minion,minion与master之间通过ZeroMQ消息队列通信。 master监听4505和4506端口,4505对应的是ZMQ的PUB system,用来发送消息,4506对应的是REP system是来接受
180 0