案例(一)-KisFlow-Golang流实时计算-快速入门指南

案例(一)-kisflow-golang流实时计算-快速入门指南

Github:https://github.com/aceld/kis-flow
文档:https://github.com/aceld/kis-flow/wiki

第 1 部分-概览
Part2.1-项目构建/基础模块
Part2.2-项目构建/基础模块
第三部分-数据流
Part4-功能调度
第5部分-连接器
Part6-配置导入导出
Part7-KisFlow 动作
Part8-Cache/Params 数据缓存和数据参数
Part9-流程的多份副本
Part10-Prometheus Metrics 统计
Part11-基于反射的FaaS参数类型自适应注册

案例1-快速入门
Case2-流程并行操作
Case3-KisFlow在多Goroutine中的应用

下载 KisFlow 源代码

$前往 github.com/aceld/kis-flow

登录后复制

KisFlow 开发者文档

KisFlow 快速入门(使用配置文件)源代码示例: kis-flow-usage/2-quick_start_with_config 位于 main · acld/kis-flow-usage

首先,让我们创建一个具有以下文件结构的项目:

项目目录

├── Makefile├── 会议│ ├── flow-CalStuAvgScore.yml│ ├── func-AvgStuScore.yml│ └── func-PrintStuAvgScore.yml├── faas_stu_score_avg.go├── faas_stu_score_avg_print.go└── main.go

登录后复制

流动

定义当前Flow。目前的Flow名为“CalStuAvgScore”,是一个计算学生平均成绩的数据流。

定义两个函数。 Function1是Calculate,是计算学生平均成绩的逻辑,Function2是Expand,是打印最终结果

立即学习“go语言免费学习笔记(深入)”;

配置

Flow 和 Functions 的配置文件如下:

(1) 流程配置

conf/flow-CalStuAvgScore.yml

kistype:流动状态:1flow_name:CalStuAvgScore流量: - 文件名称:AvgStuScore - 文件名称:PrintStuAvgScore

登录后复制

(2) 功能1配置

conf/func-AvgStuScore.yml

kistype:功能文件名称:AvgStuScorefmode:计算来源: 名称: 学生成绩 必须: - 学生ID

登录后复制

(3)功能2配置

conf/func-PrintStuAvgScore.yml

kistype:功能文件名称:PrintStuAvgScorefmode:展开来源: 名称: 学生成绩 必须: - 学生ID

登录后复制

主要的

接下来是主要逻辑,分为三步:

加载配置文件并获取Flow实例。提交数据。运行流程。

main.go

包主进口 (    “语境”    “FMMT”    “github.com/aceld/kis-flow/file”    “github.com/aceld/kis-flow/kis”)函数主() {    ctx := context.Background()    // 从文件加载配置    if err := file.ConfigImportYaml("conf/");错误!=零{        恐慌(错误)    }    // 获取流量    flow1 := kis.Pool().GetFlow("CalStuAvgScore")    如果流 1 == nil {        恐慌(“流1为零”)    }    // 提交字符串    _ = flow1.CommitRow(`{"stu_id":101, "score_1":100, "score_2":90, "score_3":80}`)    // 提交字符串    _ = flow1.CommitRow(`{"stu_id":102, "score_1":100, "score_2":70, "score_3":60}`)    // 运行流程    if err := flow1.Run(ctx);错误!=零{        fmt.Println("错误:",错误)    }    返回}

登录后复制

功能1

第一个计算过程的实现逻辑如下。 AvgStuScoreIn 是输入数据类型,目前包含三个分数,AvgStuScoreOut 是输出数据类型,是平均分数。

faas_stu_score_avg.go

包主进口 (    “语境”    “github.com/aceld/kis-flow/kis”    “github.com/aceld/kis-flow/serialize”)类型 AvgStuScoreIn 结构体 {    序列化.DefaultSerialize    StuId int `json:"stu_id"`    Score1 int `json:"score_1"`    Score2 int `json:"score_2"`    Score3 int `json:"score_3"`}类型 AvgStuScoreOut 结构体 {    序列化.DefaultSerialize    StuId int `json:"stu_id"`    AvgScore float64 `json:"avg_score"`}// AvgStuScore(FaaS) 计算学生的平均成绩func AvgStuScore(ctx context.Context, flow kis.Flow, rows []*AvgStuScoreIn) error {    对于 _, row := 范围行 {        输出 := AvgStuScoreOut{            StuId:行.StuId,            平均得分:float64(行.得分1+行.得分2+行.得分3) / 3,        }        // 提交结果数据        _ = flow.CommitRow(out)    }    返回零}

登录后复制

功能2

打印的逻辑是直接打印数据,如下

faas_stu_score_avg_print.go

包主进口 (    “语境”    “FMMT”    “github.com/aceld/kis-flow/kis”    “github.com/aceld/kis-flow/serialize”)类型 PrintStuAvgScoreIn 结构体 {    序列化.DefaultSerialize    StuId int `json:"stu_id"`    AvgScore float64 `json:"avg_score"`}类型 PrintStuAvgScoreOut 结构体 {    序列化.DefaultSerialize}func PrintStuAvgScore(ctx context.Context, flow kis.Flow, rows []*PrintStuAvgScoreIn) error {    对于 _, row := 范围行 {        fmt.Printf("stuid: [%+v], 平均成绩: [%+v]n", row.StuId, row.AvgScore)    }    返回零}

登录后复制

输出

最后运行程序,得到如下结果:

添加 KisPool FuncName=AvgStuScore添加 KisPool FuncName=PrintStuAvgScore添加 FlowRouter FlowName=CalStuAvgScore学生:[101],平均分数:[90]学习:[102],平均分数:[76.66666666666667]

登录后复制

2.KisFlow快速入门(使用原生接口,动态配置)

源代码示例:kis-flow-usage/1-quick_start at main · acld/kis-flow-usage

项目目录

├── faas_stu_score_avg.go├── faas_stu_score_avg_print.go└── main.go

登录后复制

流动

主要的

main.go

包主进口 (    “语境”    “FMMT”    “github.com/aceld/kis-flow/common”    “github.com/aceld/kis-flow/config”    “github.com/aceld/kis-flow/flow”    “github.com/aceld/kis-flow/kis”)函数主() {    ctx := context.Background()    // 创建新的流配置    myFlowConfig1 := config.NewFlowConfig("CalStuAvgScore", common.FlowEnable)    // 创建新的函数配置    avgStuScoreConfig := config.NewFuncConfig("AvgStuScore", common.C, nil, nil)    printStuScoreConfig := config.NewFuncConfig("PrintStuAvgScore", common.E, nil, nil)    // 创建一个新流    flow1 := flow.NewKisFlow(myFlowConfig1)    // 将函数链接到流程    _ = flow1.Link(avgStuScoreConfig, nil)    _ = flow1.Link(printStuScoreConfig, nil)    // 提交字符串    _ = flow1.CommitRow(`{"stu_id":101, "score_1":100, "score_2":90, "score_3":80}`)    // 提交字符串    _ = flow1.CommitRow(`{"stu_id":102, "score_1":100, "score_2":70, "score_3":60}`)    // 运行流程    if err := flow1.Run(ctx);错误!=零{        fmt.Println("错误:",错误)    }    返回}函数初始化(){    // 注册函数    kis.Pool().FaaS("AvgStuScore", AvgStuScore)    kis.Pool().FaaS("PrintStuAvgScore", PrintStuAvgScore)}

登录后复制

功能1

faas_stu_score_avg.go

包主进口 (    “语境”    “github.com/aceld/kis-flow/kis”    “github.com/aceld/kis-flow/serialize”)类型 AvgStuScoreIn 结构体 {    序列化.DefaultSerialize    StuId int `json:"stu_id"`    Score1 int `json:"score_1"`    Score2 int `json:"score_2"`    Score3 int `json:"score_3"`}类型 AvgStuScoreOut 结构体 {    序列化.DefaultSerialize    StuId int `json:"stu_id"`    AvgScore float64 `json:"avg_score"`}// AvgStuScore(FaaS) 计算学生的平均成绩func AvgStuScore(ctx context.Context, flow kis.Flow, rows []*AvgStuScoreIn) error {    对于 _, row := 范围行 {        输出 := AvgStuScoreOut{            StuId:行.StuId,            平均得分:float64(行.得分1+行.得分2+行.得分3) / 3,        }        // 提交结果数据        _ = flow.CommitRow(out)    }    返回零}

登录后复制

功能2

faas_stu_score_avg_print.go

包主进口 (    “语境”    “FMMT”    “github.com/aceld/kis-flow/kis”    “github.com/aceld/kis-flow/serialize”)类型 PrintStuAvgScoreIn 结构 {    序列化.DefaultSerialize    StuId int `json:"stu_id"`    AvgScore float64 `json:"avg_score"`}类型 PrintStuAvgScoreOut 结构体 {    序列化.DefaultSerialize}func PrintStuAvgScore(ctx context.Context, flow kis.Flow, rows []*PrintStuAvgScoreIn) error {    对于 _, row := 范围行 {        fmt.Printf("stuid: [%+v], 平均成绩: [%+v]n", row.StuId, row.AvgScore)    }    返回零}

登录后复制

输出

添加 KisPool FuncName=AvgStuScore添加 KisPool FuncName=PrintStuAvgScorefuncName NewConfig 源为零,funcName = AvgStuScore,使用默认的未命名源。funcName NewConfig 源为零,funcName = PrintStuAvgScore,使用默认的未命名源。学生:[101],平均分数:[90]学习:[102],平均分数:[76.66666666666667]

登录后复制

作者:Aceld
GitHub:https://github.com/aceld

KisFlow 开源项目地址:https://github.com/aceld/kis-flow

文档:https://github.com/aceld/kis-flow/wiki

第 1 部分-概览
Part2.1-项目构建/基础模块
Part2.2-项目构建/基础模块
第三部分-数据流
Part4-功能调度
第5部分-连接器
Part6-配置导入导出
Part7-KisFlow 动作
Part8-Cache/Params 数据缓存和数据参数
Part9-流程的多份副本
Part10-Prometheus Metrics 统计
Part11-基于反射的FaaS参数类型自适应注册

案例1-快速入门
Case2-Flow并行运行
Case3-KisFlow在多Goroutine中的应用

以上就是案例(一)-KisFlow-Golang流实时计算-快速入门指南的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2331636.html

(0)
上一篇 2025年3月1日 00:21:28
下一篇 2025年2月25日 20:43:28

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 有没有快捷的方式学习golang框架?

    go 框架是预定义的代码库,包含应用程序的结构和功能。通过选择合适的框架并按照其文档进行安装和配置,开发人员可以显著提高 go 应用程序的开发效率和可维护性,例如使用 gin 框架构建简单的 web api。 快速掌握 Go 框架:指南与实…

    2025年3月1日
    200
  • golang 框架如何通过新特性简化 REST API 的开发?

    go 框架的新特性简化了 rest api 开发,包括:http 处理程序中的泛型,实现通用处理逻辑;servemux 中的路由参数,简化路径参数获取;嵌入式子路由,便于组织和模块化 api。 Go 框架如何通过新特性简化 REST API…

    2025年3月1日
    200
  • 用于不同场景的 Go 框架推荐

    go 框架推荐指南:web 开发:echo,一个轻量级且快速的 web 框架,适用于构建高性能 rest api。grpc:grpc-go,一个高效的 rpc 框架,用于在分布式系统中构建服务。数据访问:gorm,一个活跃的 orm 框架,…

    2025年3月1日
    200
  • 工厂设计模式

    工厂设计模式广泛应用于面向对象编程中。它提供了一个用于创建对象的接口,但允许子类决定要实例化哪些类。在本文中,我们将探讨如何在 Golang 中实现工厂模式,了解其好处,并分析受日常情况启发的实际使用示例。 什么是工厂? Factory 定…

    2025年3月1日
    200
  • 哪些因素可能会影响学习golang框架的难度?

    学习 golang 框架的难度因素包括编程基础、框架选择、语言熟练度、语言环境和实际经验。难度的关键在于:拥有扎实的编程基础,包括数据结构、算法和设计模式。根据技能水平选择合适的框架,并熟悉 golang 的并发性和错误处理机制。积极参与 …

    2025年3月1日
    200
  • golang框架的生态系统是否对学习有帮助?

    go 框架生态系统通过提供学习资源和预制解决方案,助力学习 go 语言和快速开发应用。具体而言:学习 go 语言:生态系统中的框架和库提供示例和文档,帮助新手了解 go 的核心概念和最佳实践。实战案例:使用 gin 框架构建 rest ap…

    2025年3月1日
    200
  • 揭开神秘面纱:揭开 Go 的价值变化

    在 Golang 中,数据分为两大类: 值类型:这些是独立的数据单元,在传递时会被复制。 例子包括: 基本类型:整数(int、uint等)、浮点数(float32、float64)、布尔值(bool)、字符串、符文(单个字符)。 数组:相同…

    2025年3月1日
    200
  • Go 框架与其他语言框架的优劣对比

    go 框架在并发性、强类型和简单语法上优于其他语言框架,但在生态系统、泛型和面向对象支持上处于劣势。 Go 框架与其他语言框架的优劣对比 Go 语言以其出色的并发性和高性能而闻名,使其成为构建分布式系统的理想选择。然而,Go 框架与其他流行…

    2025年3月1日
    200
  • Go 框架包管理最佳实践

    go 项目的包管理最佳实践:使用 go mod 作为包管理器;设置每个包的版本号以确保稳定性;利用 go modules 独立管理依赖项;使用 vendoring 避免版本冲突;使用 go get 和 go upgrade 更新或安装包。 …

    2025年3月1日
    200
  • golang 框架的新特性如何简化 API 开发?

    go 框架的新特性通过提供简洁优雅的路由和中间件(如 echo 框架)以及高性能和强大的错误处理(如 gin 框架),极大地简化了 api 开发:echo 框架:提供直观的 dsl 定义可扩展路由。使用中间件添加跨路由功能(如身份验证)。g…

    2025年3月1日
    200

发表回复

登录后才能评论