当前位置:首页 > 开发 > 编程语言 > 编程 > 正文

构建自己的Wrapper应用

发表于: 2013-07-31   作者:g21121   来源:转载   浏览:
rap
摘要:         我们已经了解Wrapper的目录结构,下面可是正式利用Wrapper来包装我们自己的应用,这里假设Wrapper的安装目录为:/usr/local/wrapper。           首先,创建项目应用   &nb

        我们已经了解Wrapper的目录结构,下面可是正式利用Wrapper来包装我们自己的应用,这里假设Wrapper的安装目录为:/usr/local/wrapper。

 

        首先,创建项目应用

 

        1.创建一个Java项目,并创建Java 类HelloWorld,并实现WrapperListener 接口,代码如下:

package com.helloworld.hello;

import org.apache.log4j.Logger;

public class HelloWorld {
    
    static Logger logger=Logger.getLogger(HelloWorld.class);

    public static void main(String[] args) {
        logger.info("Hello World!");
    }

}

 

 

        代码很简单只是作为实例作用,这里引用了log4j 是为了展示在项目有依赖类库的情况下如何使用Wrapper 进行包装。

 

        2.导入相应log4j 的jar 包到classpath 或工程build path 下。


        3.将工程导出为Jar 包形式:
        (1)在工程名上右键 -->Export -->JAR file 导出为hello.jar。
        注:选择可运行Jar 导出时会将程序所依赖的相关类包含在Jar 中一并导出,这样做的好出就是不再需要添加额外的依赖类库,直接将此Jar包发布即可,缺点也很明显依赖关系严重不利于升级维护。
        (2)更多的情况是直接按普通jar 包导出,然后在classpath 中添加相关依赖类库,这样更加便于维护,我们将按此种方式举例,导出名为hello.jar。

 

        其次,上传Wrapper相关文件

 

        1.上传程序及依赖:
        (1)上传hello.jar 与依赖类库至服务器wrapper 所在lib 目录.
        (2)上传Wrapper lib 目录下的wrapper.jar和libwrapper.so 至服务器/usr/local/wrapper/lib 目录。

        2.上传wrapper 主程序:
        (1)上传Wrapper bin 目录下的wrapper 文件至服务器/usr/local/wrapper/bin目录。
        (2)上传Wrapper src/bin 目录下的sh.script.in 文件至服务器/usr/local/wrapper/bin 目录,并修改文件名称为:hello,去掉".script.in"后缀。

 

        3.上传Wrapper conf 目录下的wrapper.conf 文件至服务器/usr/local/wrapper/conf目录。

 

        最后,修改相关配置文件内容


        1.修改bin 目录下的hello 文件内容,利用vi 打开发现内容有将近2千行,其实不必担心,我们只需要改文件头部的配置信息即可,内容如下:

# 应用名称
APP_NAME="hello"
# 应用全名
APP_LONG_NAME="helloWorld"

# Wrapper主程序所在目录及名称
WRAPPER_CMD="./wrapper"
# 配置文件所在目录及名称
WRAPPER_CONF="../conf/wrapper.conf"

 

 

        2.修改conf 目录下的wrapper.conf 文件内容。
        (1)找到"wrapper.java.command=java" 这行(43行),可以根据服务器配置修改为"wrapper.java.command=%JAVA_HOME%/bin/java"
        (2)找到"wrapper.java.mainclass=org.tanukisoftware.wrapper.test.Main" 这行(56行),这是程序的入口即main函数所在类,修改成"com.helloworld.hello.HelloWorld"
        (3)找到"wrapper.java.classpath.1=../lib/wrappertest.jar"这行(60,61行),这行表示依赖jar包的位置,作用类似于build path或classpath,我们可以按照顺序依次添加我们所依赖的jar包,需要注意的是序号必须以"1"为起始,添加完成之后如下:

wrapper.java.classpath.1=../lib/hello.jar
wrapper.java.classpath.2=../lib/wrapper.jar
wrapper.java.classpath.3=../lib/log4j-1.2.17.jar
wrapper.java.classpath.4=../lib/slf4j-api-1.7.5.jar
wrapper.java.classpath.5=../lib/slf4j-log4j12-1.7.5.jar

 

        甚至你可以直接修改为:

wrapper.java.classpath.1=../lib/*.jar

 

        来加载lib目录下的所有jar包。

 

        (4)找到"wrapper.java.library.path.1=../lib"这行(64行),这是lib所在目录可以根据情况修改。

 

        至此所有配置文件的基本修改已经完成,输入以下命令来启动我们的程序:

root@TFS:/usr/local/wrapper/bin# ./hello console
Running helloWorld...
wrapper  | --> Wrapper Started as Console
wrapper  | Java Service Wrapper Community Edition 64-bit 3.5.20
wrapper  |   Copyright (C) 1999-2013 Tanuki Software, Ltd. All Rights Reserved.
wrapper  |     http://wrapper.tanukisoftware.com
wrapper  | 
wrapper  | Launching a JVM...
wrapper  | JVM exited while loading the application.
jvm 1    | <helloWorld>:<INFO>:2013-07-30 16:45:43 com.helloworld.hello.HelloWorld.main(HelloWorld.java:13): Hello World!
wrapper  | Launching a JVM...
wrapper  | JVM exited while loading the application.
jvm 2    | <helloWorld>:<INFO>:2013-07-30 16:45:47 com.helloworld.hello.HelloWorld.main(HelloWorld.java:13): Hello World!
wrapper  | Launching a JVM...
wrapper  | JVM exited while loading the application.
jvm 3    | <helloWorld>:<INFO>:2013-07-30 16:45:52 com.helloworld.hello.HelloWorld.main(HelloWorld.java:13): Hello World!
wrapper  | Launching a JVM...
wrapper  | JVM exited while loading the application.
jvm 4    | <helloWorld>:<INFO>:2013-07-30 16:45:57 com.helloworld.hello.HelloWorld.main(HelloWorld.java:13): Hello World!
wrapper  | Launching a JVM...
wrapper  | JVM exited while loading the application.
jvm 5    | <helloWorld>:<INFO>:2013-07-30 16:46:01 com.helloworld.hello.HelloWorld.main(HelloWorld.java:13): Hello World!
wrapper  | There were 5 failed launches in a row, each lasting less than 300 seconds.  Giving up.
wrapper  |   There may be a configuration problem: please check the logs.
wrapper  | <-- Wrapper Stopped

 

        得到以上提示说明程序已经运行成功了,但是我们发现最终Wrapper 还是由于报错而退出了,并且提示我们可能是配置问题,而且我们看到居然启动了5个jvm 线程。

 

        接下来修改上面的代码,让HelloWorld 类实现WrapperListener 接口,修改后的代码如下:

package com.helloworld.hello;

import org.tanukisoftware.wrapper.WrapperListener;
import org.tanukisoftware.wrapper.WrapperManager;

public class HelloWorld implements WrapperListener {

    public static void main(String[] args) {
        // 打印参数
        for (String arg : args)
            System.out.println(arg);
        WrapperManager.start(new HelloWorld(), args);
    }

    @Override
    public void controlEvent(int event) {
        System.out.println("controlEvent(" + event + ")");
        if ((event == WrapperManager.WRAPPER_CTRL_LOGOFF_EVENT) && (WrapperManager.isLaunchedAsService() || WrapperManager.isIgnoreUserLogoffs())) {
        } else {
            WrapperManager.stop(0);
        }
    }

    @Override
    public Integer start(String[] args) {
        // 打印参数
        for (String arg : args)
            System.out.println(arg);
        System.out.println("hello world!");
        return null;
    }

    @Override
    public int stop(int exitCode) {
        System.out.println("stop(" + exitCode + ")");
        return exitCode;
    }

}

 

 

        然后再运行服务,显示如下结果:

root@TFS:/usr/local/wrapper/bin# ./hello console
Running helloWorld...
wrapper  | --> Wrapper Started as Console
wrapper  | Java Service Wrapper Community Edition 64-bit 3.5.20
wrapper  |   Copyright (C) 1999-2013 Tanuki Software, Ltd. All Rights Reserved.
wrapper  |     http://wrapper.tanukisoftware.com
wrapper  | 
wrapper  | Launching a JVM...
jvm 1    | g21121
jvm 1    | http://286.iteye.com/
jvm 1    | WrapperManager: Initializing...
jvm 1    | g21121
jvm 1    | http://286.iteye.com/
jvm 1    | hello world!
jvm 1    | stop(0)
wrapper  |

 

        这样的结果应该是我们想要的,但是两者有什么不同呢?WrapperManager的作用又是什么,为什么会用到它?下篇文章我们仔细分析一下Wrapper的高级应用及配置。

构建自己的Wrapper应用

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

编辑推荐
将一个简单的程度如HelloWorld 的应用包装秤Wrapper 服务并不复杂,甚至可以认为非常简单。但是实际
将一个简单的程度如HelloWorld 的应用包装秤Wrapper 服务并不复杂,甚至可以认为非常简单。但是实际
  上篇跟大家聊了聊maven的简单使用,之前也写了一篇搭建基于SSI(struts2,spring,ibatis)的ja
原文地址:http://twaver.servasoft.com/?p=2908 随着网络和手持终端的迅猛发展,地理数据相关的应用
图形1: 在你当前的操作系统中用模拟器运行其他操作系统 介绍: 我认为成为专业程序员最重要的一个方
文章翻译自:www.codeproject.com 原作者:Shalom Keller. 关键字:Building your own operating sy
构建自己的个人信息资料库 金旭亮 (ver 2.0 更新时间:2013-8-21) 作为一名软件开发者,比较命苦
希望这篇文章能够对那些正在或即将开发自己团队的J2EE应用快速开发平台的个人或公司能有所启发! 像
装过Android版的Facebook、lastfm的同学是否对于这些应用的功能感到惊喜,它们可以定期更新朋友的最
装过Android版的Facebook、lastfm的同学是否对于这些应用的功能感到惊喜,它们可以定期更新朋友的最
版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号