网站开发培训深圳网站设计包括哪些内容

news/2025/10/8 4:31:04/文章来源:
网站开发培训深圳,网站设计包括哪些内容,天元建设集团有限公司一公司尤作岭,模板网站配置文件背景 性能诊断是软件工程师在日常工作中需要经常面对和解决的问题#xff0c;在用户体验至上的今天#xff0c;解决好应用的性能问题能带来非常大的收益。Java 作为最流行的编程语言之一#xff0c;其应用性能诊断一直受到业界广泛关注。可能造成 Java 应用出现性能问题的因…背景 性能诊断是软件工程师在日常工作中需要经常面对和解决的问题在用户体验至上的今天解决好应用的性能问题能带来非常大的收益。Java 作为最流行的编程语言之一其应用性能诊断一直受到业界广泛关注。可能造成 Java 应用出现性能问题的因素非常多例如线程控制、磁盘读写、数据库访问、网络I/O、垃圾收集等。想要了定位这些问题一款优秀的性能诊断工具必不可少。本文将介绍 Java 性能诊断过程中的常用工具并重点介绍其中的优秀代表 JProfiler 的基本原理和最佳实践本文所做的调研基于jprofiler10.1.4。 Java 性能诊断工具简介 在 Java 的世界里有许多诊断工具可供选择既包括像 jmap、jstat 这样的简单命令行工具又包括 JVisualvm、JProfiler 等图形化综合诊断工具同时还有 SkyWalking、ARMS 这样的针对分布式应用的性能监控系统。下面分别对其进行介绍。 简单命令行工具 JDK 内置了许多命令行工具它们可用来获取目标 JVM 不同方面、不同层次的信息。 jinfo - 用于实时查看和调整目标 JVM 的各项参数。jstack - 用于获取目标 Java 进程内的线程堆栈信息可用来检测死锁、定位死循环等。jmap - 用于获取目标 Java 进程的内存相关信息包括 Java 堆各区域的使用情况、堆中对象的统计信息、类加载信息等。jstat - 一款轻量级多功能监控工具可用于获取目标 Java 进程的类加载、JIT 编译、垃圾收集、内存使用等信息。jcmd - 相比 jstat 功能更为全面的工具可用于获取目标 Java 进程的性能统计、JFR、内存使用、垃圾收集、线程堆栈、JVM 运行时间等信息。 图形化综合诊断工具 使用上述命令行工具或组合能帮您获取目标 Java 应用性能相关的基础信息但它们存在下列局限 无法获取方法级别的分析数据如方法间的调用关系、各方法的调用次数和调用时间等这对定位应用性能瓶颈至关重要。要求用户登录到目标 Java 应用所在的宿主机上使用起来不是很方便。分析数据通过终端输出结果展示不够直观。 下面介绍几款图形化的综合性能诊断工具。 JVisualvm JVisualvm 是 JDK 内置的可视化性能诊断工具它通过 JMX、jstatd、Attach API 等方式获取目标 JVM 的分析数据包括 CPU 使用率、内存使用量、线程堆栈信息等。此外它还能直观地展示 Java 堆中各对象的数量和大小、各 Java 方法的调用次数和执行时间等。 JProfiler JProfiler 是由 ej-technologies 公司开发的一款 Java 应用性能诊断工具。它聚焦于四个重要主题上。 方法调用 - 对方法调用的分析可以帮助您了解应用程序正在做什么并找到提高其性能的方法。内存分配 - 通过分析堆上对象、引用链和垃圾收集能帮您修复内存泄漏问题优化内存使用。线程和锁 - JProfiler 提供多种针对线程和锁的分析视图助您发现多线程问题。高级子系统 - 许多性能问题都发生在更高的语义级别上。例如对于JDBC调用您可能希望找出执行最慢的 SQL 语句。JProfiler 支持对这些子系统进行集成分析。 分布式应用性能诊断 如果只需要诊断单机 Java 应用的性能瓶颈上面介绍的诊断工具就已经够用了。但随着现代系统架构逐渐从单体转变为分布式、微服务单纯使用上述工具往往无法满足需求这时就需要借助 Jaeger、ARMS、SkyWalking 这些分布式追踪系统提供的全链路追踪功能。分布式追踪系统种类繁多但实现原理都大同小异它们通过代码埋点的方式记录 tracing 信息通过 SDK 或 agent 将记录的数据传输至中央处理系统最后提供 query 接口对结果进行展示和分析想了解更多分布式追踪系统的原理可参考文章开放分布式追踪OpenTracing入门与 Jaeger 实现。 JProfiler 简介 核心组件 JProfiler 包含用于采集目标 JVM 分析数据的 JProfiler agent、用于可视化分析数据的 JProfiler UI、提供各种功能的命令行工具它们之间的关系如下图所示。 JProfiler agent JProfiler agent 是一个本地库它可以在 JVM 启动时通过参数-agentpath:path to native library进行加载或者在程序运行时通过 JVM Attach 机制进行加载。Agent 被成功加载后会设置 JVMTI 环境监听虚拟机产生的事件如类加载、线程创建等。例如当它监听到类加载事件后会给这些类注入用于执行度量操作的字节码。 JProfiler UI JProfiler UI 是一个可独立部署的组件它通过 socket 和 agent 建立连接。这意味着不论目标 JVM 运行在本地还是远端JProfiler UI 和 agent 间的通信机制都是一样的。 JProfiler UI 的主要功能是展示通过 agent 采集上来的分析数据此外还可以通过它控制 agent 的采集行为将快照保存至磁盘展示保存的快照。 命令行工具 JProfiler 提供了一系列命令行工具以实现不同的功能。 jpcontroller - 用于控制 agent 的采集行为。它通过 agent 注册的 JProfiler MBean 向 agent 传递命令。jpenable - 用于将 agent 加载到一个正在运行的 JVM 上。jpdump - 用于获取正在运行的 JVM 的堆快照。jpexport jpcompare - 用于从保存的快照中提取数据并创建 HTML 报告。 安装配置 JProfiler 同时支持诊断本地和远程 Java 应用的性能。如果您需要实时采集并展示远程 JVM 的分析数据需要完成以步骤 在本地安装 JProfiler UI。在远程宿主机上安装 JProfiler agent 并让其被目标 JVM 加载。配置 UI 到 agent 的连接。 具体步骤可参考文档 Installing JProfiler 和 Profiling A JVM。 最佳实践 本章将以高性能写 LogHub 类库 Aliyun LOG Java Producer 为原型带您了解如何使用 JProfiler 剖析它的性能。如果您的应用或者您在使用 producer 的过程中遇到了性能问题也可以用类似的方式定位问题根因。如果您还不了解 producer 的功能建议先阅读文章日志上云利器 - Aliyun LOG Java Producer。本章使用的样例代码参见 SamplePerformance.java。 JProfiler 设置 数据采集模式 JProfier 提供两种数据采集模式 Sampling 和 Instrumentation。 Sampling - 适合于不要求数据完全精确的场景。优点是对系统性能的影响较小缺点是某些特性不支持如方法级别的统计信息。Instrumentation - 完整功能模式统计信息也是精确的。缺点是如果需要分析的类比较多对应用性能影响较大。为了降低影响往往需要和 Filter 一起使用。 由于我们需要获取方法级别的统计信息这里选择了 Instrumentation 模式。同时配置了 Filter让 agent 只记录位于 Java 包com.aliyun.openservices.aliyun.log.producer下的类和类com.aliyun.openservices.log.Client的 CPU 分析数据。 应用启动模式 通过为 JProfiler agent 指定不同的参数可以控制应用的启动模式。 等待模式 - 只有在 Jprofiler GUI 和 agent 建立连接并完成分析配置设置后应用才会真正启动。在这种模式下您能够获取应用启动时期的分析数据。对应的命令为-agentpath:path to native libraryport8849。立即启动模式 - 应用会立即启动Jprofiler GUI 会在需要时和 agent 建立连接并设置分析配置。这种模式相对灵活但会丢失应用启动初期的分析数据。对应的命令为-agentpath:path to native libraryport8849,nowait。离线模式 - 通过触发器记录数据、保存快照供事后分析。对应的命令为-agentpath:path to native libraryoffline,idxxx,config/config.xml。 因为是在测试环境同时对应用启动初期的性能也比较关注这里选择了默认的等待模式。 使用 JProfiler 诊断性能 在完成 JProfiler 的设置后便可以对 Producer 的性能进行诊断。 Overview 在概览页我们可以清晰的看到内存使用量、垃圾收集活动、类加载数量、线程个数和状态、CPU 使用率等指标随时间变化的趋势。 通过此图我们可以作出如下基本判断 程序在运行过程中会产生大量对象但这些对象生命周期极短大部分都能被垃圾收集器及时回收不会造成内存无限增长。加载类的数量在程序初始时增长较快随后保持平稳符合预期。在程序运行过程中有大量线程处于阻塞状态需要重点关注。在程序刚启动时CPU 使用率较高需要进一步探究其原因。 CPU views CPU views 下的各个子视图展示了应用中各方法的执行次数、执行时间、调用关系等信息能帮我们定位对应用性能影响最大的方法。 Call Tree Call tree 通过树形图清晰地展现了方法间的层次调用关系。同时JProfiler 将子方法按照它们的执行总时间由大到小排序这能让您快速定位关键方法。 对于 Producer 而言方法SendProducerBatchTask.run()耗时最多继续向下查看会发现该方法的主要时间消耗在了执行方法Client.PutLogs()上。 Hot Spots 如果您的应用方法很多且很多子方法的执行时间比较接近使用 hot spots 视图往往能助您更快地定位问题。该视图能根据方法的单独执行时间、总执行时间、平均执行时间、调用次数等属性对它们排序。其中单独执行时间等于该方法的总执行时间减去所有子方法的总执行时间。 在该视图下可以看到Client.PutLogs()LogGroup.toByteArray()SamplePerformance$1.run()是单独执行时间耗时最多的三个方法。 Call Graph 找到了关键方法后call graph 视图能为您呈现与该方法直接关联的所有方法。这有助于我们对症下药制定合适的性能优化策略。 这里我们观察到方法Client.PutLogs()执行的主要时间花费在了对象序列化上因此性能优化的关键是提供执行效率更高的序列化方法。 Live memory Live memory 下的各个子视图能让您掌握内存的具体分配和使用情况助您判断是否存在内存泄漏问题。 All Objects All Objects 视图展示了当前堆中各种对象的数量和总大小。由图可知程序在运行过程中构造出了大量 LogContent 对象。 Allocation Call Tree Allocation Call Tree 以树形图的形式展示了各方法分配的内存大小。可以看到SamplePerformance$1.run()和SendProducerBatchTask.run()是内存分配大户。 Allocation Hot Spots 如果方法比较多您还可以通过 Allocation Hot Spots 视图快速找出分配对象最多的方法。 Thread History 线程历史记录视图直观地展示了各线程在不同时间点的状态。 不同线程执行的任务不同所展现的状态特征也不同。 线程pool-1-thread-M会循环调用producer.send()方法异步发送数据它们在程序刚启动时一直处于运行状态但随后在大部分时间里处于阻塞状态。这是因为 producer 发送数据的速率低于数据的产生速率且单个 producer 实例能缓存的数据大小有限。在程序运行初始producer 有足够空间缓存待发送数据所以pool-1-thread-M一直处于运行状态这也就解释了为何程序在刚启动时 CPU 使用率较高。随着时间的推移producer 的缓存被逐渐耗尽pool-1-thread-M必须等到 producer “释放”出足够的空间才有机会继续运行这也是为什么我们会观察到大量线程处于阻塞状态。aliyun-log-producer-0-mover负责将超时 batch 投递到发送线程池中。由于发送速率较快batch 会因缓存的数据达到了上限被pool-1-thread-M直接投递到发送线程池中因此 mover 线程在大部分时间里都处于等待状态。aliyun-log-producer-0-io-thread-N作为真正执行数据发送任务的线程有一部分时间花在了网络 I/O 状态。aliyun-log-producer-0-success-batch-handler用于处理发送成功的 batch。由于回调函数比较简单执行时间短它在大部分时间里都处于等待状态。aliyun-log-producer-0-failure-batch-handler用于处理发送失败的 batch。由于没有数据发送失败它一直处于等待状态。 通过上述分析可知这些线程的状态特征都是符合预期的。 Overhead Hot Spots Detected 当程序运行结束后JProfiler 会弹出一个对话框展示那些频繁被调用但执行时间又很短的方法。在下次诊断时您可以让 JProfiler agent 在分析过程中忽略掉这些方法以减轻对应用性能的影响。 小结 通过 JProfiler 的诊断可知应用不存在大的性能问题也不存在内存泄漏。下一步的优化方向是提升对象的序列化效率。 原文链接 本文为云栖社区原创内容未经允许不得转载。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/931099.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

北京移动端网站设计二建证书查询官网入口

编写equals()和hashCode()方法需要遵循以下原则: 1. equals()方法: - 使用instanceof关键字检查传入的对象是否为当前类的实例。 - 检查传入的对象是否为null。 - 检查传入的对象的类型是否与当前对象的类型相同。 - 比较对象的属性是否相等&#x…

电子商务网站建设 项目规划书网站优化种类

目录 一.虚拟机准备 二.基础环境配置(各个节点都做) 1.IP和hosts解析 2.防火墙和selinux 3.安装基本软件 4.配置时间同步 5.禁用swap分区 6.修改内核参数并重载 7.配置ipvs 三.docker环境(各个节点都做) 1.配置软件源并…

做资源网站怎么不封网架加工制造厂家

问题陈述: Fibonacci为1200年代的欧洲数学家,在他的著作中曾经提到:若有一只兔子每个月生一只小兔子,一个月后小兔子也开始生产。起始只有一只兔子,一个月后就有两只兔子,二个月后有三只兔子,三…

个人简介网站html代码深圳社保个人网页

三种情形: 1.执行SP时出错,如连接异常,数据库权限异常 2.SP代码中抛出异常 3.返回值/输出参数的值不符合约定 后两种情形需要在异常发生时记录传入SP的参数值;业务逻辑层需要捕获并重抛,以保证UI层提供给用户友好的错误…

网站建设与管理专业实训室辽宁建设工程信息网招标公呿

1、用定积分奇函数和偶函数的性质 2、用常用的基本不等式推出大小 3、用区间相同的情况下被积函数大的定积分大的定理

无锡那家网络公司做网站好深圳网站建设工作

C语言知识点第1章C语言知识点总结(二) 第八节 字符字符常量定义:一对单引号括起来的一个字符。如‘A’、‘a’、‘9’相应字符对应的ASCII编码值(见附录四)字符常量占用一个字节的存储单元(一个字节占8位)重点:表 C语言中常见的转义字符字符形式意义字符…

怎样让网站做301处理为什么访问外国网站速度慢

本文仅供学习使用,总结很多本现有讲述运动学或动力学书籍后的总结,从矢量的角度进行分析,方法比较传统,但更易理解,并且现有的看似抽象方法,两者本质上并无不同。 2024年底本人学位论文发表后方可摘抄 若有…

白箱算力与AI元人文:一场从“求解”到“创造”的范式革命

白箱算力与AI元人文:一场从“求解”到“创造”的范式革命 我们正站在智能演进的历史断层上。一侧,是算力规模指数级增长的“黑箱”帝国,它以其惊人的效率令我们叹服,却又因其决策的不可知性让我们深感不安;另一侧…

app开发网站建设公司哪家好海阳网站制作

322. 零钱兑换 题目: 给一个不同数额硬币的数组和一个目标金额,硬币可取无限次,求用硬币达到总金额的最小硬币数量。(求不同组合数/排列数,但是硬币数量最小) 思路: 求硬币数量最小&#x…

重庆企业网站制作外包微信官方微网站吗

页面渲染的全过程输入url后,先拿到html文件,html下载完以后会开始对它进行解析html在解析的过程中,如果文本里有外部资源链接,比如css、js和img时,会立即启用其他线程下载这些静态资源。特殊的是当遇到js文件的时候&am…

正规网站建设的公司香精香料网

1. 独立看门狗IWDG介绍(341.45) 什么是看门狗? 在由单片机构成的微型计算机系统中,由于单片机的工作常常会受到来自外界电磁场的干扰,造成程序的跑飞,而陷入死循环,程序的正常运行被打断&#…

做IT的需要别人打开网站吗文化传播有限公司注册条件

来记录一下做一个springboot项目以及上传至云服务器上过程新建并发布项目注册域名:域名备案发现的问题:在阿里云上面搞了一台个人服务器,当时是双十一打折买的,229好像。有了服务器当然要干点什么,于是做了个springboo…

商城微网站开发微网站wordpress 换域名 403

互联网给人带来便捷的同时,其公开大量的资源也同样给恶意利用者带了便捷,越来越多公开的恶意程序源码降低了对外攻击、入侵的难度,使得安全问题愈加严重。 阿里云安全团队从今年5月份监测到一BOT家族,其样本改写自互联网公开渠道…

如何查看网站使用什么程序做的建设网站需要备案

ORA-30926: 无法在源表中获得一组稳定的行 同时要求在一张表中添加一个字段,由于数据量较大,想使用merge into update的方式将数据 meger into xxx1 t1 using(select * from xxx2 )t2 on(t1.xmt2.xm and t1.dzt2.dz) when matched then update set tra…

vm ubuntu22安装docker

我是mac m1芯片环境,安装了vmware,我在vmware中安装好了ubuntu22.04.3,下一步如何安装docker? 1、安装sshsudo apt updatesudo apt install -y openssh-serversudo systemctl enable sshsudo systemctl start ssh …

浙江杰立建设集团网站会宁网站建设公司

1. 题目 一个机器人位于一个m*n的网格的左上角。 机器人可以在任何时间点移动任何方向,但是每个网格只能达到一次。机器人正试图到达网格的右下角。 有多少种可能的独特路径? 样例 1: 输入: 2 3 输出: 4样例 2: 输入: 3 3 输出: 122. 解题 暴力回溯即可 class …

php电商网站开发流程图网站设计建设方案

文章目录从框架源码学习结构型设计模式适配器模式应用实例案例一:dubbo框架日志适配器Logger接口日志实现类Logger适配器接口LoggerAdapter实现类Logger日志工厂桥接模式应用场景案例:dubbo源码-远程调用模块channelHandler设计ChannelHandler是一个SPI拓…

网站建设方案 pptdedecms做手机网站

React拆分窗格的两种方法 react-split-pane 使用第三方库react-split-pane的优点: 方便快捷:使用现有的第三方库可以快速实现拆分窗格功能,无需自己编写复杂的逻辑。 功能丰富:第三方库通常提供了许多可配置的选项和功能&…

建一个漫画网站江苏景禾瑜博建设工程有限公司网站

什么是clustering? 聚类算法查看多个数据点,并自动找到彼此相关或相似的数据点。 K-means clustering 示例 循环:再次分配每个点到离它最近的质心,重新计算质心。 K-means algorithm 注意: k-means的初始化质心Mu有…