JAVAEE
Java ee 平台由一整套服务(Services)、应用程序接口(APIs)和协议构成,它对开发基于Web的多层应用提供了功能支持,下面对JAVAEE中的13种技术规范进行简单的描述(限于篇幅,这里只进行简单的描述):
1、JDBC(Java Database Connectivity) JDBC API为访问不同的数据库提供了一种统一的途径,象ODBC一样,JDBC对开发者屏蔽了一些细节问题,另外,JDCB对数据库的访问也具有平台无关性。
2、JNDI(Java Name and Directory Interface) JNDI API被用于执行名字和目录服务。它提供了一致的模型来存取和操作企业级的资源如DNS和LDAP,本地文件系统,或应用服务器中的对象。
3、EJB(Enterprise JavaBean) JAVAEE技术之所以赢得媒体广泛重视的原因之一就是EJB。它们提供了一个框架来开发和实施分布式商务逻辑,由此很显著地简化了具有可伸缩性和高度复杂的企业级应用的开发。EJB规范定义了EJB组件在何时如何与它们的容器进行交互作用。容器负责提供公用的服务,例如目录服务、事务管理、安全性、资源缓冲池以及容错性。但这里值得注意的是,EJB并不是实现JAVAEE的唯一途径。正是由于JAVAEE的开放性,使得有的厂商能够以一种和EJB平行的方式来达到同样的目的。
4、RMI(Remote Method Invoke) 正如其名字所表示的那样,RMI协议调用远程对象上方法。它使用了序列化方式在客户端和服务器端传递数据。RMI是一种被EJB使用的更底层的协议。
5、Java IDL/CORBA 在Java IDL的支持下,开发人员可以将Java和CORBA集成在一起。他们可以创建Java对象并使之可在CORBA ORB中展开, 或者他们还可以创建Java类并作为和其它ORB一起展开的CORBA对象的客户。后一种方法提供了另外一种途径,通过它Java可以被用于将你的新的应用和旧的系统相集成。
6、JSP(Java Server Pages) JSP页面由HTML代码和嵌入其中的Java代码所组成。服务器在页面被客户端所请求以后对这些Java代码进行处理,然后将生成的HTML页面返回给客户端的浏览器。
7、Java Servlet Servlet是一种小型的Java程序,它扩展了Web服务器的功能。作为一种服务器端的应用,当被请求时开始执行,这和CGI Perl脚本很相似。Servlet提供的功能大多与JSP类似,不过实现的方式不同。JSP通常是大多数HTML代码中嵌入少量的Java代码,而servlets全部由Java写成并且生成HTML。
8、XML(Extensible Markup Language) XML是一种可以用来定义其它标记语言的语言。它被用来在不同的商务过程中共享数据。 XML的发展和Java是相互独立的,但是,它和Java具有的相同目标正是平台独立性。通过将Java和XML的组合,您可以得到一个完美的具有平台独立性的解决方案。
9、JMS(Java Message Service) JMS是用于和面向消息的中间件相互通信的应用程序接口(API)。它既支持点对点的域,有支持发布/订阅(publish/subscribe)类型的域,并且提供对下列类型的支持:经认可的消息传递,事务型消息的传递,一致性消息和具有持久性的订阅者支持。JMS还提供了另 一种方式来对您的应用与旧的后台系统相集成。
10、JTA(Java Transaction Architecture) JTA定义了一种标准的API,应用系统由此可以访问各种事务监控。
11、JTS(Java Transaction Service) JTS是CORBA OTS事务监控的基本的实现。JTS规定了事务管理器的实现方式。该事务管理器是在高层支持Java Transaction API (JTA)规范,并且在较底层实现OMG OTS specification的Java映像。JTS事务管理器为应用服务器、资源管理器、独立的应用以及通信资源管理器提供了事务服务。
12、JavaMail JavaMail是用于存取邮件服务器的API,它提供了一套邮件服务器的抽象类。不仅支持SMTP服务器,也支持IMAP服务器。
13、JAF(JavaBeans Activation Framework) JavaMail利用JAF来处理MIME编码的邮件附件。MIME的字节流可以被转换成Java对象,或者转换自Java对象。
Java虚拟机
它包括class类加载器、JIT动态编译器、执行引擎、以及垃圾收集器等;
class类加载器可以分为多种,可以自定义外部的类加载器,这里我们只说JVM基本的类加载器,它可以把需要执行的class类文件加载进来,进行检查验证等;
JIT即时编译器(just-in-time compiler)将加载进来的class文件编译成优化成机器指令;
解释器用来直接执行class文件中的字节码指令,称为解释执行,执行速度较慢;
本地代码执行引擎用来执行经JIT编译的机器指令,速度快,但编译需要更多内存、时间,导致启动慢,并且class调用可能动态改变,导致需要重新编译;所以通常是解释执行和编译执行混合的模式,JIT编译器只编译那些"热点代码"。
执行过程中,可能会通过JNI(Java Native Interface)来调用本地类库,本地类库可以是系统相关类库,这样就可以发出系统调用,使用系统资源了;也可以是自己实现的一些类库,比如用C语言写一些复杂的算法提高执行效率。
JRE、JDK以及OpenJDK
一张烂掉牙却永远学不完的图片
其他一些概念
1、JRE(Java Runtime Envirnment)
JRE是支持Java程序运行的标准环境,提供运行用 Java 编程语言编写的应用和小程序所需的库、Java 虚拟机和其他组件。主要包括Java API类库中的Java SE API(如rt.jar)、Java虚拟机(如/bin/java即HotSpot)。
此外,JRE 还包括两项关键的部署技术:Java 插件 — 使小程序可以在常用浏览器中运行;以及 Java Web Start — 通过网络部署独立的应用。它还是用于企业软件开发和部署的 Java 2 Platform, Enterprise Edition (J2EE) 的基础。
2、JDK(Java Development Kit)
JDK称为Java开发包或Java开发工具,是一个编写Java应用程序的开发环境。JDK是整个Java的核心,包括了Java程序设计语言、Java运行环境(JRE)、一些Java工具(文档工具javadoc、打包工具jar.exe等)和更多Java类库(如tools.jar)。
JDK主要有:官方主流的OracleJDK,常用的还有OracleJDK的开源版本OpenJDK,其他还有Apache Harmony等。
3、JRE与JDK的区别
JRE = Java SE API + JVM + Java 插件/Java Web Start部署技术;
JDK = Java语言 + JRE + Java工具;
JRE是个运行环境,JDK是个开发环境。开发Java程序需要JDK,而运行Java程序的时候就需要JRE。
JDK里面已经包含了JRE,因此只要安装了JDK,就可以编辑Java程序,也可以正常运行Java程序;而用户运行普通的Java程序无须安装JDK,而只需要安装JRE即可,因为JDK包含了许多与运行无关的内容,占用空间较大。
4、Java EE SDK
Java EE是一系列技术规范,官方提供的Java EE SDK是Java EE的参考实现,是实现Java EE最全的开发工具包。
三大标准平台集合
1、Java SE(Java Standard Edtion)
Java标准版提供了用于开发桌面和服务器端企业应用程序的API和工具,可以让您在桌面和服务器以及目前要求较高的嵌入式环境中开发和部署 Java 应用;
2、Java EE(Java Enterprise Edition)
Java企业版是社区驱动的企业软件标准,提供了用于开发多层企业应用程序的API和工具,现如今,Java EE不仅仅是指一种标准平台,它更多的表达着一种软件架构和设计思想;
3、Java ME(Java Micro Edition)
Java ME技术专门针对庞大的消费者空间,其涵盖了极小的商品范围,例如智能卡或寻呼机,直到机顶盒,几乎与计算机一样强大的设备。
4、Java SE 与 Java EE 区别
Java EE是在Java SE基础上发展构建的,是一系列技术规范,官方提供的Java EE SDK是Java EE的参考实现,是实现Java EE最全的开发工具包,而我们常说的JDK只是包含Java SE API实现,Java SE中存在与Java EE有关的规范;Java EE 7主要包括下面一些技术规范:
JAVA EE 的一些架构
Tomcat /JavaEE Servlet技术
Listener:
Listener(监听器)用来监听一些对象的事件,当事件发生时可以进入到定义监听器中进行处理,主要有ServletContextListener、HttpSessionListener 和 ServletRequestListener。
我们程序中可以实现这些JavaEE Servlet API中提供的监听器接口,然后通过web.xml定义部署发生作用。Spring框架中常见的一些ServletContextListenerServlet实现在web.xml定义如下:
- org.springframework.web.util.Log4jConfigListener //配置log4j.xml监听器,注意该 listener需要放在spring的Listener之前
- org.springframework.web.context.ContextLoaderListener //用来在部署相关Web应用时初始化其上下文环境
Connector用来接受请求:启动时会创建四种类型的线程Worker线程、Poller线程、Acceptor线程、AsyncTimeout线程
Poller线程使用NIO方式,轮询Selector,这样的好处就是:在没有请求数据时,只有极少数的Poller线程阻塞,而避免了直接使用多个Work线程阻塞的消耗。
Acceptor线程,调用ServerSocket.accept()监听请求连接,
AsyncTimeout线程是用来实现异步请求的超时
Work(工作)线程用来处理请求连接,先根据配置参数创建Work线程池。
Tomcat请求处理过程
- Acceptor线程接收请求,创建连接Socket,当接受到请求时,返回一个代表该请求连接的socket,然后为该Socke创建一个NIO Channel(通道),
- 然后把该通道注册(OP_READ)到其中的一个Poller线程(这里是Poller1)的Selector多路复用器中,
- 当Poller线程轮询接收到read请求时,先创建一个SocketProcessor处理器,然后再通过线程池创建Work(Exec)线程并启动处理来该Socketwork线程执行请求过程:
- 提取请求信息到Request对象,找到URI映射关系,先是创建一个Http11Processor,再用该处理器来处理。
接下找到匹配的StandardWrapper的Servlet的处理,
- 先为该Servlet创建一个FilterChain,并把Web.xml中定义的对该Servlet匹配的Filter(过虑器)加入到该FilterChain,直到FilterChain.doFilter()发现所有Filter都调用完成,再调用Servlet的处理函数servlet.service()。
- 以DispatchServlet为例,调用方法依次是doService -> doDispatch -> 根据url(request)找到handlerAdapter(controller), 执行该方法(一般都是调用service),返回ModleView.
- Servlet程序对请求处理,返回静态资源
org.springframework.web.servlet.DispatcherServlet
参考资料:
https://blog.csdn.net/tjiyu/article/details/54590259