javaee和项目开发——一、前言

1 过去请求,响应的方式
a CGI

接受第一个请求,操作系统创建一个进程,这个进程处理这个请求。接收第二个请求,操作系统创建一个新的进程,新的进程处理第二个请求。接收第n请求,操作系统创建第个进程,处理第n个请求。如图所示:

在这里插入图片描述
这个叫做公共网关接口(Common Gateway Interface)CGI.

打开自己笔记本电脑的任务管理器,只有161个进程,占用内存48%,在使用FastCGI方案之前,如果用我的笔记本电脑做服务器,用这种方式至多同时处理320个请求。进程是在内存中运行的,一个请求创建一个进程,消耗内存空间。更何况过去的服务器配置应该是比现在低的。
在这里插入图片描述

b FastCGI
CGI方式,有创建进程的步骤,耗时,并且一个进程只能处理一个请求,耗内存。

所以过去的程序员想到了一种解决方案——进程池(pooling技术)。操作系统创建好一定数量的进程,放在内存里。当来一个请求就使用已经创建好的第一个进程处理请求,响应结果。当第一个请求处理完毕,第二个请求来了,操作系统会使用第一个进程处理第二个请求,响应结果。当第三个请求来了,第二个请求还未处理完毕,操作系统会使用第二个进程处理请求,响应结果。如图所示:
在这里插入图片描述
这样,在请求-响应过程中减少了创建进程的操作,省时间。一个进程处理多个请求,省内存。

但是,FastCGI仍然是基于进程的方式。进程间相互通信困难,比如qq音乐进程与idea进程。进程消耗内存资源大。

2 sun公司制定的javaee标准
sun公司制定了13个技术规范,JDBC、JNDI、EJB、RMI、Servlet、JSP、XML、JMS、Java IDL、JPA、 JTA、JavaMail 和 JAF。来解决上面的问题。这些技术规范统称为javaee平台,或者叫javaee标准。

其中,jdbc是用来连接数据库的技术标准,也就是接口。servlet是处理请求的技术标准,JSP是用来展示页面 的技术标准,xml是传输数据的技术。

3 使用servlet,变革请求响应的方式
FastCGI使用的仍然是进程处理请求响应,Servlet使用线程,这从根本上解决了内存空间消耗的问题。具有极大的意义!将每一个进程看做一个火车,线程看做一个火车车厢。过去有100个请求同时来到,要100个进程,也就是100个火车!现在只需要一辆火车,100个车厢。节省了百倍的资源空间。如图所示:

在这里插入图片描述

4 apache公司tomcat,对javaee平台的实现

a JavaEE 应用服务器(JavaEE Application Server)

应用服务器是 Java EE 规范的具体实现:
JBoss(RedHad 收费)
Weblogic(BEA Oracle 收费)

b Web 容器(Web Server)
只实现了 JavaEE 平台下部分技术标准,如 Servlet,Jsp,JNDI,JavaMail。Web 容器是开 源免费的。
Tomcat(Apache 开源免费) Jetty(Jetty 开源免费)

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值