当前位置:首页 > 文章列表 > Golang > Go问答 > 在GCP Cloud Pub/Sub中逐条发布消息

在GCP Cloud Pub/Sub中逐条发布消息

来源:stackoverflow 2024-03-28 15:30:32 0浏览 收藏

IT行业相对于一般传统行业,发展更新速度更快,一旦停止了学习,很快就会被行业所淘汰。所以我们需要踏踏实实的不断学习,精进自己的技术,尤其是初学者。今天golang学习网给大家整理了《在GCP Cloud Pub/Sub中逐条发布消息》,聊聊,我们一起来看看吧!

问题内容

我正在开发一个示例项目,该项目从 bigquery 获取输出并将其发布到 pubsub。 bigquery 的行输出可能>100,000。我看到有批量发布的选项,并且我在多个地方读到每批 1k 条消息是理想的。我遇到的问题是,在我的一生中,我无法让它批量处理多个消息,我认为解决方案很简单,但我不知道如何做到这一点..

这就是我现在所拥有的,它所做的只是一次发布一条消息。

func publish(client pubsub.client, data []byte) (string, error) {
    ctx := context.background()

    topic := client.topic("topic-name")
    topic.publishsettings = pubsub.publishsettings{
        // bytethreshold:  5000,
        countthreshold: 1000, // no matter what i put here it still sends one per publish
        // delaythreshold: 1000 * time.millisecond,
    }

    result := topic.publish(ctx, &pubsub.message{
        data: data,
    })

    id, err := result.get(ctx)
    if err != nil {
        return "", err
    }

    return id, nil
}

这个函数被调用:

for _, v := range qr {
        data, err := json.marshal(v)
        if err != nil {
            log.printf("unable to marshal %s", data)
            continue
        }
        id, err := publish(*pubsubclient, data)
        if err != nil {
            log.printf("unable to publish message: %s", data)
        }
        log.printf("published message with id: %s", id)
    }

其中 qr 是包含从 bigquery 查询返回的数据的结构切片。

现在,是否是由于我调用函数 publish 的方式导致每条消息都被发布,并且 topic.publishsettings 被覆盖每个方法调用,因此它忘记了以前的消息?我在这里不知所措。

我在这里看到了一些批量发布代码:https://github.com/googlecloudplatform/golang-samples/blob/master/pubsub/topics/main.go#l217

但他们实际上并没有在示例中调用它,所以我不知道应该如何完成。

旁注并进一步证明我的观点,它不起作用,如果我在 topic.publishsettings var 中设置 delaythreshold 说,1 秒,它只是每秒发布一条消息,而不是所有应该发布的消息留在记忆中。

感谢您的帮助,谢谢。

编辑#1:

因此,根据 kingkupps 的评论,我将代码更改为这样以进行测试:(项目和主题名称从真实的名称切换而来)

func QueryAndPublish(w http.ResponseWriter, r *http.Request) {
    ctx := context.Background()
    // setting up the pubsub client
    pubsubClient, err := pubsub.NewClient(ctx, "fake-project-id")
    if err != nil {
        log.Fatalf("Unable to get pubsub client: %v", err)
    }

    // init topic and settings for publishing 1000 messages in batch
    topic := pubsubClient.Topic("fake-topic")
    topic.PublishSettings = pubsub.PublishSettings{
        // ByteThreshold:  5000,
        CountThreshold: 1000,
        // DelayThreshold: 1000 * time.Millisecond,
    }

    // bq set up
    bqClient, err := bigquery.NewClient(ctx, "fake-project-id")
    if err != nil {
        log.Fatalf("Unable to get bq client: %v", err)
    }
    // bq query function call
    qr, err := query(*bqClient)
    if err != nil {
        log.Fatal(err)
    }
    log.Printf("Got query results, publishing now")

    // marshalling messages to json format
    messages := make([][]byte, len(qr))
    timeToMarshal := time.Now()
    for i, v := range qr {
        data, err := json.Marshal(v)
        if err != nil {
            log.Printf("Unable to marshal %s", data)
            continue
        }
        messages[i] = data
    }
    elapsedMarshal := time.Since(timeToMarshal).Nanoseconds() / 1000000
    log.Printf("Took %v ms to marshal %v messages", elapsedMarshal, len(messages))

    // publishing messages
    timeToPublish := time.Now()
    publishCount := 0
    for _, v := range messages {
        // ignore result, err from topic.Publish return, just publish
        topic.Publish(ctx, &pubsub.Message{
            Data: v,
        })
        publishCount++
    }
    elapsedPublish := time.Since(timeToPublish).Nanoseconds() / 1000000
    log.Printf("Took %v ms to publish %v messages", elapsedPublish, publishCount)

    fmt.Fprint(w, "Job completed")
}

现在的作用是,当我的消息计数为 100,000 时,它将在大约 600 毫秒内完成发布调用,但在后台,它仍然会一一发布到 pubsub 端点。

我可以在 stackdriver 和 wireshark 中看到这一点,其中 stackdriver 中的消息/秒大约为 10-16/秒,并且 wireshark 显示每条发送的消息的新连接。


解决方案


这可能是因为当您致电时

topic.PublishSettings = pubsub.PublishSettings{ // 字节阈值: 5000, 计数阈值:1000, // DelayThreshold: 1000 * time.Millisecond, }

您正在将发布设置重置为零初始化结构。这会将 topic.PublishSettings.ByteThreshold 设置为 0,这意味着所有消息将立即发布;你告诉它等到它有 0 字节,它总是有 0 字节。

相反,您应该执行以下操作来设置 CountThreshold:

topic.PublishSettings.CountThreshold = 1000

这同样适用于其他字段。它们已经按照 here 的描述初始化为默认值,如果您想更改它们,请直接修改它们,而不是重新分配整个 PublishSetttings 对象。

今天关于《在GCP Cloud Pub/Sub中逐条发布消息》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

版本声明
本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
PHP表单防范HTTP劫持攻击指南PHP表单防范HTTP劫持攻击指南
上一篇
PHP表单防范HTTP劫持攻击指南
探究织梦CMS的安全性及挑战
下一篇
探究织梦CMS的安全性及挑战
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    508次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    497次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • PPTFake答辩PPT生成器:一键生成高效专业的答辩PPT
    PPTFake答辩PPT生成器
    PPTFake答辩PPT生成器,专为答辩准备设计,极致高效生成PPT与自述稿。智能解析内容,提供多样模板,数据可视化,贴心配套服务,灵活自主编辑,降低制作门槛,适用于各类答辩场景。
    12次使用
  • SEO标题Lovart AI:全球首个设计领域AI智能体,实现全链路设计自动化
    Lovart
    SEO摘要探索Lovart AI,这款专注于设计领域的AI智能体,通过多模态模型集成和智能任务拆解,实现全链路设计自动化。无论是品牌全案设计、广告与视频制作,还是文创内容创作,Lovart AI都能满足您的需求,提升设计效率,降低成本。
    12次使用
  • 美图AI抠图:行业领先的智能图像处理技术,3秒出图,精准无误
    美图AI抠图
    美图AI抠图,依托CVPR 2024竞赛亚军技术,提供顶尖的图像处理解决方案。适用于证件照、商品、毛发等多场景,支持批量处理,3秒出图,零PS基础也能轻松操作,满足个人与商业需求。
    26次使用
  • SEO标题PetGPT:智能桌面宠物程序,结合AI对话的个性化陪伴工具
    PetGPT
    SEO摘要PetGPT 是一款基于 Python 和 PyQt 开发的智能桌面宠物程序,集成了 OpenAI 的 GPT 模型,提供上下文感知对话和主动聊天功能。用户可高度自定义宠物的外观和行为,支持插件热更新和二次开发。适用于需要陪伴和效率辅助的办公族、学生及 AI 技术爱好者。
    25次使用
  • 可图AI图片生成:快手可灵AI2.0引领图像创作新时代
    可图AI图片生成
    探索快手旗下可灵AI2.0发布的可图AI2.0图像生成大模型,体验从文本生成图像、图像编辑到风格转绘的全链路创作。了解其技术突破、功能创新及在广告、影视、非遗等领域的应用,领先于Midjourney、DALL-E等竞品。
    52次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码