如果小伙伴们还没有安装rabbitmq,可以参考下面链接
https://www.cnblogs.com/kiba/p/11703073.html
如果想要快速获取整个rabbitmq安装包,就关注本人公众号“墨水直达”回复"rabbitmq下载"即可获取
发送方:
static void Main(string[] args)
{
var factory = new ConnectionFactory();
factory.HostName = "xxx.xxx.xxx.xx";
factory.UserName = "xxx";
factory.Password = "xxxxx";
using (var connection = factory.CreateConnection())//连接服务器,即正在创建终结点。
{
//创建一个通道,这个就是Rabbit自己定义的规则了,如果自己写消息队列,这个就可以开脑洞设计了
//这里Rabbit的玩法就是一个通道channel下包含多个队列Queue
using (var channel = connection.CreateModel())
{
for (int i = 0; i < 100; i++)
{
channel.QueueDeclare("kibaQueue", false, false, false, null);//创建一个名称为kibaQueue的消息队列
var properties = channel.CreateBasicProperties();
properties.DeliveryMode = 1;
string message = "I am Kiba518"; //传递的消息内容
channel.BasicPublish("", "kibaQueue", properties, Encoding.UTF8.GetBytes(message)); //生产消息
Console.WriteLine($"Send:{message}");
Thread.Sleep(3000);
}
}
}
Console.ReadLine();
}
接收方:
static void Main(string[] args)
{
var factory = new ConnectionFactory();
factory.HostName = "xxx.xx.xxx.xx";
factory.UserName = "xxx";
factory.Password = "xxxxx";
using (var connection = factory.CreateConnection())
{
using (var channel = connection.CreateModel())
{
channel.QueueDeclare("kibaQueue", false, false, false, null);
var consumer = new EventingBasicConsumer(channel);//消费者
channel.BasicConsume("kibaQueue", true, consumer);//消费消息 autoAck参数为消费后是否删除
consumer.Received += (model, ea) =>
{
var body = ea.Body;
var message = Encoding.UTF8.GetString(body);
Console.WriteLine("Received: {0}", message);
};
Console.ReadLine();
}
}
}
有兴趣的小伙伴也可以关注我的公众号呀!里面有各种编程资源免费领取哦