您好,
会员登录 快速注册
退出 ( 条未读消息)
关于本站 意见反馈 首页

公告:小宅博客网可以开发票了,需要发票的,去群里找群主哈!!
全部文章分类
  • 人工智能 >

  • 编程语言 >

  • WPF系列 >

  • ASP.NET系列 >

  • Linux >

  • 数据库 >

  • 嵌入式 >

  • WEB技术 >

  • PLC系列 >

  • 微服务与框架 >

  • 小宅DIY >

  • 学习资料 >

OpenCv基础 ANN车牌识别 yolov5车牌识别 指针式仪表识别 ROS系列 YOLO Halcon Detectron2 昇腾AI ChatGPT在线体验 英伟达JETSON ChatGLM ChatTTS FunASR 地平线 ByteTrack 魔搭社区 LangChain
C C# C++ Python Java Go
WPF
ASP.NET小功能 GPS定位系统-MVC GPS定位系统-VUE ASP.NET WebRTC
Linux Linux内核 Shell MakeFile
MySql SqlServer Oracle
STM8 STM32 51单片机
VUE入门 HTML JavaScript CSS layui镜像网站 ElementUi中文官网 element-plus 图标
三菱 欧姆龙 西门子 施耐德 松下 台达
IOTSharp IOTGateway ABP FRAMEWORK Docker
亚克力音响 编程仙途:智驭万法
面试题与技巧 Python入门技能树 微软C#教程
首页 编程之美 工具下载 全国就业 流量地图 文心一言
C#
内容简介 1、C#环境下使用EF操作MySql 2、实现串口通信 3、TCP通信 4、读写SqlServer数据库 5、读写ini配置文件 6、实现远程升级 7、调用打印机 8、AES数据加密与解密 AES加解密(RijndaelManaged版) 9、FTP的上传和下载 10、封装dll到exe 11、重写Button控件 12、重写Labeld控件 13、重写DataGridView控件 14、重写TabControl控件 15、重写ProgressBar控件 16、加载状态弹窗设计 17、模拟按键精灵 18、24种数据校验算法 19、C#如何调用opencv 20、地图上显示GPS坐标 21、使用EPPlus导出/导入xlsx格式的Excel报表和曲线图 22、exe程序生成安装包 23、DataGridView控件列控制 24、json解析 25、自定义委托事件 26、xml文件的生成与读取 27、DataGridView实现翻页效果 28、如何实现CAD dxf文件的读取 29、StopWatch的使用 30、Async与Await 同步与异步操作 31、关闭登录窗体打开主窗体的方法 32、SQLite数据库的操作 33、MD5数据加密 34、DES数据加密与解密 35、获取本地IP地址 36、打开与保存文件 37、静态图表显示(曲线图) 38、动态图表显示(曲线图) 39、根据公网IP获取地址信息 40、List转DataTable 41、C#下实现Ping操作 42、父窗体中嵌入子窗体 43、获取MySql数据库列表 44、WebSocket通讯 45、Mqtt客户端与服务端通讯 46、使用QRCode生成二维码 47、AForge调用摄像头 48、Emgu.CV调用摄像头 49、获取以太网网卡IP 50、DataGridView全选与定位 51、如何获取系统中所有程序的句柄 遍历指定目录下的所有文件 ​NPOI Excel报表的导入与导出 常用正则表达式字符串格式判断 Task和Thread的启停操作 C# 一些常用小功能1 C# 一些常用小功能2 如何使用C#来发送QQ邮件 Aspose.Slides文档格式转换 C# GDI+ 画心形 跳动动画 使用Remoting实现RPC RabbitMQ.消息发布与订阅 .Net Core 微信/支付宝 官方Demo C# OCR图片文字识别 Quartz 计划任务 文字语音播报 winform基于百度地图的电子围栏、路径规划、小车导航实现 Visual Studio C盘数据迁移,解决C盘空间不足的问题 Kafka通讯(Kafka-Net版) Kafka通讯(Confluent.Kafka版) 获取变量Description描述 C# 将PDF文档转换为Word文档 C# MVC 多图片上传预览
Kafka通讯(Kafka-Net版)
获取变量Description描述
激萌の小宅 小宅博客网 C#

文章作者:激萌の小宅

促销:¥0

价格:¥0

配送方式: 购买后立即生效(如购买异常,请联系站长)
付款之后一定要等待自动跳转结束,否则购买可能会失败
  • 0 天

    有效期

  • 0

    总销量

  • 0

    累计评价

Kafka通讯(Confluent.Kafka版)

环境说明:

IDE:Visual Studio 2022

框架:.NET Framework 4.8

NuGet库:Confluent.Kafka 2.1.1

QQ截图20230526100753.jpg


官方代码:

https://github.com/confluentinc/confluent-kafka-dotnet/


参考博客:

https://blog.csdn.net/weixin_30855761/article/details/96876699

https://blog.csdn.net/weixin_46867655/article/details/106998538


未解决问题:

1、无法直接获取到网络状态,但可以通过间接的方式获取到,比如:数据发送失败。

2、Message的value值只能为字符串类型,其他类型不行。

3、无法指定key值进行消费。

3、并发响应相对Kafka.Net较慢,博主这边体验有点差,不知道是不是网络不太好的原因!!


优点:

1、具备网络自动恢复,无需重复链接

2、可以设置GroupId

3、可以设置监控时间,已经获取监控日志


配置属性含义

属性含义

数据类型

备注

类型

BootstrapServers

string

kafka连接字符串地址

生产者 消费者

MessageTimeoutMs

int

超时时间

生产者

GroupId

string

组ID

消费者

EnableAutoCommit

bool

true:自动确认 false:手动确认

消费者

EnableIdempotence

bool

失败重试 true:重试 false:不重试

生产者

 

执行效果

QQ截图20230526102417.jpg


代码:

using Confluent.Kafka;
using System;
using System.Threading.Tasks;
using System.Windows.Forms;

namespace KafkaDemo
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        /// <summary>
        /// 主题
        /// </summary>
        public string topic = "test";

        public string server = "localhost:19092";

        /// <summary>
        /// 生产者
        /// </summary>
        public IProducer<string, string> producer;

        private void Form1_Load(object sender, EventArgs e)
        {
            // 初始化生产者
            var producerConfig = new ProducerConfig
            {
                // kafka连接字符串地址(生产者 消费者)
                BootstrapServers = server,
                // 超时时间
                MessageTimeoutMs = 3000,
                // 失败重试
                EnableIdempotence = true
            };
            producer = new ProducerBuilder<string, string>(producerConfig).Build();

            // 初始化消费者
            var config = new ConsumerConfig
            {
                // // kafka连接字符串地址(生产者 消费者)
                BootstrapServers = server,
                // 组ID
                GroupId = "GroupId",
                // 自动确认
                EnableAutoCommit = true,
                // 监控周期
                StatisticsIntervalMs = 10000,
                // 客户端组会话和故障检测超时
                // SessionTimeoutMs = 6000,
                // 提取数据的偏移方式(按最早的)
                AutoOffsetReset = AutoOffsetReset.Earliest,
                // 数据采集完后触发
                EnablePartitionEof = true
            };
            var consumer = new ConsumerBuilder<string, string>(config)
                                 .SetErrorHandler((_, ex) =>
                                 {
                                     System.Diagnostics.Debug.WriteLine($"Error: {ex.Reason}");
                                 })
                                 .SetStatisticsHandler((_, json) =>
                                 {
                                     System.Diagnostics.Debug.WriteLine($"{DateTime.Now:yyyy-MM-dd HH:mm:ss} > 监控");
                                 })
                                 .SetPartitionsAssignedHandler((c, partitions) =>
                                 {
                                     System.Diagnostics.Debug.WriteLine($"Assigned partitions: [{string.Join(", ", partitions)}]");
                                 })
                                 .SetPartitionsRevokedHandler((c, partitions) =>
                                 {
                                     System.Diagnostics.Debug.WriteLine($"Revoking assignment: [{string.Join(", ", partitions)}]");
                                 })
                                 .Build();

            consumer.Subscribe(topic);

            // 消费者
            new Task(() =>
            {
                while (true)
                {
                    try
                    {
                        // 堵塞方式
                        var consumeResult = consumer.Consume();
                        if (consumeResult.IsPartitionEOF)
                        {
                            System.Diagnostics.Debug.WriteLine("触发EOF");
                            continue;
                        }
                        System.Diagnostics.Debug.WriteLine($"收到消息:{consumeResult.Message.Key}: {consumeResult.Message.Value}");
                    }
                    catch (ConsumeException ex)
                    {
                        System.Diagnostics.Debug.WriteLine($"接收错误: {ex.Error.Reason}");
                    }
                }
            }).Start();
        }

        private void button1_Click(object sender, EventArgs e)
        {
            new Task(() =>
            {
                try
                {
                    var dr = producer.ProduceAsync(topic, new Message<string, string>
                    {
                        Key = "kafka_key",
                        Value = $"这是数据:{DateTime.Now.ToString("yyyy年MM月dd日 HH:mm:ss")}"
                    }).GetAwaiter().GetResult();
                    System.Diagnostics.Debug.WriteLine("------------消息发送成功!----------------");
                }
                catch (ProduceException<string, string> ex)
                {
                    System.Diagnostics.Debug.WriteLine($"消息发送失败!;data:" + ex.Error.Reason);
                }
            }).Start();
        }
    }
}


Kafka通讯(Kafka-Net版)
获取变量Description描述

友情链接: CSDN激萌の小宅 95知识库 自考题库 罗分明个人网络博客 精益编程leanboot

小宅博客  www.bilibili996.com All Rights Reserved. 备案号: 闽ICP备2024034575号

网站经营许可证  福建省福州市 Copyright©2021-2025 版权所有

小宅博客
首页 智能家居 地图定位
公告:小宅博客网可以开发票了,需要发票的,去群里找群主哈!!

文章作者:激萌の小宅

促销:¥0

价格:¥0

配送方式: 购买后立即生效(如购买异常,请联系站长)
付款之后一定要等待自动跳转结束,否则购买可能会失败
  • 0 天

    有效期

  • 0

    总销量

  • 0

    累计评价

Kafka通讯(Confluent.Kafka版)

环境说明:

IDE:Visual Studio 2022

框架:.NET Framework 4.8

NuGet库:Confluent.Kafka 2.1.1

QQ截图20230526100753.jpg


官方代码:

https://github.com/confluentinc/confluent-kafka-dotnet/


参考博客:

https://blog.csdn.net/weixin_30855761/article/details/96876699

https://blog.csdn.net/weixin_46867655/article/details/106998538


未解决问题:

1、无法直接获取到网络状态,但可以通过间接的方式获取到,比如:数据发送失败。

2、Message的value值只能为字符串类型,其他类型不行。

3、无法指定key值进行消费。

3、并发响应相对Kafka.Net较慢,博主这边体验有点差,不知道是不是网络不太好的原因!!


优点:

1、具备网络自动恢复,无需重复链接

2、可以设置GroupId

3、可以设置监控时间,已经获取监控日志


配置属性含义

属性含义

数据类型

备注

类型

BootstrapServers

string

kafka连接字符串地址

生产者 消费者

MessageTimeoutMs

int

超时时间

生产者

GroupId

string

组ID

消费者

EnableAutoCommit

bool

true:自动确认 false:手动确认

消费者

EnableIdempotence

bool

失败重试 true:重试 false:不重试

生产者

 

执行效果

QQ截图20230526102417.jpg


代码:

using Confluent.Kafka;
using System;
using System.Threading.Tasks;
using System.Windows.Forms;

namespace KafkaDemo
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        /// <summary>
        /// 主题
        /// </summary>
        public string topic = "test";

        public string server = "localhost:19092";

        /// <summary>
        /// 生产者
        /// </summary>
        public IProducer<string, string> producer;

        private void Form1_Load(object sender, EventArgs e)
        {
            // 初始化生产者
            var producerConfig = new ProducerConfig
            {
                // kafka连接字符串地址(生产者 消费者)
                BootstrapServers = server,
                // 超时时间
                MessageTimeoutMs = 3000,
                // 失败重试
                EnableIdempotence = true
            };
            producer = new ProducerBuilder<string, string>(producerConfig).Build();

            // 初始化消费者
            var config = new ConsumerConfig
            {
                // // kafka连接字符串地址(生产者 消费者)
                BootstrapServers = server,
                // 组ID
                GroupId = "GroupId",
                // 自动确认
                EnableAutoCommit = true,
                // 监控周期
                StatisticsIntervalMs = 10000,
                // 客户端组会话和故障检测超时
                // SessionTimeoutMs = 6000,
                // 提取数据的偏移方式(按最早的)
                AutoOffsetReset = AutoOffsetReset.Earliest,
                // 数据采集完后触发
                EnablePartitionEof = true
            };
            var consumer = new ConsumerBuilder<string, string>(config)
                                 .SetErrorHandler((_, ex) =>
                                 {
                                     System.Diagnostics.Debug.WriteLine($"Error: {ex.Reason}");
                                 })
                                 .SetStatisticsHandler((_, json) =>
                                 {
                                     System.Diagnostics.Debug.WriteLine($"{DateTime.Now:yyyy-MM-dd HH:mm:ss} > 监控");
                                 })
                                 .SetPartitionsAssignedHandler((c, partitions) =>
                                 {
                                     System.Diagnostics.Debug.WriteLine($"Assigned partitions: [{string.Join(", ", partitions)}]");
                                 })
                                 .SetPartitionsRevokedHandler((c, partitions) =>
                                 {
                                     System.Diagnostics.Debug.WriteLine($"Revoking assignment: [{string.Join(", ", partitions)}]");
                                 })
                                 .Build();

            consumer.Subscribe(topic);

            // 消费者
            new Task(() =>
            {
                while (true)
                {
                    try
                    {
                        // 堵塞方式
                        var consumeResult = consumer.Consume();
                        if (consumeResult.IsPartitionEOF)
                        {
                            System.Diagnostics.Debug.WriteLine("触发EOF");
                            continue;
                        }
                        System.Diagnostics.Debug.WriteLine($"收到消息:{consumeResult.Message.Key}: {consumeResult.Message.Value}");
                    }
                    catch (ConsumeException ex)
                    {
                        System.Diagnostics.Debug.WriteLine($"接收错误: {ex.Error.Reason}");
                    }
                }
            }).Start();
        }

        private void button1_Click(object sender, EventArgs e)
        {
            new Task(() =>
            {
                try
                {
                    var dr = producer.ProduceAsync(topic, new Message<string, string>
                    {
                        Key = "kafka_key",
                        Value = $"这是数据:{DateTime.Now.ToString("yyyy年MM月dd日 HH:mm:ss")}"
                    }).GetAwaiter().GetResult();
                    System.Diagnostics.Debug.WriteLine("------------消息发送成功!----------------");
                }
                catch (ProduceException<string, string> ex)
                {
                    System.Diagnostics.Debug.WriteLine($"消息发送失败!;data:" + ex.Error.Reason);
                }
            }).Start();
        }
    }
}