1、Web Server,Web container和Application Server区别。
Web Server,Web服务器,同上面所说,Web服务器是指能够为发出请求的浏览器提供文档的程序。服务器是一种被动程序,只有浏览器发出请求的时候才会响应。应用层使用的是HTTP协议。目前最主流的三个Web服务器是Apache Nginx IIS。
Web容器是一种服务器程序,在服务器端口就有一个提供相应服务的程序。所以现在知道为什么Tomcat有默认的端口——8080。一个服务器可以有多个容器。
如Tomcat,收到浏览器的请求之后还会解析Servlet,然后再把Servlet处理后的结果返回给浏览器。其实Tomcat既是Web服务器也是Web容器。为什么这样说,第三点会讲到。
而应用服务器,这里有个区分它与Web服务器的答案:
What is the difference between application server and web server?
Web服务器设计服务于HTTP内容,应用服务器不只限于HTTP。Web服务器服务于静态内容,有插件支持动态语言,
应用服务器也具有Web服务器的这些东西,除此它还支持程序级的服务,如连接池,事务支持,信息服务等。
2、web 容器
何为容器:
容器是一种服务调用规范框架,J2EE 大量运用了容器和组件技术来构建分层的企业级应用。在 J2EE 规范中,相应的有 WEB Container 和 EJB Container 等。
WEB 容器给处于其中的应用程序组件(JSP,SERVLET)提供一个环境,使 JSP,SERVLET 直接跟容器中的环境变量交互,不必关注其它系统问题(从这个角度来说,web 容器应该属于架构上的概念)。web 容器 主要由 WEB 服务器来实现。例如:TOMCAT,WEBLOGIC,WEBSPHERE 等。
若容器提供的接口严格遵守 J2EE 规范中的 WEB APPLICATION 标准。我们把该容器叫做 J2EE 中的 WEB 容器。
WEB 容器更多的是跟基于 HTTP 的请求打交道。而 EJB 容器不是。它是更多的跟数据库、其它服务打交道。
容器的行为是 将其内部的应用程序组件与外界的通信协议交互进行了隔离,从而减轻内部应用程序组件的负担(实现方面的负担?)。 例如,SERVLET 不用关心 HTTP 的细节,而是直接引用环境变量 session、request、response 就行、EJB 不用关心数据库连接速度、各种事务控制,直接由容器来完成。
3、Web服务器
Web 服务器(Web Server)可以处理 HTTP 协议。当 Web 服务器接收到一个 HTTP 请求,会返回一个 HTTP 响应,例如送回一个 HTML 页面。
Web 服务器可以响应针对静态页面或图片的请求, 进行页面跳转(redirect),或者把动态响应(dynamic response)的产生委托(delegate)给一些其它的程序,例如 CGI 脚本,JSP(JavaServer Pages)脚本,servlets,ASP(Active Server Pages)脚本,服务器端 JavaScript,或者一些其它的服务器端技术。
Web 服务器仅仅提供一个可以执行服务器端程序和返回(程序所产生的)响应的环境,而不会超出职能范围。
Web 服务器主要是处理需要向浏览器发送 HTML 的请求以供浏览。
4、应用程序服务器(The Application Server)
根据定义,作为应用程序服务器,要求可以通过各种协议(包括 HTTP 协议)把商业逻辑暴露给(expose)客户端应用程序。应用程序使用此商业逻辑就像你调用对象的一个方法或过程(语言中的一个函数)一样。
5、serverlet
Servlet(Server Applet),全称 Java Servlet,未有中文译文。是用 Java 编写的服务器端程序。其主要功能在于交互式地浏览和修改数据,生成动态 Web 内容。狭义的 Servlet 是指 Java 语言实现的一个接口,广义的 Servlet 是指任何实现了这个 Servlet 接口的类,一般情况下,人们将 Servlet 理解为后者。
Servlet 运行于支持 Java 的应用服务器中。从实现上讲,Servlet 可以响应任何类型的请求,但绝大多数情况下 Servlet 只用来扩展基于 HTTP 协议的 Web 服务器。
6、Tomcat
Tomcat 服务器是一个免费的开放源代码的 Web 应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试 JSP 程序的首选。对于一个初学者来说,可以这样认为,当在一台机器上配置好 Apache 服务器,可利用它响应对 HTML 页面的访问请求。实际上 Tomcat 部分是Apache 服务器的扩展,但它是独立运行的,所以当你运行 tomcat 时,它实际上作为一个与 Apache 独立的进程单独运行的。
Apache Tomcat is an open source software implementation of the Java Servlet and JavaServer Pages technologies.
Tomcat 服务器是一个免费的开放源代码的 Web 应用服务器。因为 Tomcat 技术先进、性能稳定且免费,所以深受 Java 爱好者的喜爱并得到了部分软件开发商的认可,成为目前比较流行的 Web 应用服务器。
一、Tomcat 与应用服务器
到目前为止,Tomcat 一直被认为是 Servlet/JSP API 的执行器,也就所谓的 Servlet 容器。然而,Tomcat并不仅仅如此,它还提供了 JNDI 和 JMX API 的实现机制。尽管如此,Tomcat 仍然还不能算是应用服务器,因为它不提供大多数 J2EE API 的支持。
很有意思的是,目前许多的应用服务器通常把 Tomcat 作为它们 Servlet 和 JSP API 的容器。由于 Tomcat允许开发者只需通过加入一行致谢,就可以把 Tomcat 嵌入到它们的应用中。遗憾的是,许多商业应用服务器并没有遵守此规则。
对于开发者来说,如果是为了寻找利用 Servlet、JSP、JNDI 和 JMX 技术来生成 Java Web 应用的话,选择Tomcat 是一个优秀的解决方案;但是为了寻找支持其他的 J2EE API,那么寻找一个应用服务器或者把 Tomcat作为应用服务器的辅助,将是一个不错的解决方案;第三种方式是找到独立的 J2EE API 实现,然后把它们跟Tomcat 结合起来使用。虽然整合会带来相关的问题,但是这种方式是最为有效的。
二、Tomcat 与 Web 服务器
Tomcat 是提供一个支持 Servlet 和 JSP 运行的容器。Servlet 和 JSP 能根据实时需要,产生动态网页内容。而对于 Web 服务器来说, Apache 仅仅支持静态网页,对于支持动态网页就会显得无能为力;Tomcat 则既能为动态网页服务,同时也能为静态网页提供支持。尽管它没有通常的 Web 服务器快、功能也不如 Web 服务器丰富,但是 Tomcat 逐渐为支持静态内容不断扩充。大多数的 Web 服务器都是用底层语言编写如 C,利用了相应平台的特征,因此用纯 Java 编写的 Tomcat 执行速度不可能与它们相提并论。
一般来说,大的站点都是将 Tomcat 与 Apache 的结合,Apache 负责接受所有来自客户端的 HTTP 请求,然后将 Servlets 和 JSP 的请求转发给 Tomcat 来处理。Tomcat 完成处理后,将响应传回给 Apache,最后 Apache 将响应返回给客户端。
java 技术树如下:
一. Git版本管理+Maven工程管理
二. Java编程
书籍
- 《Java核心技术(卷1)》:学习java必备的黄皮书,入门推荐书籍
- 《Java核心技术(卷2)》:黄皮书之高级特性
- 《Java并发编程实战》: 对java并发库讲得非常透彻
- 《Effective Java》:Java之父高司令都称赞的一本java进阶书籍
- 《写给大忙人看的Java SE 8》:涵盖了java8带来以及java7中被略过的新的java特性,值得一看
资料
- Socket编程: http://ifeve.com/java-socket/
- NIO: http://ifeve.com/java-nio-all/
- 序列化: http://ifeve.com/java-io-s-objectinputstream-objectoutputstream/
- RPC框架: http://dubbo.io
- 并发编程:http://ifeve.com/java-concurrency-constructs/
三. 开发框架
- Spring: 跟开涛学Spring3
- Spring MVC: 跟开涛学SpringMvc
- MyBatis: MyBatis实战教程 MyBatis学习
对于这些框架或者是一些常用的软件,个人最推崇的还是阅读官方文档来学习。当然,看这些资料能让你入门地更加快速一些。
更进一步的,在学会使用之后,去阅读这些框架或软件的源码是必不可少的一步。阅读源码的一种比较好的步骤如下:
- 1) 先阅读架构文档
- 2) 根据架构,将源码文件以模块(或上下层级)分类
- 3) 从最独立(依赖性最小)的模块代码读起
- 4) 阅读该模块功能文档
- 5) 阅读该模块源代码
- 6) 一边阅读一边整理「调用关系表」
- 7) goto 3
四. 性能优化与诊断-系统
学习内容:
- Linux概述
- 性能分析工具
- 系统调优
- Linux服务器应用的性能特征
- 调优案例分析
五. 性能优化与诊断-JVM
-
学习内容:
- JVM概述
- JVM性能监控
- JVM性能剖析与工具
- JVM参数与调优步骤
- JVM调优案例分析
六. 消息中间件
JMS
最为经典,也比较简单的一个消息中间件规范,ActiveMQ是其一个实现。但由于自身的一些局限,不再推荐使用。
- 大规模分布式消息中间件简介:http://blog.csdn.net/huyiyang2010/article/details/5969944
- JMS Overview: http://docs.oracle.com/javaee/6/tutorial/doc/bncdr.html
- Basic JMS API Concepts: http://docs.oracle.com/javaee/6/tutorial/doc/bncdx.html
- The JMS API Programming Model: http://docs.oracle.com/javaee/6/tutorial/doc/bnceh.html
- Creating Robust JMS Applications:http://docs.oracle.com/javaee/6/tutorial/doc/bncfu.html
- Using the JMS API in Java EE Applications: http://docs.oracle.com/javaee/6/tutorial/doc/bncgl.html
- Further Information about JMS: http://docs.oracle.com/javaee/6/tutorial/doc/bncgu.html
RabbitMQ
RabbitMQ是AMQP(The Advanced Message Queuing Protocol)协议的实现。适用于需要事务管理、对消息丢失很敏感的应用场景。对比kafka来看,RabbitMQ更为强调消息的可靠性、事务等。通过阅读官方文档学习即可:官方文档
Kafka
基于日志的消息队列,首推当然是官方文档: http://kafka.apache.org/documentation.html
-
kafka中文教程:比较不错的中文教程
学习内容:
- 开始学习kafka
- 入门
- 接口
- 配置
- 设计
- 实现
- 什么是kafka
- 什么场景下使用kafka
-
kafka-study: 笔者在学习kafka时的一些笔记
七. OAuth认证技术
原理
OAuth是目前最为流行的第三方认证技术,即如何为第三方应用提供基于自己系统帐户体系的认证。目前,微博、微信、QQ、Facebook、Twitter基本上都是通过此协议让第三方应用集成的。简单的介绍可见百度百科简介: OAuth。
此外,这里有一篇博文讲的比较详细:OAuth的机制原理讲解及开发流程。
开源实现
- Google oauth core:http://oauth.net/code/
- Spring oauth: http://projects.spring.io/spring-security-oauth/
八. Redis设计与实现
-
Redis命令: 使用当然要看这份权威文档,也是平常开发中最常用的参考资料。
-
Redis设计与实现:可以通过此文档来学习Redis的原理。当然,自己去看redis的源代码更是不错的选择。
学习内容:
- 常用命令以及数据结构
- 内部数据结构
- 内存映射数据库结构
- redis数据类型
- 功能的实现
- 内部运作机制
九. 数据相关
理论基础
作为业界良心的google还有其他许多先进的分布式技术,其论文也非常值得去研读。可以通过此链接获取一些论文的内容:http://www.chinacloud.cn/show.aspx?id=14382&cid=11
实时计算
- 《Storm分布式实时计算模式》:虽然twitter推出了新一代的Heron,但Storm仍是目前应用最为广泛的实时计算技术。
- Spark streaming: :Spark带来了基于批处理的实时流计算技术,对比Storm各有优劣。
离线计算
- 《Hadoop权威指南》:无须多言,Haoop是大数据必须要学习的技术,涵盖了HDFS+HBase+MapReduce。
- 《Hive编程指南》:Hive降低了MapReduce程序编写的复杂度。
- 《Spark快速大数据分析》: Spark引进的基于RDD的计算模型大大提高了离线计算的性能,相对于MR来说是更为领先的离线计算技术。
Lambda架构
大数据领域的经典架构方案,融合了离线和实时计算模型,对外能够提供稳定可靠的数据。对此架构的剖析可见此篇文章:Linkedln技术高管Jay Kreps:Lambda架构剖析
机器学习
除了个性化推荐系统之外,CTR预估、广告推荐、预测模型都是机器学习的应用场景。
相关推荐
该项目是一款使用Python语言编写的个人杂谈日记簿后端设计源码,总文件量为30个,其中包含17个Python源代码文件、5个XML配置文件、2个Git忽略文件、2个文本文件以及其他几种类型文件。源码未包含最新版本更新。
### 高并发架构设计 ...综上所述,高并发架构的设计涉及到多个层面的技术,需要根据实际情况选择合适的技术栈和实施方案。通过综合运用以上提到的各种技术手段,可以构建出稳定、高效且可扩展的高并发系统。
听评课技术杂谈PPT教案.pptx
ASP生成静态Html文件技术杂谈.pdf
在编程世界中,程序设计是一项核心技能,涵盖了多种技术和方法。程序设计经验杂谈涉及到的不仅仅是语法和逻辑,更关乎到代码的可读性、可维护性以及性能优化。这里,我们将深入探讨程序设计的各个方面,包括但不限于...
大数据与人工智能技术分享演讲 当人工智能“科学遇到艺术”的一点杂谈_张 敏清华大学计算机科学与技术系 共12页.pdf
ERP实施杂谈ERP实施杂谈
"高并发场景杂谈.zip"这个压缩包文件集成了多种处理高并发问题的策略和技术,旨在为开发者提供解决高并发问题的思路和实践案例。下面将详细讨论其中涉及的知识点。 首先,我们来看"Redis专场:如何利用Redisson...
本文档《为己杂谈学习精要.doc》主要探讨了个人修养、企业文化、管理理念以及如何在职业生涯中找到良好发展平台的主题。作者引用了老子的哲学思想,并结合《论语》中的教诲,阐述了一种既考虑个人利益又兼顾他人和...
地产行业杂谈系列之十六:社区增值服务模式初探
"IT工作杂谈"的标签进一步明确了文档的内容,它涵盖了IT工作中广泛的话题,可能包括但不限于编程语言的学习与实践、软件开发流程、项目管理、团队协作、技术趋势、网络安全、数据分析、云计算、人工智能、移动应用...
"程序设计经验杂谈"这个主题旨在分享程序员们在实践中积累的各种经验和技巧,帮助新手和有经验的开发者更好地理解和优化他们的编程实践。 首先,我们来探讨一下程序设计的基本原则。程序设计的核心是解决问题,这...
### JAVA杂谈:深入探索Java的核心机制与实践 #### 动态加载机制解析 Java的动态加载机制是其面向对象编程(OOP)理念的核心体现之一,它使得Java能够在运行时根据需要加载类,而非在程序启动之初加载所有类。这种...
### 彻底掌握ASP分页技术详解 #### 引言 在Web开发中,分页是一种常见的技术,尤其是在处理大量数据展示的时候。本文将以ASP(Active Server Pages)为基础,详细介绍如何实现网页上的分页功能,并深入探讨其背后...
在准备HPUX 091考试时,考生还需要关注HP的最新技术动态,因为官方认证考试往往会考察到最新的产品特性和解决方案。保持对行业动态的敏感度,结合理论知识和实践经验,将大大增加成功通过考试的可能性。同时,保持...
元计算技术人员为大家介绍有限元软件模型格式杂谈