在本文中,我们将为您详细介绍化妆品监管app怎么用化妆品监管app怎么查看化妆品备案信息的相关知识,并且为您解答关于化妆品监管怎么查询的疑问,此外,我们还会提供一些关于.NETwebapi某化妆品直播
在本文中,我们将为您详细介绍化妆品监管app怎么用 化妆品监管app怎么查看化妆品备案信息的相关知识,并且为您解答关于化妆品监管怎么查询的疑问,此外,我们还会提供一些关于.NET webapi某化妆品直播卡死分析、2023化妆品大会在杭州举行,杨建允:美妆品牌要做好四个方面、360:2015年Q2化妆品行业研究报告、clinique是什么牌子的化妆品的有用信息。
本文目录一览:- 化妆品监管app怎么用 化妆品监管app怎么查看化妆品备案信息(化妆品监管怎么查询)
- .NET webapi某化妆品直播卡死分析
- 2023化妆品大会在杭州举行,杨建允:美妆品牌要做好四个方面
- 360:2015年Q2化妆品行业研究报告
- clinique是什么牌子的化妆品
化妆品监管app怎么用 化妆品监管app怎么查看化妆品备案信息(化妆品监管怎么查询)
化妆品监管APP是国家药监局推出的官方APP,用户可以通过化妆品监管APP来查询化妆品详细信息,具有化妆品数据查询、专题科普、投诉举报等多种功能。帮你一键鉴别化妆品真伪。
很多朋友都会通过网络购买化妆品,网购如果不得其道的话,是比较容易买到伪劣化妆品的。有了这款化妆品监管APP,买到的化妆品知否靠谱就一目了然了!一起来看看它的体验如何吧。
化妆品监管APP的使用并不复杂,开启后,即可进入主界面,通过各个模块来查找产品信息。例如,你可以直接在搜索框键入产品名称查找化妆品,也可以通过“搜产品”栏目当中的列表寻找相应的产品。
化妆品监管APP主界面,可以搜索产品信息
找到相应的化妆品后,点击即可查看相应信息,包括生产国、生产企业、相应地址、批号等等。
而通过产品详情页下方的按钮,还能够查看历次化妆品抽检的信息,也可以举报相应产品,功能还是非常齐全的。
国内正规贩售的产品都能搜到信息,如果找不到,那就要小心了
想要在化妆品监管APP中,也可以直接扫描产品条码查询化妆品信息。点击“扫一扫”,就可以利用手机摄像头扫描产品条码,识别还是非常快捷的。
比这里尝试了扫描商店里的商品,识别迅速且准确,如果你担心在实体店买到假货,这个化妆品监管APP可以让你打消疑虑。
也可以扫码辨真伪
在化妆品监管APP中,还能够查看到其他信息,例如划转配股行政许可检验机构等等,不愧是药监局出品的APP,足够权威。
查询各类信息
总的来说,这款化妆品监管APP的确实用性十足,有了它各位小仙女可以大大减少被不良奸商蒙骗的概率。
当然,这款化妆品监管APP能查询的也仅限于国内有备案的化妆品,如果海淘或者出国买买买的话,它可能会无能为力,大家还是多长个心眼吧,贪便宜一时爽,烂脸就很可怕了!
.NET webapi某化妆品直播卡死分析
一:背景
1. 讲故事
10月份星球里的一位老朋友找到我,说他们公司的程序在一个网红直播带货下给弄得无响应了,无响应期间有大量的 RabbitMQ 超时,寻求如何找到根源,聊天截图我就不发了。
既然无响应了,那必然是程序的大量线程被主动或者被动的挂起,朋友也很及时的从程序上抽了一管血下来,接下来就上 windbg 一起探究下到底发生了什么?
二:Windbg 分析
1. 线程们都怎么了
要想看所有线程,还是老命令 !t 。
0:000> !t ThreadCount: 5221 UnstartedThread: 0 BackgroundThread: 5199 PendingThread: 0 DeadThread: 21 Hosted Runtime: no Lock DBG ID OSID ThreadOBJ State GC Mode GC Alloc Context Domain Count Apt Exception 20 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 00000279ccc56cd0 9 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.IOptions`1<xxx.RabbitMq.RabbitMqConfig>, Microsoft.Extensions.Logging.ILogger`1<System.Object>) 0000008B8A9ED860 00007ffd84a6a317 xxx.RabbitMq.RabbitMqProducer..ctor(Microsoft.Extensions.Options.IOptionsSnapshot`1<xxx.RabbitMq.RabbitMqConfig>, Microsoft.Extensions.Logging.ILogger`1<xxx.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.ControllerFactoryProvider+c__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(IOptions<RabbitMqConfig> options, ILogger<dynamic> 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, ILogger<dynamic> logger) { Policy.Handle<SocketException>().Or<BrokerUnreachableException>().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 查看源码发现它是用 CloseReason==null 来判断的。
接下来看看 CloseReason 不为空即可。
0:000> !dumpheap -type RabbitMqConnection Address 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 _delegate 0: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 _closeReason 0: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 <Connection>k__BackingField 00007ffd831f1570 400001d 8 ...abbitMqConnection 0 static 00000277cbd7aa68 _uniqueInstance 00007ffd82390c68 400001e 10 System.Object 0 static 00000277cbd7aa50 _objLock
从输出信息中可以很清楚的看到当前托管堆有两个 RabbitMqConnection 对象,其中一个果然是失败了(_closeReason=00000279ccc56e28),还有一个正在努力的new <Connection>k__BackingField=0000000000000000, 这也就验证了假设。
4. 后续
有了这些信息,和朋友做了下沟通,建议再优化一下 IsOpen=false 时的异常处理逻辑,比如 return 或者 throw new,或者干脆不要用懒检测, 千万不要硬着来。
至于造成 RabbitMQ 不响应的一系列诱因,朋友通过参考的开源项目,发现将别人的 AddSingleton 改成了 AddScoped。
这也就造成了每一次Http请求都要试探性的判断单例逻辑, 别人的解法是一旦上层单例化了,下层就不会再次处理了,也就不会走 IsOpen 逻辑。
三:总结
造成本次程序卡死的事故,主要有两点:
- RabbitMQ 生成单例化中的 IsOpen 判断问题,建议改用自动重连属性 AutomaticRecoveryEnabled 和 TopologyRecoveryEnabled,或者用静态构造函数替代双检锁。
- 过多的 http 请求对单例逻辑的试探,按照朋友的改发将 Scoped 改成 Singleton 来规避。
以上就是.NET webapi化妆品直播卡死分析的详细内容,更多关于.NET webapi直播卡死的资料请关注其它相关文章!
- .NET CPU爆高事故事故分析某供应链WEB网站
- .NetCore使用过滤器实现登录权限认证的方法小结
- .NET内存泄漏分析Windbg项目实例
- 一篇文章教你如何排查.NET内存泄漏
- .NET某消防物联网后台服务内存泄漏分析
2023化妆品大会在杭州举行,杨建允:美妆品牌要做好四个方面
2月22日,2023(第一届)中国化妆品科学家大会、2023CiE美妆创新展在杭州国际博览中心举行,掀起了中国化妆品产业科技创新的高潮。
11位科学家、产研界资深人士,围绕各自擅长的研究领域,进行了深度分享,化妆品行业学研界、产业界的智慧之花,在这场会议上绚烂绽放。
在CiE美妆创新展区,提供了6万㎡的展区面积,共计有800多家优质展商和3万多的各类美妆界人士深度参与。
同时,展会还准备了20多场特备活动,共计有超过100位美妆红人和100位行业大咖围绕市场趋势、研发创新、新品开发、营销推广、渠道增长等方面进行精彩分享。
内容涵盖C店、直播MCN、KOL、自媒体电商、社群(电商)团购、时尚百货、新零售、线下代理、连锁店、商超便利等方面。
4大专业论坛:围绕数据趋势、营销创新、渠道增长、原料创新进行讨论。
4大电商营销分享会:由京东美妆、拼多多、蝉妈妈、魔马会进行重点分享。
4大MCN营销分享会:由快美全域、缇苏、宸帆、初新文化进行干货分享。
新品发布会:多家美妆企业进行了多款新品的发布。
在营销创新论坛,各大平台和服务机构、行业营销大咖纷纷登台献技,结合产品营销案例,从多个层面,对“全域营销”的经营方法论进行了着重论述,是一场广大美妆从业者的高端盛宴。
互联网营销专家杨建允认为,不确定性中的确定性是坚持长期主义。在新的竞争和营销趋势下,品牌应该做好以下四个方面:
一,做一家有技术含量的企业。
不管是做研发生产还是产品营销,都要有技术含量。技术含量就是核心的产品力和竞争力。
营销和科技是行业有力的两大驱动力。
现在的市场竞争,比拼的是产品力。产品、营销、运营都要有科技含量、有技术含量。
杨建允提醒,营销类企业和品牌要能进行公私域的结合运营,打造自己的护城河。
二,清晰可感的产品价值。
企业和品牌做产品、做营销,不能只懂得讲故事,要能将用户带入其中,实现“感同身受”,以内容为基础,让用户与信息产生共鸣感和认同感,从而深化品牌价值。
品牌应该有内涵、价值、故事。
杨建允认为,企业做产品要能做到在某类人群中是刚需,高复购,依赖性比较强;
三,长期主义的运营服务。
专注、聚焦。加强私域运营能力,一个品牌只想依靠广告投流来获取用户,这种品牌在市场竞争中是没有任何优势的;
杨建允提出,存量用户的精细化运营和服务是确保竞争胜出的关键。
四,完备的体系化团队。
企业和品牌经营,特别是互联网营销布局需要一个完备的体系化团队精诚协作,企业要能不断地引入新的优秀的人才,保证企业有足够的内升力。
杨建允提醒,关注自身技术积累、品牌价值、产品价值、用户价值和运营技术的企业,才能更好地抵挡市场竞争,才能在发展中行稳致远。
360:2015年Q2化妆品行业研究报告
clinique是什么牌子的化妆品
clinique 是一家护肤和彩妆品牌,由皮肤科医生和化妆品编辑于 1968 年创建,以无香料、不过敏且有效的产品闻名。该品牌以“皮肤护理首先”的理念,提供全系列护肤和彩妆产品,标志性产品是其三步护肤系统,适合各种肤质。clinique 定位中高端,拥有广泛的全球客户群。
Clinique 是一家备受推崇的护肤和彩妆品牌,以其无香料、不过敏和经过皮肤科医生测试的产品而闻名。
品牌历史
Clinique 于 1968 年由皮肤科医生 Norman Orentreich 博士和化妆品编辑 Carol Phillips 创立。他们的目标是创造一种对敏感肌肤温和且有效的护肤系列。
品牌理念
Clinique 的核心理念是“皮肤护理首先”。他们的产品专为解决各种皮肤问题而设计,例如干燥、油腻、敏感和痤疮。他们相信健康的皮肤是美丽肌肤的基础,因此他们的产品不含刺激性成分。
产品系列
Clinique 提供全系列护肤和彩妆产品,包括:
- 护肤品:洁面乳、保湿霜、精华液、面膜
- 彩妆:粉底、遮瑕膏、眼影、口红
- 身体护理:沐浴露、身体乳、防晒霜
标志性产品
Clinique 最著名的产品之一是其 3 步护肤系统,包括洁面乳、爽肤水和保湿霜。该系统以其温和有效而著称,适合所有肤质。
品牌定位
Clinique 被定位为一个中高端护肤和彩妆品牌,其产品价格适中。该品牌在全球拥有广泛的客户群,包括皮肤科医生和美容爱好者。
以上就是clinique是什么牌子的化妆品的详细内容,更多请关注php中文网其它相关文章!
今天关于化妆品监管app怎么用 化妆品监管app怎么查看化妆品备案信息和化妆品监管怎么查询的分享就到这里,希望大家有所收获,若想了解更多关于.NET webapi某化妆品直播卡死分析、2023化妆品大会在杭州举行,杨建允:美妆品牌要做好四个方面、360:2015年Q2化妆品行业研究报告、clinique是什么牌子的化妆品等相关知识,可以在本站进行查询。
本文标签: