Stackstorm 框架初探

2024-02-02 03:18
文章标签 框架 初探 stackstorm

本文主要是介绍Stackstorm 框架初探,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1介绍:

官方解释:StackStorm是一个功能强大的开源自动化平台,可将所有应用程序,服务和工作流程连接起来。 它具有可扩展性,灵活性, 设计中包含了对DevOps和ChatOps的热爱。它可以将您现有的基础架构和应用程序环境联系在一起,以便您可以更轻松地自动化操作该环境。它特别专注于针对事件采取行动。

我的理解:通过事件驱动的方式来达到自动化执行动作的引擎。
盗图一张:
在这里插入图片描述

2 StackStorm组成

StackStorm环境中的插件是通过扩展传感器和动作实现。

1 Sensors

是用于内部或外部集成的Python插件,该插件可以接受到个自的事件。
当一个外部系统的事件发生时,该事件可以被一个sensor处理,一个StackStorm
的trigger触发器将会发射到系统中。

2 Triggers

是StackStorm中外部事件的表现。有通用的triggers(例如:timers, webhooks)
和集成的triggers(例如: Sensu alert, JIRA问题更新)。一个新的trigger类型可以
通过编写一个sensor插件来定义。

3 Actions

是StackStorm外部集成。有一般的actions(ssh, REST调用),intergrations(
OpenStack, Docker, Puppet),或者定制化actions。
Actions要么是Python插件,或者是任何脚本,通过添加几行代码到metadata中来被StackStorm
消费。Actions可以被用户通过命令行或者API直接调用,或者作为rules和workflows的一部分被使用。

4 Rules

映射triggers到actions(或者workflows),应用匹配的criteria和映射
trigger payload到action输入。

5 Workflows

将actions组装到uber-actions,定义顺序,转换条件,
并传递数据。大多数自动化不止一步,因此需要不止一个action。
Workflows,就像原子actions,可以在Action库中获取,可以被手动调用或者
被规则触发。

6 Packs

是内容步数的单元。它们简化了管理并通过分组集成(
triggers和actions
)和自动化(rules和workflows)来共享StackStorm插件化内容。
大量packs可以从
https://exchange.stackstorm.org/
获得。用户可以创建他们自己的packs,在Github上共享它们,
或者提交到StackStorm的Exchange。
7) Audit trail

审计跟踪动作执行,手动或自动化的触发上下文和执行结果被记录和存储。
它也可以在audit日志终被布或到,用于集成到外部日志系统和分析工具:
LogStash, Splunk, statsd, syslog。

3 框架执行流程:

1, 各个服务系统通过push的方式将事件发送给传感器。
2,传感器接收事件触发触发器
3,触发器根据规则解析事件。
4,根据解析结果执行对应的action。
5,action执行完成结果返回给规则引擎进一步处理。

4,环境配置:

可以参考官方文档,环境系统要求linux,文档介绍比较全,有多种方式安装,比如利用容器docker ,Kubernets等等。为了开发方便,我这边直接安装了ubuntu系统。

按照文档安装同时注意版本基本没有什么问题,我这边列几个需要注意的细节:
https://docs.stackstorm.com/install/u18.html

1 nginx 安装启动异常:

$ sudo service nginx restart
Job for nginx.service failed because the control process exited with error code.
See “systemctl status nginx.service” and “journalctl -xe” for details.

查看异常原因

$ nginx -t
nginx: [alert] could not open error log file: open() “/var/log/nginx/error.log” failed (13: Permission denied)
2020/01/07 15:03:31 [warn] 6215#6215: the “user” directive makes sense only if the master process runs with super-user privileges, ignored in /etc/nginx/nginx.conf:1
2020/01/07 15:03:31 [emerg] 6215#6215: a duplicate default server for 0.0.0.0:80 in /etc/nginx/sites-enabled/default:22
异常原因:a duplicate default server for 0.0.0.0:80 in /etc/nginx/sites-enabled/default:22

处理方式:
$ sudo rm /etc/nginx/sites-enabled/default
$ service nginx restart

2 WebUI 本地启动地址:https://127.0.0.1/

3 建议再安装st之前,装好python环境,利用pip安装些异常包。我这边用的是python3,anaconda做多个环境部署,可以做参考。

5 初步使用

st会提供自带的传感器,触发器 和规则,建议一个一个模块看,理解后可以自定义写几个触发器,规则等,后面的pack还没有看。

重点!!!重点重是留到最后。推荐一个博客,针对各个模块进行了详细讲解,介绍的细节比较多,有很多示例,还有源码剖析可以参考。

https://blog.csdn.net/qingyuanluofeng/category_8605700.html

这篇关于Stackstorm 框架初探的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/669324

相关文章

SpringBoot集成图片验证码框架easy-captcha的详细过程

《SpringBoot集成图片验证码框架easy-captcha的详细过程》本文介绍了如何将Easy-Captcha框架集成到SpringBoot项目中,实现图片验证码功能,Easy-Captcha是... 目录SpringBoot集成图片验证码框架easy-captcha一、引言二、依赖三、代码1. Ea

Gin框架中的GET和POST表单处理的实现

《Gin框架中的GET和POST表单处理的实现》Gin框架提供了简单而强大的机制来处理GET和POST表单提交的数据,通过c.Query、c.PostForm、c.Bind和c.Request.For... 目录一、GET表单处理二、POST表单处理1. 使用c.PostForm获取表单字段:2. 绑定到结

修改若依框架Token的过期时间问题

《修改若依框架Token的过期时间问题》本文介绍了如何修改若依框架中Token的过期时间,通过修改`application.yml`文件中的配置来实现,默认单位为分钟,希望此经验对大家有所帮助,也欢迎... 目录修改若依框架Token的过期时间修改Token的过期时间关闭Token的过期时js间总结修改若依

MyBatis框架实现一个简单的数据查询操作

《MyBatis框架实现一个简单的数据查询操作》本文介绍了MyBatis框架下进行数据查询操作的详细步骤,括创建实体类、编写SQL标签、配置Mapper、开启驼峰命名映射以及执行SQL语句等,感兴趣的... 基于在前面几章我们已经学习了对MyBATis进行环境配置,并利用SqlSessionFactory核

cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个?

跨平台系列 cross-plateform 跨平台应用程序-01-概览 cross-plateform 跨平台应用程序-02-有哪些主流技术栈? cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个? cross-plateform 跨平台应用程序-04-React Native 介绍 cross-plateform 跨平台应用程序-05-Flutte

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

数据治理框架-ISO数据治理标准

引言 "数据治理"并不是一个新的概念,国内外有很多组织专注于数据治理理论和实践的研究。目前国际上,主要的数据治理框架有ISO数据治理标准、GDI数据治理框架、DAMA数据治理管理框架等。 ISO数据治理标准 改标准阐述了数据治理的标准、基本原则和数据治理模型,是一套完整的数据治理方法论。 ISO/IEC 38505标准的数据治理方法论的核心内容如下: 数据治理的目标:促进组织高效、合理地

ZooKeeper 中的 Curator 框架解析

Apache ZooKeeper 是一个为分布式应用提供一致性服务的软件。它提供了诸如配置管理、分布式同步、组服务等功能。在使用 ZooKeeper 时,Curator 是一个非常流行的客户端库,它简化了 ZooKeeper 的使用,提供了高级的抽象和丰富的工具。本文将详细介绍 Curator 框架,包括它的设计哲学、核心组件以及如何使用 Curator 来简化 ZooKeeper 的操作。 1

【Kubernetes】K8s 的安全框架和用户认证

K8s 的安全框架和用户认证 1.Kubernetes 的安全框架1.1 认证:Authentication1.2 鉴权:Authorization1.3 准入控制:Admission Control 2.Kubernetes 的用户认证2.1 Kubernetes 的用户认证方式2.2 配置 Kubernetes 集群使用密码认证 Kubernetes 作为一个分布式的虚拟

Spring Framework系统框架

序号表示的是学习顺序 IoC(控制反转)/DI(依赖注入): ioc:思想上是控制反转,spring提供了一个容器,称为IOC容器,用它来充当IOC思想中的外部。 我的理解就是spring把这些对象集中管理,放在容器中,这个容器就叫Ioc这些对象统称为Bean 用对象的时候不用new,直接外部提供(bean) 当外部的对象有关系的时候,IOC给它俩绑好(DI) DI和IO