参考地址:《C#使用RabbitMQ

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

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

下载后解压

创建工程后,先引用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连接,方便发送数据。

c# RabbitMQ 发送消息的更多相关文章

  1. SpringBoot Rabbitmq发送消息

    官方文档:https://docs.spring.io/spring-boot/docs/2.1.3.RELEASE/reference/htmlsingle/#boot-features-amqp ...

  2. 给RabbitMQ发送消息时,设置请求头Header。

    消费者的请求头 生产者设置请求头 由于消费者那里,@Payload是接受的消息体,使用了@Header注解,需要请求头,生产者这边就要设置请求头,然后rabbitTemplate再调用convertA ...

  3. RabbitMQ发送消息成功,但是接受不到消息

    commom模块为mq配置模块 分了多模块后消息队列无法自动创建,发现原因竟然是SpringBoot没有扫描到common模块内的配置类. 我们在XxxApplication启动类上添加@Compon ...

  4. java 操作 RabbitMQ 发送、接受消息

    例子1 Producer.java import java.io.IOException; import java.util.concurrent.TimeoutException; import c ...

  5. RabbitMQ初学之二:直接发送消息到队列

    一. 背景 总前提:队列无论是在生产者声明还是在消费者声明,只有声明了,才能在RabbitMQ的管理界面看到该队列 生产者直接发送消息到队列,消费者直接消费队列中的消息,而不用指定exchange并绑 ...

  6. rabbitmq实现一台服务器同时给指定部分的consumer发送消息(tp框架)(第六篇)

    previous article:  http://www.cnblogs.com/spicy/p/7989717.html 上一篇学习了,发送消息的时候用direct类型的exchange,绑定不同 ...

  7. rabbitmq实现一台服务器同时给所有的consumer发送消息(tp框架)(第四篇)

    之前的学习了把消息直接publish到queue里面,然后consume掉, 真实的情况,我们会把消息先发送到exchange里面,由它来处理,是发给某一个队列,还是发给某些队列,还是丢弃掉? exc ...

  8. RabbitMQ + topic发送消息+python

    接口使用两个queue监听信息,且有两个测试环境,所以需要向mq中发送测试数据: python使用pika包:Pika is a RabbitMQ (AMQP-0-9-1) client librar ...

  9. RabbitMQ学习系列二-C#代码发送消息

    RabbitMQ学习系列二:.net 环境下 C#代码使用 RabbitMQ 消息队列 http://www.80iter.com/blog/1437455520862503 上一篇已经讲了Rabbi ...

随机推荐

  1. (转)JAVA 十六个常用工具类

    一. org.apache.commons.io.IOUtils closeQuietly 关闭一个IO流.socket.或者selector且不抛出异常.通常放在finally块 toString ...

  2. js闭包及问题的解决

    闭包定义,作用 闭包就是能够读取其他函数内部变量的函数. 作用:一个是可以读取函数内部的变量,另一个就是让这些变量的值始终保持在内存中 缺点:闭包会保存函数中的变量在内存中,导致内存消耗大   闭包会 ...

  3. 洛谷 U3357 C2-走楼梯

    https://www.luogu.org/problem/show?pid=U3357 题目背景 在你成功地解决了上一个问题之后,方方方不禁有些气恼,于是他在楼梯上跳来跳去,想要你求出他跳的方案数. ...

  4. 2015/11/2用Python写游戏,pygame入门(2):游戏中的事件和显示

    pygame是一个比较大的库,以我这点弱小的实力是没办法详解的.所以我只讲我懂得那些部分,其他部分由大家慢慢查找了解. ------------------------------- 我用pygame ...

  5. 新Linux系统配置yum源

    新的Linux系统安装好以后,yum的源还是需要配置一下的,我使用的是redhat6.6版本,同时为了不注册而使用更多的yum源的资源,也需要做一下的修改. 1. 删除redhat原有的yum源 # ...

  6. 非法字符:"\ufeff"

    Eclipse项目导入IDEA可能遇到这样的问题 ,原因就是: 带BOM的UTF-8」和「无BOM的UTF-8」 方法一.用Notepad++把文件转成无BOM的UTF-8 另存为,替换原来的文件 方 ...

  7. Linux网络知识

    在思科上面模拟一下数据包的传递过程:一般上网使用的协议是tcp 交换机是一个2层的设备,它和Ip地址是没有关系的. 交换机上主要处理的是硬件地址(MAC),它只能分析到硬件地址,再到IP地址它就不管了 ...

  8. JVM学习十二:JVM之性能监控工具

    前面我们学习了很多JVM相关的理论知识,那么本节将重点讲述的是工具的使用,正所谓:工欲善其事,必先利其器.因此,本节介绍常用的性能监控工具,用于性能监控和问题排查. 一.系统性能监控 系统性能工具用于 ...

  9. 51nod1056 最长等差数列 V2

    基准时间限制:8 秒 空间限制:131072 KB 分值: 1280  N个不同的正整数,从中选出一些数组成等差数列.   例如:1 3 5 6 8 9 10 12 13 14 等差子数列包括(仅包括 ...

  10. 【CODEVS】1922 骑士共存问题

    [算法]二分图最大匹配(最大流) [题解]按(i+j)奇偶性染色后,发现棋子跳到的地方刚好异色. 然后就是二分图了,对于每个奇点向可以跳到的地方连边,偶点不需连(可逆). 所以题目要求转换为求二分图上 ...