zmq封装

2023-10-21 17:04
文章标签 封装 zmq

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

ZmqBindlib

zmq常用封装

使用方法

基本使用

1.简单请求回复

 ZmqRequest request = new ZmqRequest();request.RemoteAddress = localaddes;request.PubClient = "A";int num = 0;while (true){//   Thread.Sleep(1000);//string msg = request.Request("hi");Person p=  request.Request<Person,Person>(new Person { Name = "jin", Description = "请求", Id = num++, Title = "rr" });Console.WriteLine(p.Description+p.Name);}
    ZmqResponse rep = new ZmqResponse();rep.LocalAddress = localaddes;rep.Start();int num = 0;//rep.ByteReceived += (sender, e) =>//{//    Console.WriteLine(System.Text.Encoding.Default.GetString(e));//    rep.Response("word"+num++);//};rep.StringReceived += (sender, e) =>{Console.WriteLine(e);if (e == "hi"){Thread.Sleep(1000);}rep.Response("word" + num++);};

2.异步下的请求回复,类似TCP,支持多请求

  server =new EhoServer();server.RouterAddress = "tcp://127.0.0.1:66666";//服务地址,请求的远端地址//  server.ByteReceived += Server_ByteReceived;// server.StringReceived += Server_StringReceived1; server.Start();
 private static void Server_StringReceived1(object? sender, RspSocket<string> e){Console.WriteLine(e.Message);if (e.Message == "hi"){//  Thread.Sleep(4000);e.Response("jinyu");return;}e.Response("word");}
		 private static  void recvice(){while (true){var ss = server.GetMsg<Person>();ss.Message.Description = "回复"+ss.Message.Id;ss.Response(ss.Message);}}

3.订阅发布

	````ZmqSubscriber sub = new ZmqSubscriber();sub.Address = new string[] { localaddes };sub.Subscribe("A");// sub.ByteReceived += Sub_ByteReceived;sub.StringReceived += Sub_StringReceived;
		  ZmqPublisher pub = new ZmqPublisher();pub.LocalAddress =localaddes;// pub.IsProxy = true; 是否使用中间代理int num = 0;while (true){// Thread.Sleep(1000);pub.Publish("A", "ssss"+num++);}
		static void Proxy(){//中间代理ZmqDDSProxy.PubAddress = "tcp://127.0.0.1:7771";//注意,客户端订阅此地址ZmqDDSProxy.SubAddress = "tcp://127.0.0.1:7772";//客户端发布此地址ZmqDDSProxy.Start();}
	
## 中心高可用部署
1.推荐方式使用IP漂移:1. windows  使用DNS+VLS;Panguha软件2.Linux使用keppalive2.使用封装该功能前提是可以使用广播,可以允许少量数据丢失;(1)请求返回模式中心:
      EhoServer eho = new EhoServer();eho.IsCluster = true;eho.DealerAddress = "inproc://server";eho.RouterAddress = "tcp://127.0.0.1:5550";eho.StringReceived += EhoServer_StringReceived;eho.Start();
    客户端:与单个一致(2)订阅发布中心:
  ZmqDDSProxy.PubAddress = "tcp://127.0.0.1:2222";ZmqDDSProxy.SubAddress = "tcp://127.0.0.1:4444";ZmqDDSProxy.IsCluster=true;ZmqDDSProxy.Start();
发布端:
        ZmqPublisher pub = new ZmqPublisher();pub.Address = "tcp://127.0.0.1:5678";pub.IsProxy = true; //是否使用中间代理pub.IsDDS = true;//高可用启动int num = 0;while (true){Thread.Sleep(1000);try{pub.Publish("A", "ssss" + num++);}catch(Exception ex){Console.WriteLine(ex.ToString());}}
订阅端:
          ZmqSubscriber sub = new ZmqSubscriber();sub.Address = new string[] { "tcp://127.0.0.1:1234" };sub.IsDDS = true;//高可用启动sub.Subscribe("");// sub.ByteReceived += Sub_ByteReceived;sub.StringReceived += Sub_StringReceived;
            对于发布订阅,中心何发布订阅端都需要启动高可用,会刷新地址(3)负载均衡式订阅发布该模式是仿照kafka功能的;中心:
           ZmqDDSProxy.PubAddress = "tcp://127.0.0.1:2222";ZmqDDSProxy.SubAddress = "tcp://127.0.0.1:4444";ZmqDDSProxy.IsCluster = true;//高可用ZmqDDSProxy.StartProxy(); //注意方法,启动和另外发布订阅方法不同
            发布端:和前面一样订阅端:
       ZmqSubscriberGroup zmqSubscriber=new ZmqSubscriberGroup();zmqSubscriber.Address = "tcp://127.0.0.1:1234";zmqSubscriber.IsDDS= true;//高可用// zmqSubscriber.Indenty = "test";//订阅在不同分组zmqSubscriber.Subscribe("A");zmqSubscriber.StringReceived += ZmqSubscriber_StringReceived;
            (4)kafka封装
         KafkaPublisher kafkaPublisher = new KafkaPublisher();int num = 0;while (true){Thread.Sleep(1000);kafkaPublisher.Push("A", "SSSSS"+num++);}
            KafkaSubscriber  kafkaSubscriber = new KafkaSubscriber();kafkaSubscriber.Subscriber("A");kafkaSubscriber.Consume(p =>{if(p==null){return;}Console.WriteLine(string.Format("Received message at {0}:{1}", p.Topic, p.Value));});
说明1.接收数据一端,定义了2个事件一个方法,顺序是ByteReceived、StringReceived、GetMsg<T>()方法。一旦前一个实现,后面就无效。项目地址:https://github.com/jinyuttt/ZmqBindlib.git

这篇关于zmq封装的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

鸿蒙中Axios数据请求的封装和配置方法

《鸿蒙中Axios数据请求的封装和配置方法》:本文主要介绍鸿蒙中Axios数据请求的封装和配置方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.配置权限 应用级权限和系统级权限2.配置网络请求的代码3.下载在Entry中 下载AxIOS4.封装Htt

SpringBoot中封装Cors自动配置方式

《SpringBoot中封装Cors自动配置方式》:本文主要介绍SpringBoot中封装Cors自动配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录SpringBoot封装Cors自动配置背景实现步骤1. 创建 GlobalCorsProperties

Java导入、导出excel用法步骤保姆级教程(附封装好的工具类)

《Java导入、导出excel用法步骤保姆级教程(附封装好的工具类)》:本文主要介绍Java导入、导出excel的相关资料,讲解了使用Java和ApachePOI库将数据导出为Excel文件,包括... 目录前言一、引入Apache POI依赖二、用法&步骤2.1 创建Excel的元素2.3 样式和字体2.

JAVA封装多线程实现的方式及原理

《JAVA封装多线程实现的方式及原理》:本文主要介绍Java中封装多线程的原理和常见方式,通过封装可以简化多线程的使用,提高安全性,并增强代码的可维护性和可扩展性,需要的朋友可以参考下... 目录前言一、封装的目标二、常见的封装方式及原理总结前言在 Java 中,封装多线程的原理主要围绕着将多线程相关的操

C++实现封装的顺序表的操作与实践

《C++实现封装的顺序表的操作与实践》在程序设计中,顺序表是一种常见的线性数据结构,通常用于存储具有固定顺序的元素,与链表不同,顺序表中的元素是连续存储的,因此访问速度较快,但插入和删除操作的效率可能... 目录一、顺序表的基本概念二、顺序表类的设计1. 顺序表类的成员变量2. 构造函数和析构函数三、顺序表

Go语言利用泛型封装常见的Map操作

《Go语言利用泛型封装常见的Map操作》Go语言在1.18版本中引入了泛型,这是Go语言发展的一个重要里程碑,它极大地增强了语言的表达能力和灵活性,本文将通过泛型实现封装常见的Map操作,感... 目录什么是泛型泛型解决了什么问题Go泛型基于泛型的常见Map操作代码合集总结什么是泛型泛型是一种编程范式,允

JavaSE——封装、继承和多态

1. 封装 1.1 概念      面向对象程序三大特性:封装、继承、多态 。而类和对象阶段,主要研究的就是封装特性。何为封装呢?简单来说就是套壳屏蔽细节 。     比如:对于电脑这样一个复杂的设备,提供给用户的就只是:开关机、通过键盘输入,显示器, USB 插孔等,让用户来和计算机进行交互,完成日常事务。但实际上:电脑真正工作的却是CPU 、显卡、内存等一些硬件元件。

哈希表的封装和位图

文章目录 2 封装2.1 基础框架2.2 迭代器(1)2.3 迭代器(2) 3. 位图3.1 问题引入3.2 左移和右移?3.3 位图的实现3.4 位图的题目3.5 位图的应用 2 封装 2.1 基础框架 文章 有了前面map和set封装的经验,容易写出下面的代码 // UnorderedSet.h#pragma once#include "HashTable.h"

封装MySQL操作时Where条件语句的组织

在对数据库进行封装的过程中,条件语句应该是相对难以处理的,毕竟条件语句太过于多样性。 条件语句大致分为以下几种: 1、单一条件,比如:where id = 1; 2、多个条件,相互间关系统一。比如:where id > 10 and age > 20 and score < 60; 3、多个条件,相互间关系不统一。比如:where (id > 10 OR age > 20) AND sco

Java封装构造方法

private/public的分装 被public修饰的成员变量或者是成员方法,可以被类的调用对象直接使用 而private修饰的成员变量和方法,不能被类的调用对象使用 例如: 可以看到我们是不能在main方法中直接调用被private修饰的变量 当然我们可以在我们定义的TestMode类中可以定一个方法show,然后在调用show方法实现 这里我们可以清楚了解 private 不光可以修