当前位置: 首页 > news >正文

网站如何做404页面中间商可以做网站吗

网站如何做404页面,中间商可以做网站吗,高质量的赣州网站建设,住房和城乡建设部网站进不去一#xff1a;背景 1. 讲故事10月份星球里的一位老朋友找到我#xff0c;说他们公司的程序在一个网红直播带货下给弄得无响应了#xff0c;无响应期间有大量的 RabbitMQ 超时#xff0c;寻求如何找到根源#xff0c;聊天截图我就不发了。既然无响应了#xff0c;那必然是… 一背景 1. 讲故事10月份星球里的一位老朋友找到我说他们公司的程序在一个网红直播带货下给弄得无响应了无响应期间有大量的 RabbitMQ 超时寻求如何找到根源聊天截图我就不发了。既然无响应了那必然是程序的大量线程被主动或者被动的挂起朋友也很及时的从程序上抽了一管血下来接下来就上 windbg 一起探究下到底发生了什么二Windbg 分析 1. 线程们都怎么了要想看所有线程还是老命令  !t 。0:000 !t ThreadCount:      5221 UnstartedThread:  0 BackgroundThread: 5199 PendingThread:    0 DeadThread:       21 Hosted Runtime:   noLock  DBG   ID     OSID ThreadOBJ           State GC Mode     GC Alloc Context                  Domain           Count Apt Exception20    1     74e4 00000276CB778180  202a020 Preemptive  0000000000000000:0000000000000000 00000276cb77c9d0 -00001 MTA 31    2     42cc 00000276CB6CA830    2b220 Preemptive  0000000000000000:0000000000000000 00000276cb77c9d0 -00001 MTA (Finalizer) 32    3     2b40 00000276CB85D1B0  102a220 Preemptive  0000000000000000:0000000000000000 00000276cb77c9d0 -00001 MTA (Threadpool Worker) 2    6     bccc 00000276CBA5D2F0    20220 Preemptive  0000000000000000:0000000000000000 00000276cb77c9d0 -00001 Ukn 33    9     7224 00000276CBA5C0C0  3029220 Preemptive  0000000000000000:0000000000000000 00000276cb77c9d0 -00001 MTA (Threadpool Worker) System.IO.IOException 00000279ccc56cd09   23     29e0 0000027BD86FD180    20220 Preemptive  0000000000000000:0000000000000000 00000276cb77c9d0 -00001 Ukn  ...从简要信息看当前有 5000 的线程太牛了一般一台机器的所有进程的线程加起来也没这么多。。。不过我目前看到最多的是 1w 的线程 就是那种不用线程池直接用 Thread 造成的一种线程垃圾。可以看到线程列表中的 9号线程 抛了托管异常接下来看看是个啥错误, 使用 !wpe 00000279ccc56cd0 命令。0:000 !wpe 00000279ccc56cd0 Address: 00000279ccc56cd0 Exception Type: System.IO.IOException Message: Unable to read data from the transport connection: 远程主机强迫关闭了一个现有的连接。. Inner Exception: 00000279ccc56b20 System.Net.Sockets.SocketException 远程主机强迫关闭了一个现有的连接。 Stack: SP               IP               Function 000000791b88c970 00007ffd844a1b31 System.Net.Sockets.NetworkStream.Read(Byte[], Int32, Int32) 000000791b88ee80 00007ffd849e6f8a System.IO.BufferedStream.ReadByteSlow() 000000791b88eeb0 00007ffd8312950a RabbitMQ.Client.Impl.InboundFrame.ReadFrom(System.IO.Stream, Byte[]) 000000791b88ef40 00007ffd849e6d7d RabbitMQ.Client.Framing.Impl.Connection.MainLoopIteration() 000000791b88efa0 00007ffd8312832f RabbitMQ.Client.Framing.Impl.Connection.MainLoop()HResult: 80131620从堆栈信息来看程序做了一个远程访问 RabbitMQ结果 tcp 连接被对方关闭了貌似和朋友说的有大量 RabbitMQ 超时有关。接下来就是查看各个线程栈研究下此时这些线程都在干什么使用 ~*e !clrstack 命令通过仔细研读线程栈我发现有大量的方法卡在 xxx.RabbitMq.RabbitMqConnection.GetInstance 方法处。Child SP               IP Call Site 0000008B8A9ED6A8 00007ffdf5246594 [HelperMethodFrame_1OBJ: 0000008b8a9ed6a8] System.Threading.Monitor.ReliableEnter(System.Object, Boolean ByRef) 0000008B8A9ED800 00007ffd84a6a4a9 xxx.RabbitMq.RabbitMqConnection.GetInstance(Microsoft.Extensions.Options.IOptions1xxx.RabbitMq.RabbitMqConfig, Microsoft.Extensions.Logging.ILogger1System.Object) 0000008B8A9ED860 00007ffd84a6a317 xxx.RabbitMq.RabbitMqProducer..ctor(Microsoft.Extensions.Options.IOptionsSnapshot1xxx.RabbitMq.RabbitMqConfig, Microsoft.Extensions.Logging.ILogger1xxx.RabbitMq.RabbitMqProducer) 0000008B8A9ED8A0 00007ffd8334817b DynamicClass.ResolveService(ILEmitResolverBuilderRuntimeContext, Microsoft.Extensions.DependencyInjection.ServiceLookup.ServiceProviderEngineScope) 0000008B8A9ED930 00007ffd83347d76 DynamicClass.ResolveService(ILEmitResolverBuilderRuntimeContext, Microsoft.Extensions.DependencyInjection.ServiceLookup.ServiceProviderEngineScope) 0000008B8A9EDE90 00007ffd844f3cb3 Microsoft.Extensions.DependencyInjection.ActivatorUtilities.GetService(System.IServiceProvider, System.Type, System.Type, Boolean) [/_/src/libraries/Common/src/Extensions/ActivatorUtilities/ActivatorUtilities.cs  173] DynamicClass.lambda_method196(System.Runtime.CompilerServices.Closure, System.IServiceProvider, System.Object[]) 0000008B8A9EDF20 00007ffd84a0fc9c Microsoft.AspNetCore.Mvc.Controllers.ControllerFactoryProviderc__DisplayClass5_0.g__CreateController|0(Microsoft.AspNetCore.Mvc.ControllerContext) 0000008B8A9EDF70 00007ffd8452ce7f Microsoft.AspNetCore.Mvc.Infrastructure.ControllerActionInvoker.Next(State ByRef, Scope ByRef, System.Object ByRef, Boolean ByRef) [/_/src/Mvc/Mvc.Core/src/Infrastructure/ControllerActionInvoker.cs  285] 0000008B8A9EE030 00007ffd84a0fac8 Microsoft.AspNetCore.Mvc.Infrastructure.ControllerActionInvoker.InvokeInnerFilterAsync() [/_/src/Mvc/Mvc.Core/src/Infrastructure/ControllerActionInvoker.cs  490] 0000008B8A9EE0B0 00007ffd845346cd Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.Next(State ByRef, Scope ByRef, System.Object ByRef, Boolean ByRef) [/_/src/Mvc/Mvc.Core/src/Infrastructure/ResourceInvoker.cs  883] 0000008B8A9EE240 00007ffd84a0f9ad Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.InvokeNextExceptionFilterAsync() [/_/src/Mvc/Mvc.Core/src/Infrastructure/ResourceInvoker.cs  1024] 0000008B8A9EE2C0 00007ffd84534272 Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.Next(State ByRef, Scope ByRef, System.Object ByRef, Boolean ByRef) [/_/src/Mvc/Mvc.Core/src/Infrastructure/ResourceInvoker.cs  883] 0000008B8A9EE450 00007ffd84a0f850 Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.InvokeNextResourceFilter() [/_/src/Mvc/Mvc.Core/src/Infrastructure/ResourceInvoker.cs  976] ...从调用栈信息看源头是一个http请求然后在 GetInstance 下的 lock 处被冻结这就激发了我很大的好奇心接下来根据 IP 导出源码看看。public sealed class RabbitMqConnection {public static RabbitMqConnection GetInstance(IOptionsRabbitMqConfig options, ILoggerdynamic logger){if (_uniqueInstance  null || _uniqueInstance.Connection  null || !_uniqueInstance.Connection.IsOpen){lock (_objLock){if (_uniqueInstance  null || _uniqueInstance.Connection  null || !_uniqueInstance.Connection.IsOpen){_uniqueInstance  new RabbitMqConnection(options.Value, logger);}}}return _uniqueInstance;}private RabbitMqConnection(RabbitMqConfig config, ILoggerdynamic logger){Policy.HandleSocketException().OrBrokerUnreachableException().WaitAndRetry(6, (int retryAttempt)  TimeSpan.FromSeconds(1.0), delegate (Exception ex, TimeSpan time, int retryCount, Context content){if (6  retryCount){throw ex;}_logger.LogError(ex, ${retryCount}:{ex.Message});}).Execute(delegate{Connection  factory.CreateConnection();});} }从代码逻辑看朋友用了 双检锁 来给 RabbitMQ 实例做单例化如果实例创建失败还会有 6 次 1s 的尝试这种写法乍一看没什么问题。2. 单例写法真的没问题吗如果单例写法没问题的话为什么有大量的线程卡在 lock 处呢既然是 单例 那肯定是 rabbitmq 第一次被实例化后后人直接乘凉就好了哈带着这个疑问再次检查 双检索 写法尼玛在判断单例的时候居然做了 _uniqueInstance.Connection.IsOpen 判断大家知道这意味着什么吗这意味着一旦 rabbitmq 在某个时刻挂掉了单例条件就被破防了无数的线程排队来做 RabbimtMQ 的实例化要知道这都是些不实例出来不罢休的勇士继而导致程序挂死...3. 验证我的想法既然从源码中推出了这个代码缺陷但口说无凭我得拿出证据要想验证很简单到托管堆寻找 RabbitMqConnection 实例看下此时它的 IsOpen 是不是 false 即可, 通过 ILSpy 查看源码发现它是用 CloseReasonnull 来判断的。接下来看看 CloseReason 不为空即可。0:000 !dumpheap -type RabbitMqConnectionAddress               MT     Size 00000277cbd7aa68 00007ffd831f1570       32   00000277ccb13068 00007ffd831f1570       32   0:000 !DumpObj /d 00000277cbd7b858 Name:        RabbitMQ.Client.Framing.Impl.AutorecoveringConnection MethodTable: 00007ffd83235db0 EEClass:     00007ffd83242898 Size:        200(0xc8) bytes File:        G:\xxx\RabbitMQ.Client.dll Fields:MT    Field   Offset                 Type VT     Attr            Value Name 00007ffd82397238  4000180       bc       System.Boolean  1 instance                0 _disposed 00007ffd82390c68  4000181        8        System.Object  0 instance 00000277cbd7b920 _eventLock 00007ffd831fc230  4000182       10 ...g.Impl.Connection  0 instance 00000277cbd7d5f8 _delegate0:000 !DumpObj /d 00000277cbd7d5f8 Name:        RabbitMQ.Client.Framing.Impl.Connection MethodTable: 00007ffd831fc230 EEClass:     00007ffd8322cd70 Size:        232(0xe8) bytes File:        G:\xxx\RabbitMQ.Client.dll Fields:MT    Field   Offset                 Type VT     Attr            Value Name 00007ffd82397238  4000198       b8       System.Boolean  1 instance                0 _disposed 00007ffd82390c68  4000199        8        System.Object  0 instance 00000277cbd7d6e0 _eventLock 00007ffd82d93d00  400019a       10 ...ualResetEventSlim  0 instance 00000277cbd7d6f8 _appContinuation 00007ffd83276028  400019b       18 ...ShutdownEventArgs  0 instance 00000279ccc56e28 _closeReason0:000 !do 00000277ccb13068 Name:        xxx.RabbitMq.RabbitMqConnection MethodTable: 00007ffd831f1570 EEClass:     00007ffd831eb920 Size:        32(0x20) bytes File:        G:\xxx\xxx.dll Fields:MT    Field   Offset                 Type VT     Attr            Value Name 00007ffd831f13f8  400001f        8 ...Private.CoreLib]]  0 instance 00000278cbe4c2a0 _logger 00007ffd831f2ab0  4000020       10 ...lient.IConnection  0 instance 0000000000000000 Connectionk__BackingField 00007ffd831f1570  400001d        8 ...abbitMqConnection  0   static 00000277cbd7aa68 _uniqueInstance 00007ffd82390c68  400001e       10        System.Object  0   static 00000277cbd7aa50 _objLock从输出信息中可以很清楚的看到当前托管堆有两个 RabbitMqConnection 对象其中一个果然是失败了(_closeReason00000279ccc56e28)还有一个正在努力的new Connectionk__BackingField0000000000000000 这也就验证了假设。4. 后续有了这些信息和朋友做了下沟通建议再优化一下 IsOpenfalse 时的异常处理逻辑比如 return 或者 throw new或者干脆不要用懒检测 千万不要硬着来。至于造成 RabbitMQ 不响应的一系列诱因朋友通过参考的开源项目发现将别人的 AddSingleton 改成了 AddScoped。这也就造成了每一次Http请求都要试探性的判断单例逻辑, 别人的解法是一旦上层单例化了下层就不会再次处理了也就不会走 IsOpen 逻辑。三总结 造成本次程序卡死的事故主要有两点RabbitMQ 生成单例化中的 IsOpen 判断问题建议改用自动重连属性 AutomaticRecoveryEnabled 和 TopologyRecoveryEnabled或者用静态构造函数替代双检锁。过多的 http 请求对单例逻辑的试探按照朋友的改发将 Scoped 改成 Singleton 来规避。END工作中的你是否已遇到 ... 1. CPU爆高2. 内存暴涨3. 资源泄漏4. 崩溃死锁5. 程序呆滞等紧急事件全公司都指望着你能解决...  危难时刻才能展现你的技术价值作为专注于.NET高级调试的技术博主欢迎微信搜索: 一线码农聊技术免费协助你分析Dump文件希望我能将你的踩坑经验分享给更多的人。
http://www.zqtcl.cn/news/797107/

相关文章:

  • 专业的集团网站设计公司优化网站服务
  • 深圳专业网站建设公司好吗个人网站排名欣赏
  • 百度网站流量查询网站建设流程总结
  • 使用代理服务器后看什么网站怎么做动态的实时更新的网站
  • 网站修改titlephp 网站下载器
  • 网站开发飞沐东莞人才市场档案服务中心
  • 北京中小企业网站建设智慧团建官网登录口手机版
  • wordpress插 件seo服务是什么
  • 推荐几个安全没封的网站湖南长大建设集团股份有限公司网站
  • 免费淘宝客网站模板下载怎么申请注册公司
  • 网站动画用什么做wordpress 主题 下载
  • 制作网站的app推动高质量发展的必要性
  • 网站建设培训个人企业的官网
  • 物流公司做网站佛山市城乡和住房建设局网站
  • 建设银行六安市分行网站云梦网络建站
  • 寿光专业做网站的公司有哪些网页制作基础教程黄洪杰
  • discuz可以做门户网站么江西省网站备案
  • 天眼查在线查询系统seo平台优化服务
  • 建设部网站 注册违规北京梵客装饰
  • 大连制作网站报价网站网站怎么做代理
  • php做网站如何架构品牌vi设计欣赏
  • 网站外链建设与文章发布规范网址例子
  • 外贸网站空间选择商业计划书
  • 手机作图软件app专业做邯郸网站优化
  • 济南网站定制制作wordpress theid
  • 企业网站建设能解决什么问题设计房子需要多少钱
  • 专业网站开发制作石家庄信息门户网站定制
  • 藤虎网络广州网站建设网站域名实名认证官网
  • 佛山专业网站建设公司推荐it行业做网站一个月多少钱
  • 三网合一网站怎么做苏醒主题做的网站