Jetty安装学习并展示

Jetty 的基本架构

Jetty 目前的是一个比较被看好的 Servlet 引擎,它的架构比较简单,也是一个可扩展性和非常灵活的应用服务器,它有一个基本数据模型,这个数据模型就是 Handler,所有可以被扩展的组件都可以作为一个 Handler,添加到 Server 中,Jetty 就是帮你管理这些 Handler。

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

图 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

[[email protected] etc]# /usr/local/jetty_7.6.15_8100/bin/jetty.sh stop
Stopping Jetty: OK
[[email protected] 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
[[email protected] 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下
[[email protected] 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,最后正常关闭启动如下:

[[email protected] bin]# pwd
/usr/local/jetty_7.6.15_8200/bin
[[email protected] bin]# /usr/local/jetty_7.6.15_8100/bin/jetty.sh stop
Stopping Jetty: OK
[[email protected] bin]# /usr/local/jetty_7.6.15_8200/bin/jetty.sh stop
Stopping Jetty: OK
[[email protected] bin]# /usr/local/jetty_7.6.15_8300/bin/jetty.sh stop
Stopping Jetty: OK
[[email protected] bin]# ps -eaf|grep jetty
root     20205 11980  0 20:28 pts/2    00:00:00 grep jetty
[[email protected] 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
[[email protected] 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
[[email protected] 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
[[email protected] 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应用:
[[email protected] webapps]# mkdir test1
[[email protected] 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
[[email protected] webapps]#

[[email protected] test1]# cd test1
[[email protected] 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
[[email protected] 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
[[email protected] 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 做服务器,像淘宝的 web 旺旺就是用 Jetty 作为 Servlet 引擎。

(2)另外由于 Jetty 的架构非常简单,作为服务器它可以按需加载组件,这样不需要的组件可以去掉,这样无形可以减少服务器本身的内存开销,处理一次请求也是可以减少产生的临时对象,这样性能也会提高。另外 Jetty 默认使用的是 NIO 技术在处理 I/O 请求上更占优势,Tomcat 默认使用的是 BIO,在处理静态资源时,Tomcat 的性能不如 Jetty。

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

Jetty安装学习并展示,布布扣,bubuko.com

时间: 2024-12-20 20:51:36

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

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

DB查询分析器 6.04 在 Windows 10 上的安装与运行展示 中国本土程序员马根峰(CSDN专访马根峰:海量数据处理与分析大师的中国本土程序员 http://www.csdn.net/article/2014-08-09/2821124)推出的个人作品----万能数据库查询分析器,中文版本<DB 查询分析器>.英文版本<DB QueryAnalyzer>.它具有强大的功能.友好的操作界面.良好的操作性.跨越各种数据库平台乃至于EXCEL和文本文件. 你可以通过它 ① 查询

内核编译安装学习笔记

前提:查看本地硬件信息常用工具 查看CPU信息: #cat /proc/cpuinfo #x86info #lscpu 查看PCI: #lspci 查看USB: #lsusb 查看块设备: #lsblk 查看综合的设备详细信息: #hal-device 编译:交叉编译 cross-compiling用于在宿主机上编译,应用于别的机器上架构迥异的内核. 编译内核的步骤:(安装好开发环境:Development Tools,Server Platform Development,ncurses-de

虚拟化(七):vmware horizon view 安装及效果展示

虚拟化(一):虚拟化及vmware产品介绍 虚拟化(二):虚拟化及vmware workstation产品使用 虚拟化(三):vsphere套件的安装注意及使用 虚拟化(四):vsphere高可用功能前提-共享存储搭建 虚拟化(五):vsphere高可用群集与容错 虚拟化(六):vmware 桌面虚拟化 horizon view 介绍 vmware horizon view 整体结构图,如下: 本节主要简要介绍view套件的安装,主要步骤有准备ad和dns环境,安装vsphere套件,安装com

[Linux] 学习笔记之安装学习环境(sshd, lrzsz)

紧接前一篇,在VMWare安装完Linux,这个时候我们要使用远程工具连接到虚拟机上去了,以前一直使用Putty,后来到新公司之后,推荐使用SecureCRT,使用之后,觉得效果不错,但是每次连接都失败,linux新手伤不起,在网上搜啊搜,终于找到解决办法.   搜索了很多资料之后,发现是由于我未在Linux上安装ssh服务导致无法使用SecureCRT连接. 1. 可以使用ssh localhost对此进行测试,具体使用如下: 2. 使用apt-get或者yum安装ssh服务,具体哪种操作系统

jetty安装

linux 内核版本: [[email protected] webapps]# uname -a Linux master-1-1 2.6.32-431.el6.x86_64 #1 SMP Fri Nov 22 03:15:09 UTC 2013 x86_64 x86_64 x86_64 GNU/Linux linux 系统版本: [[email protected] webapps]# cat /etc/redhat-release CentOS release 6.5 (Final) 安装

jetty 安装

http://blog.csdn.net/codeforces_sphinx/article/details/8209356 1. 如果没有装JDK的话,安装OpenJDK [plain] view plaincopyprint? sudo apt-get install openjdk-7-jdk 2. 安装Jetty,Ubuntu软件源里的是Jetty6 [plain] view plaincopyprint? sudo apt-get install jetty 3. 配置Jetty,修改

Jetty 安装、启动与项目部署

Jetty 是一个开源的servlet容器,它为基于Java的web容器,例如JSP和servlet提供运行环境.Jetty是使用Java语言编写的,它的API以一组JAR包的形式发布.开发人员可以将Jetty容器实例化成一个对象,可以迅速为一些独立运行(stand-alone)的Java应用提供网络和web连接.-------百度百科 Jetty目前的是一个比较被看好的 Servlet 引擎,它的架构比较简单,也是一个可扩展性和非常灵活的应用服务器.它有一个基本数据模型,这个数据模型就是 Ha

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

前言 由于工作需要,目前我正在学习使用Redis.我当时学习Redis就从网上下载了点资料就开始学习了.入门看的是<REDIS入门指南>,这本书个人觉得很适合新手用来学习接触.根据书上的引导,学习Redis需要首先要安装Redis.我在安装Redis的过程中遇到了许多问题,由于我的的电脑是Windows64的,也没有POSIX系统和OS X系统的机子,于是就只能在Windows环境下安装,根据书上所说,需要先安装Cygwin(Cygwin能够在Windows环境下模拟Linux系统环境).鼓捣

fabric安装学习教程

fabric 是一个python的库,fabric可以通过ssh批量管理服务器.在学习fabric之前,安装fabric是我们的第一步.如何安装呢? 第一步安装依赖包 安装epel源 安装fabric依赖及pip 第二步安装fabric 第三步 测试安装及简单使用 测试安装是否成功 显示出版本说明安装成功 简单使用 编写fabfile; vim host_type.py 使用fab 在本地执行刚才定义的host_type 至此fabric简单安装及使用到此为止 fabric好用之处就是你可以编写