性能优化解决方案1OneAPM能做什么2OneAPM的实现原理3OneAPM与其他厂商的对比4典型客户案例最易用的JVM工具,串联事务性能、JVM和SQL语句的运行状态OneAPM致力于为互联网平台和大型IT系统服务:实时监控每条登录、订单等关键事务的响应时间及时或前瞻性地提供应用系统性能优化决策依据OneAPM能做什么?立即抓取运行慢的SQL语句和代码程序,快速定位造成交互缓慢和失败的程序问题Web事务分析针对慢的事务,查看其traces分析信息,通过分析相关类、方法甚至关联SQL语句的执行时间,快速定位问题关键点。JVM监控针对使用Java语言开发的应用系统,JVM监控功能可以监测所有JVM的运行情况。针对运行较差的JVM,尽早优化确保业务运行顺畅;当JVM出现异常时,OneAPM会发出报警,通知运维人员,及时修正问题,保证业务的正常运行。A.class12345891、2、3:classLoader将A.class装载入JVM,期间调用javaagent在A.class的字节码中嵌入监控代码后,生成A’.class;4、5、6、7:当Request请求需调用A.class,Engine会找到并执行A’.class,A’.class执行A.class正常的业务逻辑,返回Response;8:A’.class执行结束,Engine会将监控Data写入监控数据暂存区;9,10,11:每隔60s,Agent线程向OneAPM发送数据,并清理暂存区RequestResponseJVM6107Java字节码探针实现原理ClassLoaderEngineAgentA’.classjavaagent监控数据暂存区运行时数据区11OneAPMNewRelicAppDynamics安装难易非常简单,每个收集结点只需要部署一个探针非常简单,与OneAPM一样,一个节点一个探针简单,有时一个收集节点既要部署结点也要安装代理使用难易使用方便使用方便界面不易用使用方式SaaSSaaSSaasOn-premisesOn-premises价格策略SaaS模式:每月每主机收取¥699,敬请关注“风口计划”*针对线下售卖模式的价格,请咨询oneapmBD部门。价格昂贵,SaaS模式:每月*每主机收取$149=¥912价格昂贵,线下售卖模式,需商议决定网络稳定性国内机房,网络稳定国外机房,容易被墙国外机房,容易被墙注:OneAPM是国内唯一的应用性能提供商,只有与国外厂商对比情况OneAPM,NewRelic及AppDynamics比较OneAPM,NewRelic及AppDynamics比较风口计划为帮助创业者和个人开发者能以更低的成本使用OneAPM,我们推出了”风口计划”的打包优惠策略如下表:主机数价格1每月¥92~3每月¥3994~6每月¥6996每月每主机¥699注:上表价格为打包价,只要主机数在有限个数之内,只收取打包优惠价。以2~3为例,如果用户只有2或3台主机,每月只需支付¥399元,相当于每主机价格为¥399/3或¥399/2“风口计划”只适用于SaaS模式,线下售卖模式不执行该价格策略OneAPMNewRelicAppDynamics支持程序语言Java.NETNode.jsPythonRubyPHP事务追踪WebNon-webSQL移动端支持AndroidiOS代码级监控支持服务支持邮件,电话及企业级的现场支持邮件,无中国本地化支持邮件,无中国本地化支持语言中文支持注:OneAPM是国内唯一的应用性能提供商,只有与国外厂商对比情况OneAPM,NewRelic及AppDynamics比较客户案例一观察从四个维度观察IT应用系统的整体运行情况,四个维度分别为:Web事务、数据库、外部调用及其他事务1,为保证系统正常平稳运行,希望实时了解系统整体的运行状况2,当出现明显缓慢或异常业务时,能有工具立即发现,并马上定位到问题3,对JVM的监控需要,借助图形化的展示工具,得知JVM的运行情况为什么使用OneAPM怎么使用OneAPM左图是Web事务的整体运行情况,出现的两次峰值必须予以重视观察web事务的整体运行情况事务详情,在问题时间段内,Web事务的响应时间和吞吐量。Traces记录,上图是问题时间段内的traces记录,列出来所有Web事务的执行时间。客户案例一右图是数据库操作语句的整体执行情况,出现的一次峰值延时,必须立即修复。慢SQL,该时间段内的慢SQL列表。SQL分析,该时间段内的所有SQL列表,用折线图统计执行较慢的、前5条SQL语句的平均执行时间,以及各种SQL操作的吞吐量和响应时间。观察数据库的整体运行情况客户案例一左图是Web事务涉及的API的响应情况,及时防范API的风险。外部服务,左侧是该时间段内调用的所有API,同时对API的响应时间和吞吐量进行统计。观察外部服务的整体运行情况客户案例一最准确、全面、直观的JVM监控工具客户案例一1,通过总览页的四大指标的统计,让我对系统运行情况有了初步了解2,逐个排查问题,当发现有尖端峰值时,从各个指标的分图表中,观察异常出现的时间段,缩小排查范围3,深入分析,快速定位,对Web事务、数据库和外部调用进行深入分析,逐步找出拖慢性能的具体业务和时间,如Web事务的URL、发生时间和执行时间。4,借助JVM监控,及时发现JVM存在的隐患,立即作出优化,规避风险OneAPM的效果客户案例二1,找出缓慢事务后,因为业务逻辑非常复杂,无法快速定位问题点2,发现慢SQL后,无法定位其关联事务3,出现慢事务和慢SQL后,无法及时报警为什么使用OneAPM怎么使用OneAPM1,发现了一个总耗时46,375ms的慢事务,如何排查问题客户案例二跟踪方法的执行轨迹,还没有发现问题!至此发现,两个非常耗时数据库操作语句,问题找出!!!客户案例二2,发现了一个总耗时4.14s的慢SQL,如何找出调用该SQL语句的事务从上图看出,该SQL相关的多个事务都一一列出,并记录下执行较缓慢的SQL语句通过对慢SQL的进一步分析,找到了调用的该SQL语句的方法是getNewMessageAlert,需要回到getNewMessageAlert对其SQL调用进行优化客户案例二报警提醒页面,当问题发生时,及时发送告警信息,通知相关人员及时修复1,慢事务和慢SQL的报警服务,通过短信、邮件等方式,提醒运维人员,立刻对问题作出反应,保证系统正常运行2,慢事务和慢SQL的快速定位问题功能,辅助开发人员排查问题,定位问题,极大减轻工作量,提高工作效率OneAPM的效果客户案例二CNT系统(CNT是用于记录跳转计数的系统)运行一直很慢,经常接到用户的很多投诉。花了很长时间做过排查,也找不到问题。希望借助OneAPM对应用系统进行监控、分析,帮助我们快速定位问题点。使用目标客户案例三为什么使用OneAPM1,发现执行缓慢的事务2,查看缓慢事务的traces分析,初步定位到拖慢事务执行的类和方法怎么使用OneAPM客户案例三3,对该事务做线程剖析,确定是哪一行代码拖慢了事务的执行。从中发现是一个DNS解析函数getAllByName0占用了事务99.99%的执行时间。经过进一步分析发现,getAllByName0方法在一直等待DNS返回结果,最后定位到是DNS解析出的问题,导致业务系统缓慢。更新DNS服务器后,应用系统运行流畅,性能提升。OneAPM的效果客户案例三OneAPM能够帮助您优化应用性能,提升用户体验联系我们技术咨询:400-622-3101销售咨询:400-659-1230联系电话:010-82156267邮箱:support@oneapm.comOneAPM微信公众号