RabbitMQ 消费端 Client CPU 100%的解决办法


 Func<bool> run = () =>
            {
                try
                {
                    using (IConnection conn = cf.CreateConnection())
                    {
                        using (IModel channel = conn.CreateModel())
                        {
                            var consumer = createConsumer(channel);
                            while (channel.IsOpen)
                            {
                                Thread.Sleep(10);
                                BasicDeliverEventArgs ea = null;
                                try
                                {
                                    ea = consumer.Queue.DequeueNoWait(null);
                                    if (ea == null) continue;
                                }

                                catch (Exception ex)
                                {
                                    TraceLogHelper.WriteError("RabbitMQ", "【里面】", ex.StackTrace);
                                    break;
                                }
                                var body = ea.Body;
                                var message = Encoding.UTF8.GetString(body);
                                var b = func(message);
                                if (b)
                                {
                                    channel.BasicAck(ea.DeliveryTag, false);
                                    Console.WriteLine("接收消息成功:" + message);
                                }

      
                            }
                        }
                    }
                    return true;
                }
                catch (Exception ex)
                {
                    TraceLogHelper.WriteError("RabbitMQ", "[外层]", ex.StackTrace);
                    return false;
                }
            };

  

增加一个 Thread.Sleep(10);即可解决。

 

以后遇到无线循环的时候,需要加Sleep


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM