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