首页 技术 正文
技术 2022年11月14日
0 收藏 500 点赞 4,198 浏览 2946 个字

参考地址:《C#使用RabbitMQ

C#操作RabbitMQ需要引用RabbitMQ的DLL,地址是:http://www.rabbitmq.com/releases/rabbitmq-dotnet-client/

下载最新版本即可,因为我使用的.Net Framework 4.5,所以选择

c# RabbitMQ 发送消息

下载后解压

c# RabbitMQ 发送消息

创建工程后,先引用RabbitMQ的库RabbitMQ.Client.dll,即第一个dll文件

这里我使用了一个新通用Class,首先需要引用RabbitMQ的命令空间 using RabbitMQ.Client;

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;using RabbitMQ.Client;namespace MES_MonitoringClient.Common
{
/// <summary>
/// RabbitMQ队列上传动作
/// </summary>
public class RabbitMQClientHandler
{
// 定义一个静态变量来保存类的实例
private static RabbitMQClientHandler uniqueInstance;
//定义一个标识确保线程同步
private static readonly object locker = new object(); /*-------------------------------------------------------------------------------------*/ //ConnectionFactory
private static ConnectionFactory mc_ConnectionFactory = null;
//Connection
public IConnection Connection;
//Channel
public IModel Channel; /*-------------------------------------------------------------------------------------*/ /// <summary>
/// 定义私有构造函数,使外界不能创建该类实例
/// </summary>
public RabbitMQClientHandler()
{
//连接工厂
mc_ConnectionFactory = new ConnectionFactory(); //连接工厂信息
mc_ConnectionFactory.HostName = "localhost";
mc_ConnectionFactory.UserName = "guest";
mc_ConnectionFactory.Password = "guest"; //创建连接
Connection = mc_ConnectionFactory.CreateConnection();
//创建频道
Channel = Connection.CreateModel();
} /// <summary>
/// 定义公有方法提供一个全局访问点,同时你也可以定义公有属性来提供全局访问点
/// </summary>
/// <returns></returns>
public static RabbitMQClientHandler GetInstance()
{
// 当第一个线程运行到这里时,此时会对locker对象 "加锁",
// 当第二个线程运行该方法时,首先检测到locker对象为"加锁"状态,该线程就会挂起等待第一个线程解锁
// lock语句运行完之后(即线程运行完之后)会对该对象"解锁"
// 双重锁定只需要一句判断就可以了
if (uniqueInstance == null)
{
lock (locker)
{
// 如果类的实例不存在则创建,否则直接返回
if (uniqueInstance == null)
{
uniqueInstance = new RabbitMQClientHandler();
}
}
}
return uniqueInstance;
} /*-------------------------------------------------------------------------------------*/ /// <summary>
/// 发送消息至服务端
/// </summary>
/// <param name="queueName"></param>
/// <param name="message"></param>
/// <returns></returns>
public bool publishMessageToServer(string queueName, string message)
{
try
{
//创建一个持久化的频道
bool durable = true;
Channel.QueueDeclare(queueName, durable, false, false, null); //设置消息持久性
//var properties = Channel.CreateBasicProperties();
//properties.SetPersistent(true); //消息内容转码,并发送至服务器
var messageBody = Encoding.UTF8.GetBytes(message);
Channel.BasicPublish("", "test", null, messageBody); return true;
}
catch (Exception ex)
{
return false;
}
} }
}

RabbitMQClientHandler

然后在调用时,只需要使用

Common.RabbitMQClientHandler.GetInstance().publishMessageToServer("test", "test message");

这里需要比较的地方是,在测试过程中发现

  • 1.同一个服务器中,不能有两个一样名字的Queue
  • 2.针对同一个Queue,发送端与接收端的Channel.QueueDeclare时指定的durable(bool类型)指定的不同,也不能顺利接收到
  • 3.还有在发送时,Channel.BasicPublish(“”, “test”, null, messageBody);  其中的routing参数也需要与Queue保持一致(后期可以通过设置Exchange和Routing对Queue进行分配)

2019-01-04 发现一个问题问题表现为,RabbitMQ发送服务为后台服务,在开发环境中,RabbitMQ服务器有可能会随时中断,那么后台服务一直在运行,建立的连接则只存在于过去,RabbitMQ重新启动后,之前创建的连接已经不存了,导致后台服务即使能读到Mongodb中的数据,但是无法通过之前建立的连接将数据发送至RabbitMQ服务器,这时,只需要将后台服务重新启动,重新创建新的连接即可正常服务,在代码中需要增加一些判断,如果发送RabbitMQ不能成功,则需要重新建立RabbitMQ连接,方便发送数据。

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,495
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,909
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,741
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,496
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:8,134
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:5,298