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

非法网站怎么推广猎聘网招聘官方网站

非法网站怎么推广,猎聘网招聘官方网站,建设银行科技中心网站首页,网站子页面如何做seo一#xff1a;背景 1. 讲故事前天有位粉丝朋友在后台留言让我帮忙看看他的 Winform程序 UI无响应 410线程 到底是啥情况#xff0c;如下图#xff1a;说实话#xff0c;能看到这些真实案例我是特别喜欢的???????????? #xff0c;就像医生看病#xff0c;光… 一背景 1. 讲故事前天有位粉丝朋友在后台留言让我帮忙看看他的 Winform程序 UI无响应 410线程 到底是啥情况如下图说实话能看到这些真实案例我是特别喜欢的???????????? 就像医生看病光停留在理论和那些 demo 上那是没有前途的如果有朋友在这块搞不定的话我可以免费帮你解读 dump再附送一篇博客详述。好了言归正传既然粉丝朋友已经提到了高达 410 线程我本能反应就是要么高负载要么野线程后者大多是无数新出现的线程卡在某个锁上。WinForm 出现高负载的情况我至今还是没遇到????????????如果说卡在某个锁上基本都属于这类有了这个先入为主的思路接下来就可以祭出 windbg 一探究竟了。二windbg 分析 1. 查找 CLR 同步块表十个人用锁八个人会用 lock, 所以先用 !syncblk 看看程序的锁情况。 0:000 !syncblk Index         SyncBlock MonitorHeld Recursion Owning Thread Info          SyncBlock Owner76   070e5fa4           67         1 17367570 15e8 218   03e6dd68 System.IO.Ports.SerialStream ----------------------------- Total           789 CCW             39 RCW             2 ComClassFactory 1 Free            535我去从卦象上来看情况很不好我来简单分析下。MonitorHeld 67这个 67 表示当前有 1 个线程持有锁有 33 个线程在等待锁肯定有朋友想问怎么算的很简单当一个线程持有了锁的时候 MonitorHeld1 当一个线程在等待锁的时候 MonitorHeld2 所以表达式就是:  67 [1 66(33*2)]。Owning Thread Info  17367570 15e8 218上面三个信息都表示当前持有线程可以看最后的 218它是 windbg 映射出来的线程ID如果不信的话可以用 !t 来一探究竟。 0:000 !t ThreadCount:      315 UnstartedThread:  0 BackgroundThread: 302 PendingThread:    0 DeadThread:       0 Hosted Runtime:   noLock  ID OSID ThreadOBJ    State GC Mode     GC Alloc Context  Domain   Count Apt Exception0    1  c64 00cc3de0     24220 Preemptive  042E1884:00000000 00cbc0a0 0     STA 214  240 1398 16702b90   1029220 Preemptive  00000000:00000000 00cbc0a0 0     MTA (Threadpool Worker) 215  323  b5c 12ab7260   1029220 Preemptive  00000000:00000000 00cbc0a0 0     MTA (Threadpool Worker) 216  290 1858 16c21c98   1029220 Preemptive  00000000:00000000 00cbc0a0 0     MTA (Threadpool Worker) 218  117 15e8 17367570   1029220 Preemptive  00000000:00000000 00cbc0a0 1     MTA (Threadpool Worker) ...对就是 218 这个罪魁祸首在持有了锁导致 33 个线程在无辜的等待它。。。SyncBlock Owner System.IO.Ports.SerialStream也许你会好奇到底 lock 持有的是哪一个对象呢从 SyncBlock Owner 上看就是 SerialStream ????????原来老兄在玩串口编码我先膜拜一下。2. 查看线程栈知道是 218 惹的祸接下来可以看看它的线程栈到底都在干什么关于上面的调用栈可能有些朋友看不明白我画了一张简图从图中看来自于 ThreadPool 的线程在用户自定义的 DataReceived 方法上卡住了为了方便我就用 !DumpIL 看看这个方法的 IL 代码。 0:218 !name2ee *!xxx.TYAComYB.DataReceived Module:      03b10cc4 Assembly:    YKit.dll Token:       06000108 MethodDesc:  08533584 Name:        xxx.TYAComYB.DataReceived(System.Object, System.IO.Ports.SerialDataReceivedEventArgs) JITTED Code Address: 08644dc00:218 !dumpil 08533584 ilAddr  05dc2dd8 IL_0000: nop  IL_0001: nop  IL_0002: nop  IL_0003: ret ????????这代码居然藏了钩子用 !dumpil 居然看不到代码难怪在线程栈上看到了类似混淆的方法xxx.TYAComYB.EYLlXL2bKH()不过看反汇编是没有问题的,简化如下 0:218 !U /d 08644edf 08644ddd e86edaffff      call    08642850 (xxxx.com.ComPort.get_isOpen(), mdToken: 060004b6) 08644df4 e807deffff      call    08642c00 (xxxx.YBComParam.get_DataPacketLen(), mdToken: 0600010c) 08644dfb b92a3e136e      mov     ecx,offset mscorlib_ni!System.GC.ReRegisterForFinalize(System.Object) PERF (mscorlib_ni0x3e2a) (6e133e2a) 08644e00 e80fd460f8      call    00c52214 (JitHelp: CORINFO_HELP_NEWARR_1_VC) 08644e15 e8e6ddffff      call    08642c00 (xxx.YBComParam.get_DataPacketLen(), mdToken: 0600010c) 08644e22 e8edac4d68      call    System_ni0x13fb14 (70b1fb14) (System.IO.Ports.SerialPort.Read(Byte[], Int32, Int32), mdToken: 06004173) 08644e2e ff153836b103    call    dword ptr ds:[3B13638h] (xxxx.LogKit.WriteLine(System.Exception), mdToken: 06000183) 08644e59 e8a2ddffff      call    08642c00 (xxxx.YBComParam.get_DataPacketLen(), mdToken: 0600010c) 08644e64 ff1580355308    call    dword ptr ds:[8533580h] (xxxx.TYAComYB.EYLlXL2bKH(), mdToken: 06000107) 08644e9b ff15a4265308    call    dword ptr ds:[85326A4h] (xxxx.YBComParam.get_DataPacketStart(), mdToken: 0600010e) 08644ea8 e837e34e66      call    mscorlib_ni!System.Convert.ToByte(System.String, Int32) (6eb331e4) 08644ed9 ff1580355308    call    dword ptr ds:[8533580h] (xxxx.TYAComYB.EYLlXL2bKH(), mdToken: 06000107)反正做的事情挺多我就懒得分析了。接下来看看那 33 个线程怎么就卡在 SerialStream 上呢可以用 ~*e !clrstack 扫一下所有的 threads抽几个看看。 0:218 ~*e !clrstack OS Thread Id: 0xc64 (0) Child SP       IP Call Site OS Thread Id: 0x13d8 (330) Child SP       IP Call Site 1b1aec90 77c8016d [GCFrame: 1b1aec90]  1b1aee30 77c8016d [GCFrame: 1b1aee30]  1b1aede0 77c8016d [HelperMethodFrame: 1b1aede0] System.Threading.Monitor.ReliableEnter(System.Object, Boolean ByRef) 1b1aee70 710d6b54 System.IO.Ports.SerialPort.CatchReceivedEvents(System.Object, System.IO.Ports.SerialDataReceivedEventArgs) 1b1aeeac 710d9520 System.IO.Ports.SerialStreamEventLoopRunner.CallReceiveEvents(System.Object) 1b1aeec0 6e45e356 System.Threading.QueueUserWorkItemCallback.WaitCallback_Context(System.Object) 1b1aeec8 6e43da07 System.Threading.ExecutionContext.RunInternal(System.Threading.ExecutionContext, System.Threading.ContextCallback, System.Object, Boolean) 1b1aef34 6e43d956 System.Threading.ExecutionContext.Run(System.Threading.ExecutionContext, System.Threading.ContextCallback, System.Object, Boolean) 1b1aef48 6e45f120 System.Threading.QueueUserWorkItemCallback.System.Threading.IThreadPoolWorkItem.ExecuteWorkItem() 1b1aef5c 6e45e929 System.Threading.ThreadPoolWorkQueue.Dispatch() 1b1aefac 6e45e7d5 System.Threading._ThreadPoolWaitCallback.PerformWaitCallback() 1b1af1d4 71382552 [DebuggerU2MCatchHandlerFrame: 1b1af1d4] 我去居然都卡在 System.IO.Ports.SerialPort.CatchReceivedEvents 这里了而且还是 framework 提供的这就很困惑了。3. 分析 SerialPort 源码要想看 SerialPort 类的源码可以用 ILSpy如下图所示:看到这里再结合我刚才画的图思路是不是就清晰多了究其原因就是 dataReceived(this, e); 触发的用户回调函数迟迟得不到结束导致底层大量的线程在 lock 处等待。三总结 为了理解为啥底层会创建那么多线程我特意还查了下串口类 SerialPort说串口发送方送过来的数据接收方可以主动接收可以被动接收被动就是这种 事件模式接收方收到发送方送来的数据时操作系统会让 CLR 通过 Thread 来处理这段回调事件所以从卦象上看就是典型的接收方处理能力不足造成的大量 lock 等待。大概提两点优化措施提升 xxx.TYAComYB.DataReceived 方法中业务逻辑的处理能力。增加蓄水池让底层的 lock (serialStream) 尽快得到释放。END工作中的你是否已遇到 ... 1. CPU爆高2. 内存暴涨3. 资源泄漏4. 崩溃死锁5. 程序呆滞等紧急事件全公司都指望着你能解决...  危难时刻才能展现你的技术价值作为专注于.NET高级调试的技术博主欢迎微信搜索: 一线码农聊技术免费协助你分析Dump文件希望我能将你的踩坑经验分享给更多的人。
http://www.zqtcl.cn/news/213308/

相关文章:

  • 广州网站建设开发团队江苏省建设招标网站
  • 南昌建设工程质量监督网站wordpress菜单登录
  • 网站设计贵不贵网站seo设置是什么
  • 不属于企业网站建设基本标准的是南通网站建设知识
  • 玉树州wap网站建设公司做试玩网站
  • 商城网站怎么建保定网络营销网站建设
  • 检索类的网站建设公司的网站建设规划书
  • 百度做网站需要交钱吗保定网站建设平台分析
  • 张家界建设局网站电话优化关键词排名公司
  • 宁夏网站建设一条龙网站建设中的图片及视频要求
  • 某些网站dns解析失败湛江制作企业网站
  • 网站开发用什么代码长沙哪家公司做网站
  • 做视频找素材的网站有哪些wordpress 合法评论
  • php网站开发程序填空题高水平网站运营托管
  • 揭东建设局网站wordpress建站后发布
  • 济南哪里有建网站制作视频的手机软件
  • 建设教育网站的国内外研究现状沧州市宇通网站建设公司
  • 大型网站开发框架有哪些厦门外贸网页设计服务
  • 开网站空间流量怎么选择公司注册咨询电话
  • 邢台网站建设基本流程网站制作公司教你怎么制作网站
  • 苏州网站建设方案外包视频网站制作教程视频
  • 呼伦贝尔市规划建设局网站wordpress 主题切换
  • 建设网站的要求吗网站怎么建立
  • 网站结构有哪些建设局平台
  • 高端网站建设公司服务好吗有哪些制作网站的公司
  • 网站整站模板下载工具淮安网站建设案例
  • 网站前台用什么做广东省网站设计师
  • 汕头网站建设公司哪个好百度公司注册地址
  • 创建网站需要什么平台wordpress 卡盟模板
  • 网站开发常用的流程肃宁网站建设公司