Jetty 的基本架构

Jetty 眼下的是一个比較被看好的 Servlet 引擎,它的架构比較简单,也是一个可扩展性和很灵活的应用server,它有一个基本数据模型,这个数据模型就是 Handler,全部能够被扩展的组件都能够作为一个 Handler,加入到 Server 中,Jetty 就是帮你管理这些 Handler。

下图是 Jetty 的基本架构图,整个 Jetty 的核心组件由 Server 和 Connector 两个组件构成,整个 Server 组件是基于 Handler 容器工作的,它相似与 Tomcat 的 Container 容器,Jetty 与 Tomcat 的比較在后面具体介绍。Jetty 中另外一个比不可少的组件是 Connector,它负责接受client的连接请求,并将请求分配给一个处理队列去执行。

图 1. Jetty 的基本架构

開始部署安装:

1 Jetty下载地址:
http://wiki.eclipse.org/Jetty/Howto/Install_Jetty

2 加入执行jetty账号
useradd -m jetty
usermod -a -G nagcmd jetty

3 解压缩(解压缩)
解压缩直接能够使用,不须要configre也不须要make了。
mv jetty-distribution-7.6.15.v20140411 /usr/local/jetty

查看README.txt
cat /usr/local/jetty/README.txt
能够看到一些RUNNING的方法:
......
RUNNING JETTY
=============
The run directory is either the top-level of a binary release
or jetty-distribution/target/assembly-prep directory when built from
source.
To run with the default options:
  java -jar start.jar
To see the available options and the default arguments
provided by the start.ini file:
  java -jar start.jar --help
To run with extra configuration file(s) appended, eg SSL
  java -jar start.jar etc/jetty-ssl.xml
To run with properties
  java -jar start.jar jetty.port=8081
To run with extra configuration file(s) prepended, eg logging & jmx
  java -jar start.jar --pre=etc/jetty-logging.xml --pre=etc/jetty-jmx.xml
To run without the args from start.ini
  java -jar start.jar --ini OPTIONS=Server,websocket etc/jetty.xml etc/jetty-deploy.xml etc/jetty-ssl.xml
to list the know OPTIONS:
  java -jar start.jar --list-options
java -jar /usr/local/jetty_7.6.15_8100/start.jar --pre=etc/jetty-logging.xml --pre=etc/jetty-jmx.xml jetty.port=8100

我须要在启动3个jetty服务,一个服务相应一个web应用,所以直接copy3个解压缩包
 cp -r jetty jetty_8100
 cp -r jetty jetty_8200
 cp -r jetty jetty_8300
 
4, 分别启动3个应用,带上jetty.port端口:
 nohup java -jar /usr/local/jetty_7.6.15_8100/start.jar --pre=etc/jetty-logging.xml --pre=etc/jetty-jmx.xml jetty.port=8100 &
 nohup java -jar /usr/local/jetty_7.6.15_8200/start.jar --pre=etc/jetty-logging.xml --pre=etc/jetty-jmx.xml jetty.port=8200 &
 nohup java -jar /usr/local/jetty_7.6.15_8300/start.jar --pre=etc/jetty-logging.xml --pre=etc/jetty-jmx.xml jetty.port=8300 &
 
 问题在于,用这样的方法start,却没有相应的办法去stop;
 比方java -jar /usr/local/jetty_7.6.15_8200/start.jar -DSTOP.PORT=8200 -DSTOP.KEY=magic --stop 的办法没有能够关闭掉jetty进程,仅仅能手工kill ID,这样的不是太保险。
 改端口例如以下:
将<Set name="port"><Property name="jetty.port" default="8100"/></Set>中的8080改成8100

vim /usr/local/jetty_7.6.15_8100/etc/jetty.xml
<Call name="addConnector">
<Arg>
<New class="org.eclipse.jetty.server.nio.SelectChannelConnector">
<Set name="host"><Property name="jetty.host" /></Set>
<Set name="port"><Property name="jetty.port" default="8100"/></Set>
<Set name="maxIdleTime">300000</Set>
<Set name="Acceptors">2</Set>
<Set name="statsOn">false</Set>
<Set name="confidentialPort">8443</Set>
<Set name="lowResourcesConnections">20000</Set>
<Set name="lowResourcesMaxIdleTime">5000</Set>
</New>
</Arg>
</Call>

 5,进入/bin/文件夹,发现有jetty.sh脚本能够启动
启动start :
/usr/local/jetty_7.6.15_8100/bin/jetty.sh start
停止stop :
/usr/local/jetty_7.6.15_8100/bin/jetty.sh stop

[root@localhost etc]# /usr/local/jetty_7.6.15_8100/bin/jetty.sh stop
Stopping Jetty: OK
[root@localhost etc]# /usr/local/jetty_7.6.15_8100/bin/jetty.sh start
Starting Jetty: 2014-05-13 15:53:05.744:INFO::Redirecting stderr/stdout to /usr/local/jetty_7.6.15_8100/logs/2014_05_13.stderrout.log
OK 2014年 05月 13日 星期二 15:53:09 CST
[root@localhost etc]#

有报错例如以下:
Starting Jetty: Already Running!!

改端口例如以下:
将<Set name="port"><Property name="jetty.port" default="8100"/></Set>中的8080改成8100

vim /usr/local/jetty_7.6.15_8200/etc/jetty.xml
<Call name="addConnector">
<Arg>
<New class="org.eclipse.jetty.server.nio.SelectChannelConnector">
<Set name="host"><Property name="jetty.host" /></Set>
<Set name="port"><Property name="jetty.port" default="8200"/></Set>
<Set name="maxIdleTime">300000</Set>
<Set name="Acceptors">2</Set>
<Set name="statsOn">false</Set>
<Set name="confidentialPort">8443</Set>
<Set name="lowResourcesConnections">20000</Set>
<Set name="lowResourcesMaxIdleTime">5000</Set>
</New>
</Arg>
</Call>

依次改成8100,8200,8300再列出停止启动命令例如以下:
/usr/local/jetty_7.6.15_8100/bin/jetty.sh stop
/usr/local/jetty_7.6.15_8200/bin/jetty.sh stop
/usr/local/jetty_7.6.15_8300/bin/jetty.sh stop

/usr/local/jetty_7.6.15_8300/bin/jetty.sh start
/usr/local/jetty_7.6.15_8200/bin/jetty.sh start
/usr/local/jetty_7.6.15_8100/bin/jetty.sh start

启动了8100,再起8200还是报一样的错误

Starting Jetty: Already Running!!

java -jar /usr/local/jetty_7.6.15_8300/start.jar --pre=etc/jetty-logging.xml --pre=etc/jetty-jmx.xml  --stop STOP.PORT=8300 STOP.KEY=1

nohup java -jar /usr/local/jetty_7.6.15_8100/start.jar --pre=etc/jetty-logging.xml --pre=etc/jetty-jmx.xml jetty.port=8100 &

6,再换java -jar方式启动试试
nohup java -jar /usr/local/jetty_7.6.15_8200/start.jar  jetty.port=8200 &
java -jar /usr/local/jetty_7.6.15_8200/start.jar --STOP.PORT=8200 --STOP.KEY=magic --stop 
java -jar /usr/local/jetty_7.6.15_8200/start.jar -DSTOP.PORT=8200 -DSTOP.KEY=magic --stop

下述方法能启动3个jetty,可是无法正常stop,--stop參数没有成功,jetty进程仍然在后台执行,仅仅能kill强行停止进程:

nohup java -jar /usr/local/jetty_7.6.15_8100/start.jar --pre=etc/jetty-logging.xml --pre=etc/jetty-jmx.xml jetty.port=8100 &
nohup java -jar /usr/local/jetty_7.6.15_8200/start.jar --pre=etc/jetty-logging.xml --pre=etc/jetty-jmx.xml jetty.port=8200 &
nohup java -jar /usr/local/jetty_7.6.15_8300/start.jar --pre=etc/jetty-logging.xml --pre=etc/jetty-jmx.xml jetty.port=8300 &

7,去看看 jetty.sh脚本,check下
[root@localhost bin]# /usr/local/jetty_7.6.15_8100/bin/jetty.sh check
Checking arguments to Jetty:
JETTY_HOME     =  /usr/local/jetty_7.6.15_8100
JETTY_CONF     =  /usr/local/jetty_7.6.15_8100/etc/jetty.conf
JETTY_RUN      =  /var/run
JETTY_PID      =  /var/run/jetty.pid
JETTY_PORT     = 
JETTY_LOGS     = 
START_INI      =  /usr/local/jetty_7.6.15_8100/start.ini
CONFIGS        =  etc/jetty-logging.xml etc/jetty-started.xml
JAVA_OPTIONS   =  -Djetty.state=/usr/local/jetty_7.6.15_8100/jetty.state -Djetty.home=/usr/local/jetty_7.6.15_8100 -Djava.io.tmpdir=/tmp
JAVA           =  /usr/java/jdk1.6.0_45/bin/java
CLASSPATH      =  .:/usr/java/jdk1.6.0_45/lib/tools.jar:/usr/java/jdk1.6.0_45/lib/dt.jar
RUN_CMD        =  /usr/java/jdk1.6.0_45/bin/java -Djetty.state=/usr/local/jetty_7.6.15_8100/jetty.state -Djetty.home=/usr/local/jetty_7.6.15_8100 -Djava.io.tmpdir=/tmp -jar /usr/local/jetty_7.6.15_8100/start.jar etc/jetty-logging.xml etc/jetty-started.xml

看到JETTY_PID      =  /var/run/jetty.pid,突然意识到,启动8200假设也是这样JETTY_PID      =  /var/run/jetty.pid一个pid的话,那肯定跟8100是冲突的,难怪每次仅仅能启动一个jetty.sh,须要去看下jetty.sh的脚本里面是在哪里设置/var/run/jetty.pid的,找到了改动下带上后缀数字。

vim jetty.sh
在第343行 将 jetty.pid 改成 jetty_8200.pid
改成

if [ -z "$JETTY_PID" ]
then
JETTY_PID="$JETTY_RUN/jetty_8200.pid"
fi if [ -z "$JETTY_STATE" ]
then
JETTY_STATE=$JETTY_HOME/jetty.state

  
8,最后正常关闭启动例如以下:

[root@localhost bin]# pwd
/usr/local/jetty_7.6.15_8200/bin
[root@localhost bin]# /usr/local/jetty_7.6.15_8100/bin/jetty.sh stop
Stopping Jetty: OK
[root@localhost bin]# /usr/local/jetty_7.6.15_8200/bin/jetty.sh stop
Stopping Jetty: OK
[root@localhost bin]# /usr/local/jetty_7.6.15_8300/bin/jetty.sh stop
Stopping Jetty: OK
[root@localhost bin]# ps -eaf|grep jetty
root 20205 11980 0 20:28 pts/2 00:00:00 grep jetty
[root@localhost bin]# /usr/local/jetty_7.6.15_8300/bin/jetty.sh start
Starting Jetty: 2014-05-13 20:28:32.146:INFO::Redirecting stderr/stdout to /usr/local/jetty_7.6.15_8300/logs/2014_05_13.stderrout.log
OK 2014年 05月 13日 星期二 20:28:33 CST
[root@localhost bin]# /usr/local/jetty_7.6.15_8200/bin/jetty.sh start
Starting Jetty: 2014-05-13 20:28:34.416:INFO::Redirecting stderr/stdout to /usr/local/jetty_7.6.15_8200/logs/2014_05_13.stderrout.log
OK 2014年 05月 13日 星期二 20:28:37 CST
[root@localhost bin]# /usr/local/jetty_7.6.15_8100/bin/jetty.sh start
Starting Jetty: 2014-05-13 20:28:38.527:INFO::Redirecting stderr/stdout to /usr/local/jetty_7.6.15_8100/logs/2014_05_13.stderrout.log
OK 2014年 05月 13日 星期二 20:28:41 CST
[root@localhost bin]#

9,打开 http://192.xxx.xxx.xx:8100/cargo-jetty-deployer/报错例如以下

HTTP ERROR 400

Problem accessing /cargo-jetty-deployer/. Reason:

Command / is unknown
Powered by Jetty://

10,部署一个简单的jetty应用:
[root@localhost webapps]# mkdir test1
[root@localhost webapps]# ll
总计 27100
-rw-r--r-- 1 root root    10220 05-13 20:44 cargo-jetty-7-and-onwards-deployer-1.4.8.war
-rw-r--r-- 1 root root 26839664 05-14 15:22 imClient.war
drwxr-xr-x 3 root root     4096 03-31 22:05 META-INF
-rw-r--r-- 1 root root    14578 05-13 15:20 spdy.war
drwxr-xr-x 2 root root     4096 05-14 16:05 test1
-rw-r--r-- 1 root root   763052 05-13 15:20 test.war
-rw-r--r-- 1 root root    60014 05-14 13:31 webim_server.jar
drwxr-xr-x 3 root root     4096 03-31 22:05 WEB-INF
[root@localhost webapps]#

[root@localhost test1]# cd test1
[root@localhost test1]# vim hello.jsp
<html>
<body>
<h4>simple demo test</h4>
<%--echo hello world--%>
<%@page language="java"%>
<%="Hello World,The first jetty demo page of timman in pl"%>
</body>
</html>

又一次启动jetty
[root@localhost test1]# /usr/local/jetty_7.6.15_8100/bin/jetty.sh restart
Stopping Jetty: OK
Starting Jetty: 2014-05-14 16:08:25.445:INFO::Redirecting stderr/stdout to /usr/local/jetty_7.6.15_8100/logs/2014_05_14.stderrout.log
. . . OK 2014年 05月 14日 星期三 16:08:38 CST
[root@localhost test1]#

11,查看效果显示:在浏览器里面输入网址: http://192.xxx.xxx.xx:8100/test1/hello.jsp
会在页面显演示样例如以下:
simple demo test

Hello World,The first jetty demo page of timman in pl,例如以下图:

附加总结:

(1):单纯比較 Tomcat 与 Jetty 的性能意义不是很大,仅仅能说在某种使用场景下,它表现的各有差异。由于它们面向的使用场景不尽同样。

从架构上来看 Tomcat 在处理少数很繁忙的连接上更有优势,也就是说连接的生命周期假设短的话,Tomcat 的整体性能更高。
而 Jetty 刚好相反,Jetty 能够同一时候处理大量连接并且能够长时间保持这些连接。比如像一些 web 聊天应用很适合用 Jetty 做server,像淘宝的 web 旺旺就是用 Jetty 作为 Servlet 引擎。

(2)另外由于 Jetty 的架构很easy,作为server它能够按需载入组件,这样不须要的组件能够去掉,这样无形能够降低server本身的内存开销,处理一次请求也是能够降低产生的暂时对象,这样性能也会提高。另外 Jetty 默认使用的是 NIO 技术在处理 I/O 请求上更占优势,Tomcat 默认使用的是 BIO,在处理静态资源时,Tomcat 的性能不如 Jetty。

參考网址: http://www.ibm.com/developerworks/cn/java/j-lo-jetty/

Jetty安装学习并展示的更多相关文章

  1. DB 查询分析器 6.04 在 Windows 10 上的安装与运行展示

    DB查询分析器 6.04 在 Windows 10 上的安装与运行展示 中国本土程序员马根峰(CSDN专访马根峰:海量数据处理与分析大师的中国本土程序员 http://www.csdn.net/art ...

  2. jetty安装、配置、优化

    )Jetty: 作用:Jetty 是一个开源的servlet容器,它为基于Java的web内容,例如JSP和servlet提供运行环境. 特性:易用性,可扩展性,易嵌入性 2) Jetty安装:  t ...

  3. Centos6.8 Jetty 安装配置

    ssh root@IP Password------------------------------------------------------------------------------↑登 ...

  4. Jetty 安装、启动与项目部署

    Jetty是当下非常流行的一款轻量级Java Web服务器和Servlet容器实现,它由Eclipse基金会托管,完全免费而且开放源代码,因此所有人均可以从其官网下载最新源代码进行研究.由于其轻量.灵 ...

  5. python3数据分析,安装学习

    python3数据分析,安装学习 转载注明来源: 本文链接 来自osnosn的博客,写于 2019-09-26. 为了简单.安装 anaconda3 就好啦. 因为安装原版python3,用pip安装 ...

  6. Redis学习笔记(一)关于在windows64位环境下的安装学习使用

    前言 由于工作需要,目前我正在学习使用Redis.我当时学习Redis就从网上下载了点资料就开始学习了.入门看的是<REDIS入门指南>,这本书个人觉得很适合新手用来学习接触.根据书上的引 ...

  7. laravel安装学习步骤

    在看知乎比较php框架的优劣的时候提到为什么laravel这么好国内用的少,还有就是yii2,有人提到原因就是composer在国内无法使用.这制约了使用composer进行包管理的框架在国内的传播和 ...

  8. Jetty安装

    下载jetty http://www.eclipse.org/jetty/  看好jdk 版本 安装 解压压缩包到指定目录,且将其目录路径定义为${JETTY_HOME} 进入${JETTY_HOME ...

  9. Sql Server 2008开发版(Developer Edition)过期升级企业版(Enterprise Edition)失败后安装学习版(Express Edition)

    最近一个多月,甚是悠哉,无事可做.上线的网站系统也没接到客户的反馈,反而觉得无聊之极了.上周五早上,一上QQ,就收到客户发来消息,管理平台无法登陆了.心里一惊,立马开始查找故障原因.翻看了系统日志,提 ...

随机推荐

  1. Unicode 字符集与它的编码方式

    正式内容開始之前,我们先来了解一个基本概念,编码字符集. 编码字符集:编码字符集是一个字符集,它为每个字符分配一个唯一数字.Unicode 标准的核心是一个编码字符集,字母"A"的 ...

  2. 运用mapreduce计算tf-idf

    问题描写叙述:给定一个大文件,文件里的内容每一行为:文档名,文档内容. input 文档名1,word1 Word2 ....... 文档名2,word1 Word2 ....... output w ...

  3. html浏览器兼容性的 JavaScript语法

    1.      在FireFox中能够使用与HTML节点对象ID属性值同样的JS变量名称.可是IE中不行. 解决的方法:在命名上区分HTML节点对象ID属性值和JS变量 2.      IE不支持JS ...

  4. [SVN]常见问题的解决方案

    Date:2014-1-3 Summary: SVN使用的一些常见问题解决方案记录,来源Internet,本人亲测 Contents: 1.回滚自己的分支到某一个版本 $svn merge -r rH ...

  5. 常见问题(FAQ) | VPNCUP

    常见问题(FAQ) | VPNCUP 常见问题(FAQ) 关于FAQ 新手开始 登录验证问题 为什么刚注册后,登录VPN服务器提示错误? 免费注册的用户有哪些限制? 为什么连接免费VPN后20分钟自动 ...

  6. margin 等高布局

    <div id="main"> <div id="left"> 我是左边的内容的啦啦啦啦... .<br> 我是左边的内容的 ...

  7. 使用xml和java代码混合控制UI界面

    main.xml.................... <?xml version="1.0" encoding="utf-8"?> <Li ...

  8. C编译: 使用gdb调试

    作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! gdb是the GNU Debugger的简称.它是一款UNIX平台的调试器(de ...

  9. VSTO之旅系列(三):自定义Excel UI

    原文:VSTO之旅系列(三):自定义Excel UI 本专题概要 引言 自定义任务窗体(Task Pane) 自定义选项卡,即Ribbon 自定义上下文菜单 小结 引言 在上一个专题中为大家介绍如何创 ...

  10. uva10480(最小割)

    传送门:Sabotage 题意:给定多个城市的网络,每个城市之间的通信有花费,要求使得首都和最大城市之间的通信断掉的最小花费.要求输出任意一组砸掉的边. 分析:跑一遍最大流dinic后,根据最小割定理 ...