本人新浪微博:http://weibo.com/guoyunsky
最近要写一个独立的Java程序去监控Hadoop和Oozie,通过Shell去调用.写代码到现在也4年多了,貌似就从来没在生产环境中写过一个独立的Java程序,不是部署到Tomcat就是直接丢给Hadoop.于是参考Hadoop等开源环境,自己写了一个demo,并且可以通过Ant打包生成可运行的程序.所以这里有三步:Java程序,Shell,Ant
1.首先建立Java程序,由于是例子,所以这里很简单,只是输出传入参数的个数,代码如下:
package com.guoyun.study.shell; public class ShellJavaAnt { /** * @param args */ public static void main(String[] args) { System.out.println("arguments length:"+args.length); } }
2.Shell脚本
#!/bin/bash # PRG="${0}" while [ -h "${PRG}" ]; do ls=`ls -ld "${PRG}"` link=`expr "$ls" : '.*-> \(.*\)$'` if expr "$link" : '/.*' > /dev/null; then PRG="$link" else PRG=`dirname "${PRG}"`/"$link" fi done BASEDIR=`dirname ${PRG}` BASEDIR=`cd ${BASEDIR}/..;pwd` if test -z ${JAVA_HOME} then JAVA_BIN=java else JAVA_BIN=${JAVA_HOME}/bin/java fi CLASS_PATH=$BASEDIR/shell-run-java-by-ant-*.jar SERVICE_CLASS="com.guoyun.study.shell.ShellJavaAnt" ${JAVA_BIN} -cp $CLASS_PATH ${SERVICE_CLASS} "${@}" exit 0
3.ANT
<project name="shell-run-java-by-ant" default="release-jar" basedir="."> <property file="build.properties" /> <property name="jar.name" value="shell-run-java-by-ant" /> <property name="version" value="0.1" /> <property name="package.name" value="${jar.name}-${version}" /> <property name="build.dir" location="build" /> <property name="build.cache.dir" location="${build.dir}/cache" /> <property name="build.lib.dir" location="${build.dir}/lib" /> <property name="javadoc.dir" location="javadoc" /> <property name="dist.dir" location="dist" /> <property name="dist.java.dir" location="${dist.jar}/java" /> <property name="package.dir" location="${dist.dir}/${package.name}" /> <property name="tar.file" location="${dist.dir}/${jar.name}-${version}.tar.gz" /> <property name="src.dir" location="src" /> <property name="java.src.dir" location="${src.dir}/java" /> <property name="test.src.dir" location="${src.dir}/test" /> <property name="classes.dir" location="${build.dir}/classes" /> <property name="lib.dir" value="${basedir}/lib"/> <property name="script.dir" value="${basedir}/script"/> <target name="release" description="sets properties for release builds."> <echo message="Building in release mode..."/> <property name="compile.mode" value="release"/> <property name="java.debug" value="false"/> </target> <target name="init"> <tstamp/> <mkdir dir="${build.dir}" /> <mkdir dir="${classes.dir}" /> </target> <macrodef name="compile-source"> <sequential> <javac srcdir="${java.src.dir}" destdir="${classes.dir}" debug="${java.debug}" debuglevel="lines,vars,source"> <classpath> <fileset dir="lib"> <include name="**/*.jar"/> </fileset> </classpath> </javac> </sequential> </macrodef> <target name="compile" depends="init" description="compile the source"> <compile-source /> </target> <target name="jar" depends="compile"> <delete file="${build.dir}/${jar.name}-${version}.jar"/> <jar jarfile="${build.dir}/${jar.name}-${version}.jar"> <fileset dir="${classes.dir}"/> </jar> </target> <target name="package" depends="clean, jar"> <mkdir dir="${package.dir}"/> <mkdir dir="${package.dir}/lib"/> <mkdir dir="${package.dir}/bin" /> <copy todir="${package.dir}/lib" includeEmptyDirs="false"> <fileset dir="${lib.dir}"> <include name="**/*" /> </fileset> </copy> <copy todir="${package.dir}"> <fileset file="${build.dir}/${jar.name}-${version}.jar"/> </copy> <copy todir="${package.dir}/" file="build.xml"/> <copy todir="${package.dir}/bin" includeEmptyDirs="false"> <fileset dir="${basedir}/script/shell"> <include name="**/*" /> </fileset> </copy> <chmod file="${package.dir}/bin/*" perm="ugo+rx"/> </target> <target name="tar" depends="package" description="Create release tarball"> <tar compression="gzip" longfile="gnu" destfile="${tar.file}"> <tarfileset dir="${package.dir}" mode="777" prefix="${package.name}"> <exclude name="bin/*" /> <exclude name="**/*.sh" /> <include name="**" /> </tarfileset> <tarfileset dir="${package.dir}" mode="777" prefix="${package.name}"> <include name="**/*.sh" /> </tarfileset> </tar> <delete dir="${package.dir}" /> </target> <target name="javadoc" depends="compile" description="generate documentation" > <delete dir="${javadoc.dir}" /> <javadoc destdir="${javadoc.dir}"> <fileset dir="${java.src.dir}" /> <classpath> <fileset dir="${lib.dir}"> <include name="**/*.jar"/> </fileset> </classpath> </javadoc> </target> <target name="release-jar" description="Build release and jar" depends="release,jar"/> <target name="clean" description="clean up"> <delete dir="${build.dir}"/> <delete dir="${classes.dir}" /> <delete dir="${dist.dir}"/> </target> </project>
由于比较简单,这里就不多做注释,完整例子,请见附件.使用的话,只要进入你的工程,运行ant package,便会将程序打包到$YOUR_PROJECT/dist目录下.之后进入该程序运行bin/shell-java-ant a b c d e f g,就会得到arguments length:7
这样子的输出.
更多技术文章、感悟、分享、勾搭,请用微信扫描:
相关推荐
Umi-OCR-main.zip
基于springboot+Web的毕业设计选题系统源码数据库文档.zip
基于springboot校外兼职教师考勤管理系统源码数据库文档.zip
58商铺全新UI试客试用平台网站源码
基于springboot大学生就业信息管理系统源码数据库文档.zip
基于SpringBoot的口腔诊所系统源码数据库文档.zip
数据存放网盘,txt文件内包含下载链接及提取码,永久有效。失效会第一时间进行补充。样例数据及详细介绍参见文章:https://blog.csdn.net/T0620514/article/details/143956923
3-240P2162218.zip
网络安全 基于Qt创建的Linux系统下的浏览器.zip
C++ 类和对象:多态-练习题目2(制作咖啡和茶叶)
基于springboot+J2EE在线项目管理与任务分配中的应用源码数据库文档.zip
简介本项目提供了一个在51单片机上运行的简单操作系统,旨在帮助学习者深入理解操作系统的基本原理和任务调度机制。该操作系统通过汇编和C语言编写,实现了任务调度、中断处理等核心功能,并提供了详细的源代码和注释,方便学习和实践。
本文将深度卷积神经网络(CNN)设计实现一个复杂结构的生成模型,旨在通过多阶段的编码器-解码器结构,能够有效地将灰度图像转换为彩色图像。最后,本文将实现一个简单的Web应用,用户可以通过上传灰度图像,应用会使用预训练的Caffe模型对其进行颜色化,并将结果返回给用户。 1.模型设计:模型由多个卷积层、ReLU激活函数和批归一化层组成,通过前向传播函数将输入的灰度图像(L通道)转换为彩色图像(ab通道)。如果指定了 pretrained=True,则会自动下载并加载预训练的模型权重。 2. 系统通过Flask框架提供了一个Web应用,用户可以上传灰度图像,系统会自动将其转换为彩色图像,并在网页上显示结果。整个过程包括文件验证、图像处理、颜色化预测和结果展示,具有较高的实用性和用户体验。
一个JAVA图形化的、联网的五子棋游戏.zip javaweb
KWDB 是一款面向 【AIoT 场景】的【分布式多模数据库】,支持在同一实例同时建立时序库和关系库并融合处理多模数据,具备千万级设备接入、百万级数据秒级写入、亿级数据秒级读取等时序数据高效处理能力,具有稳定安全、高可用、易运维等特点。
页面数量:7页 网页主题:网站模板、酒店网站模板、官方网站模板 网页页面:首页、关于我们、相关服务、服务详情、在线博客、博客详情、在线留言 页面实现元素:加载动画、滚动加载、主题切换、导航栏 、轮播图、图文列表、图片切换、 文字列表、 按钮悬停、图片悬停、表单 实现技术:HTML、CSS 、JQuery 源码样式及js文件均分开存放,所有内容仅供初学者学习参考
内容概要:本文档提供了详细的 Neo4j 安装与配置指南,涵盖 Windows、Linux 和 Mac 系统的安装步骤。具体包括下载、安装、启动服务、修改配置文件(如端口配置、远程访问和内存限制)、设置管理员密码以及基本的 Cypher 查询语言使用方法。同时,还提供了一些常见问题及其解决方案。 适合人群:数据库管理员、软件开发人员、系统管理员。 使用场景及目标:①帮助初学者快速掌握 Neo4j 的安装与配置;②适用于需要搭建和使用图数据库的项目;③为已有用户解决常见问题。 其他说明:本文档不仅包含了基础的安装和配置流程,还提供了实际操作中可能遇到的问题及其解决方法,有助于提高使用者的实际操作能力。
基于SpringBoot+Vue的软件产品展示销售系统源码数据库文档.zip
《书戴嵩画牛》教学课件.pptx
20届智能车 【项目资源】:包含前端、后端、移动开发、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源,毕业设计等各种技术项目的源码。包括C++、Java、python、web、C#、EDA等项目的源码。 【适用人群】:适用于希望学习不同技术领域的初学者或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。