- 浏览: 142512 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (152)
- 资讯 (53)
- 随笔 (11)
- 学习 (10)
- 算法 (6)
- 模式 (4)
- 性能 (2)
- 源码 (1)
- java (15)
- jquery (0)
- linux (10)
- html5 (1)
- jboss (4)
- struts (2)
- NA (1)
- jbpm (1)
- oracle (4)
- eclipse (1)
- play (6)
- ios (1)
- Objective-C (1)
- mysql (1)
- nosql (1)
- redis (4)
- 总结 (4)
- 面试 (4)
- vue (1)
- Mac (1)
- 原型设计 (1)
- sharding-jdbc (0)
- shardingsphere (1)
- shardingjdbc (1)
- zookeeper (1)
- kafka (2)
- 腾讯云 (1)
- Docker (1)
最新评论
-
szh_java:
问楼主一个问题,我在ejb中使用了log4j,用weblogi ...
JBoss EJB应用程序迁移到WebLogic上 -
429537044:
多谢楼主分享
eclipse + jbpm5 + jboss的集成配置 -
qingling600:
现在这个JS 怎么不能下载啊。。。
12306辅助js 实现自动登录 自动查票 自动订单 -
dx1234xd:
搞错了吧,怎么从时间比直接比出速度比了?忽略路程不算?
IQ题 -
woshifeixiaochuan:
很不错,学习了,谢谢
html5-canvas
构建高性能的J2EE应用不但需要了解常用的实施技巧。下面介绍最常用的10种有效方法,可帮助架构设计师们快速成为这方面的专家。
Java性能的基础—内存管理
任何Java应用,单机的或J2EE的性能基础都可归结到你的应用是如何管理内存的问题。Java的内存管理包括两个重要任务:内存的分配和内存的 回收。在内存的分配中,目标是要减少需要创建的对象。
内存回收是导致性能下降的普遍原因。也就是说,内存中的对象越多,垃圾回收越困难。所以我们对创建对象的态度应该越保守越好。
在J2EE应用中常见的两个内存有关的问题是:游离的对象(也被称为内存泄露)和对象循环(指大量频繁创建和删除-在Java中体现为解除引用—对 象)。
我们应注意确保所有可到达的对象实际是活的,即这些对象不但在内存中,而且也要在执行的代码中是存在的。当对象在应用中已经没有用了,而我们却忘记 了删除对该对象的引用时,游离的对象就出现了。
我们知道垃圾回收会占用CPU时间。短期对象的大量创建增加了垃圾回收的频率会造成性能下降。
不要在Servlet中实现业务逻辑
在构建J2EE应用时,架构工程师通常会使用到J2EE的基本部分——Servlet。如果架构师不使用Session Beans, Entity Beans, 或 Message Beans, 那么改进性能的方法就很少。只能采用增加CPU或更多的物理服务器等方法。EJB使用了缓存(cache)和资源池等方法可以提高性能和扩展性。
尽可能使用本地接口访问EJB
在早期的J2EE (遵循EJB1.X规范)应用中,访问EJB是`通过RMI使用远程接口实现的。随着EJB2.0的出现,可以通过本地接口访问EJB,不再使用RMI, 在同一个JVM中使用远程方法已经少多了。但是现在还是有一些使用EJB1.X实现的应用和不知道使用本地接口的一些EJB新手。为说明这点,我们作个比 较:
1、客户端应用调用本地Stub
2、该Stub装配参数
3、该Stub传到skeleton
4、该skeleton分解参数
5、该skeleton调用EJB对象
6、EJB对象执行容器服务
7、EJB对象调用企业BEAN实例
8、企业BEA执行操作
9、执行组装/分解步骤然后返回
与远程接口处理相比较,本地接口的EJB方法是:
1、客户端调用本地对象
2、本地对象执行容器服务
3、本地对象调用企业Bean实例
4、企业Bean实例执行操作
5、没有其他返回步骤!
如果你不需要从远程的客户端访问一个特殊EJB,就应该使用本地方法。
在实现Session Bean的服务中封装对实体EJB的访问
从Servlet访问实体EJB不但效率低而且难于维护。使用Session Facade(会话外观)模式可把对实体EJB的访问封装在会话EJB中,在该会话EJB中通过使用本地接口访问实体EJB而避免过多的远程调用。
这项技术会有额外的性能和扩展方面的好处,这是因为会话和实体EJB可以使用缓存和资源池技术来进行改进。另外,由于负载的需要,会话和实体EJB 可被扩展部署到其他硬件设备上,这比将Servlet层复制扩展到其他硬件设备上要简单的多。
尽量粗粒度访问远程EJB
当访问远程EJB时,调用set/get方法将产生过多的网络请求,同时也导致远程接口处理的过载。为避免这种情况,可考虑将数据属性集中在一个对 象中,这样通过一次对远程EJB的调用就可以传递所有数据。这项技术就是数据传输对象(Data Transfer Object)模式。
优化SQL
J2EE 的架构设计工程师和开发人员通常不是SQL专家或经验丰富的数据库管理员。首先应该确保SQL使用了数据库提供的索引支持。在某些情况下,将数据库的索引 和数据分开存放会提高性能。但要知道,增加额外的索引可以提高SELECT性能但也会降低INSERT的性能。对于某些数据库,关联表之间的排序会严重影 响性能。可以多向数据库管理员咨询。
避免在实体EJB中过多执行SQL
有时候,通过实体EJB访问数据会执行多个SQL语句。根据J2EE 规范,第一步,将调用实体Bean的find(发现)方法;第二步,在第一次调用实体EJB的业务方法时,容器会调用ejbLoad()从数据库中获得信 息。
很多CMP(容器管理持久性)在调用发现方法时就缓存了实体数据,所以在调用ejbLoad()时就不再访问数据库了。应该避免使用 BMP(Bean管理的持久性)或者自己实现缓存算法避免二次访问数据库。
使用Fast Lane Reader 模式访问只读数据
J2EE 应用经常要以只读方式访问大量长时间不变的数据,而不是访问单个实体,例如浏览在线产品目录。在这种只读情况下,使用实体EJB访问数据会导致严重过载并 且实现很麻烦。实体EJB 适合于对单个实体的粗粒度访问,访问大量的列表只读数据时效率不高。不管是使用CMP还是BMP,一定需要编写代码操作多个实体EJB及其关联。这将导致 访问多个数据库并存在大量的也是不必要的事务开销。
利用Java Messaging Servce(消息服务)
J2EE规范在JMS中提供了内置的异步处理服务。当涉及到系统需求时,应该了解在什么情况下应该采用JMS进行异步处理的设计。一旦确定要执行一 些异步处理,那么同步处理的任务就应该越少越好,将数据库密集的操作安排在稍后的异步处理中完成。
缓存JNDI Lookup查找
很多操作在进行JNDI查找时要消耗大量资源。通常应该缓存JNDI资源避免网络调用和某些处理的过载。可以缓存的JNDI查找包括:
EJB Home Interfaces
Data Sources
JMS Connection Factories
MS Destinations/Topics
一些JNDI包实现了缓存功能。但是调用对EJB主接口的narrow方法时,这种功能作用有限。缓存查找的设计应该使用共享的 IntialContext 实例,尽管构建它很麻烦。这是因为需要访问多种数据源,包括应用资源文件JNDI.properties,系统属性的各项参数,传入到构造函数的各项参数。
发表评论
-
微软windows11、office2021、visio2021、project2021
2022-03-19 14:20 010月5日,Windows 11 正式发布, ... -
阿里VS腾讯
2017-03-24 16:01 537转自:谁是中国互联网行业的第一巨头? 对于理性的金融 ... -
Jackcess 2.0 发布,Java 访问 Access 数据库
2014-01-21 09:36 1108Jackcess 2.0 发布,Java 访问 Acces ... -
电脑容量存储单位
2013-07-04 10:20 699千,1KB=2的10次方=1024B, 兆,1MB=2的 ... -
读EMBA花费过百万 仅二成学员自掏腰包
2012-05-09 09:26 699近日,清华大学 ... -
24种错误生活方式让疾病粘上你
2012-04-24 09:10 6771、高跟鞋的美丽错误 高跟鞋 ... -
我国女职工产假由90天延长至98天
2012-04-19 09:13 671本报讯(记者孙乾)昨天,国务院常务会议审议并原则通过《女 ... -
你能养活几张银行卡:存款太少不要惹招行
2012-04-13 10:15 992在工商银行灵通卡账户存100元钱,10年后 ... -
业生平均薪酬在涨 国企起薪四千是民企2倍
2012-03-21 08:59 714记者在日前举行的“2012 ... -
北京首套房贷利率优惠重现 大行领头“松绑”
2012-03-21 08:59 7012012年一季度以来,多个地区的首套房贷利率都有所松动,北京多 ... -
小米手机第五轮开放购买 称10万台35分钟售罄
2012-03-21 08:58 760小米手机第五轮开放购买 3月18日消息,小米手 ... -
传谷歌年底推Android眼镜:可返回实时信息
2012-02-23 09:39 699腾讯科技讯(中涛)北京时间2月22日消息,据《纽约时报》旗下博 ... -
统计你写的java代码行数
2012-02-09 11:40 9531)自动统计工具SourceCounter-2.5.5.9,可 ... -
龙年赚钱8条投资建议:人民币升值趋势纳入考量
2012-01-31 10:55 675兔年在投资者一片哀叹中过去了,A股在今天迎来龙年第一个交易日。 ... -
行情转暖几乎不可能 2012年何时买房最合适?
2012-01-30 10:14 663对于刚性需求来说,2012年可重点关注5月、10月两个 ... -
26岁出纳挪用2570万元公款炒黄金
2012-01-30 09:49 857迷上香港的国际现货黄金交易,26岁的出纳谢某挪用公司资金257 ... -
新就业职工和外来务工者可申请公租房
2012-01-29 17:41 7742011年12月,各区县街道、乡镇的公租房窗口就将开始接受普通 ... -
北京官方租房平台网址
2012-01-29 17:13 719北京官方租房平台 http://www.bjjs.gov. ... -
12306辅助js 实现自动登录 自动查票 自动订单
2012-01-11 10:52 4488运行需求您必须准备以下条件之一: Firefox,最好 ... -
12306的优化思考
2012-01-10 12:31 1215一、场景分析 1、平时访问量不高,但是春运几天会出现瞬间 ...
相关推荐
### 构建高性能J2EE应用的10个技巧详解 #### 一、Java性能的基础:内存管理 在探讨如何构建高性能的Java 2 Platform, Enterprise Edition (J2EE) 应用之前,理解Java应用如何高效管理内存至关重要。Java应用的性能...
### J2EE (Java 2 Platform, Enterprise Edition) ...总之,J2EE Connector架构是J2EE平台不可或缺的一部分,它为开发人员提供了一个强大而灵活的框架,使得他们能够在不同的环境中快速构建高质量的企业级应用程序。
《J2EE经典实例详解》是一本专注于Java企业级应用开发的实践指南,它通过一系列精选的实例,帮助开发者深入理解和熟练运用J2EE技术。J2EE(Java 2 Platform, Enterprise Edition)是Java平台的企业版,为构建分布式...
J2EE 主流架构详解与应用 J2EE(Java 2 Enterprise Edition)是一种用于开发大型企业级应用程序的Java技术平台。J2EE提供了一系列的API和工具,帮助开发者快速构建大型企业级应用程序。在这个领域中,有多种架构可...
它允许开发者使用Java语言来构建高性能、高可靠性的服务器端应用。下面将详细解析J2EE的一些关键知识点: 1. **Servlet**:Servlet是Java EE中的基础组件,用于处理HTTP请求。开发者可以通过实现Servlet接口来创建...
《J2EE应用开发详解(刘晓华 陈亚强版)》是一本深度解析J2EE技术的专著,作者刘晓华和陈亚强是业界知名的IT专家,他们在书中详细介绍了如何进行J2EE应用程序的开发。这本书的光盘内容包含了丰富的源代码,为读者...
- 应对J2EE应用的性能优化、安全策略和故障排查。 每个实例通常会涵盖一个特定主题,比如数据库连接池的配置、EJB的生命周期管理、JMS的实现、或是使用JSF创建用户友好的界面。通过这些实例,开发者可以加深对J2EE...
在IT行业中,J2EE(Java 2 Platform, Enterprise Edition)是一个广泛使用的开源企业级应用开发平台,它为构建分布式、多层的Web应用程序提供了强大的框架。设计模式是软件工程中的一种最佳实践,它们是解决常见问题...
- **电商系统**:利用轻量级框架可以快速搭建出高性能的电商平台,如商品展示、订单处理等功能模块。 - **OA办公自动化系统**:基于Spring MVC等技术可以开发出高效的办公自动化系统,提高企业的内部管理效率。 - **...
J2EE(Java 2 Platform, Enterprise Edition)是Java平台的一个版本,专门针对企业级应用开发。它提供了一个多层架构的框架,用于构建可扩展、安全且易于维护的分布式应用程序。J2EE平台包含了各种服务、APIs和协议...
J2EE在J2SE的基础上,额外提供了大量的企业级服务,如分布式计算、Web服务、安全性、事务处理等,使其成为构建高负载、高可用性系统的理想选择。 #### J2EE SDK与J2SE SDK的关系 J2EE SDK实际上是包含了J2SE SDK的...
通过深入学习 J2EE,开发者可以构建可扩展、高性能、高度可靠的网络应用程序,满足复杂的业务需求。J2EE教程中的内容可能涵盖这些概念的详细讲解,帮助初学者和经验丰富的开发者更好地理解和掌握这一技术。
### J2EE体系结构及其主要设计模式 #### J2EE体系结构 **1.1 J2EE产生前提** 随着企业应用系统的不断复杂化以及...通过遵循J2EE的最佳实践和模式,开发者能够构建出高质量的企业级应用,满足日益增长的业务需求。
J2EE定义了一系列的服务、API和规范,如EJB(Enterprise JavaBeans)、JMS(Java Message Service)、JTA(Java Transaction API)、JPA(Java Persistence API)等,用于构建高可用、高性能、可扩展的企业级应用。...
在基于Hibernate和Struts的J2EE应用开发中,我们主要关注的是如何利用这两个框架的优势来构建高效、可维护的企业级应用。Hibernate是一个强大的数据持久层框架,它解决了Java对象与关系型数据库之间的映射问题,实现...
总的来说,J2EE群集技术是构建高可用、高性能企业级应用的重要手段。通过理解群集的基本原理,掌握Tomcat和WebLogic等服务器的群集配置,以及EJB在群集环境中的行为,开发者可以设计出更健壮的应用架构,以应对复杂...
J2EE是一个开放的、可移植的、多层的、分布式的、面向服务的企业级应用平台,它由一系列的Java API和服务组成,如Servlet、JSP、EJB(Enterprise JavaBeans)、JMS(Java Message Service)等,用于构建和部署分布式...