Java

本类阅读TOP10

·使用MyEclipse开发Struts框架的Hello World!(录像1)
·hibernate配置笔记
·AOP编程入门--Java篇
·linux下Tomcat 5.0.20 与 Apache 2 安装/集成/配置
·在win2003下整合了整合Tomcat5.5+ apache_2.0.53+ mod_jk_2.0.47.dll
·构建Linux下IDE环境--Eclipse篇
·Jsp 连接 mySQL、Oracle 数据库备忘(Windows平台)
·ASP、JSP、PHP 三种技术比较
·Tomcat5.5.9的安装配置
·AWT GUI 设计笔记(二)

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
shark工作流源代码学习(三)

作者:未知 来源:月光软件站 加入时间:2005-2-28 月光软件站

怎么使用Shark

 

前面写了两篇Shark源代码分析的文章,但有很多同行来信讨论的是怎么使用Shark,所以这篇先用Shark的源代码来讨论怎么使用Shark的问题

 

Shark的使用有两种方式:作为Corba服务和调用API。实际上,在我们安装Shark安装版后,根目录下有多个批处理文件,其中runAll.bat就是将它作为Corba服务启动,runSA就是将它作为调用API,如下:

runAll.bat如下

{        @echo off

cd D:\Program Files\Shark-1.0

 

find "nameserverhost" < Shark.conf > nshost.txt

for /F "tokens=1,2* delims==" %%i in (nshost.txt) do SET NS_HOST=%%j

del nshost.txt>nul

 

find "nameserverport" < Shark.conf > nsport.txt

for /F "tokens=1,2* delims==" %%i in (nsport.txt) do SET NS_PORT=%%j

del nsport.txt>nul

 

set OLDCLASSPATH=%CLASSPATH%

set CLASSPATH=

 

//启动名字服务

start "Name Server" "D:\j2sdk1.4.2\bin\tnameserv" -ORBInitialPort 10123

//启动Shark服务器

start "Shark Server" "D:\j2sdk1.4.2\bin\java" -Djava.ext.dirs=lib org.enhydra.shark.corba.SharkCORBAServer Shark.conf

//启动管理控制台

start "Shark Admin" "D:\j2sdk1.4.2\bin\java" -jar lib\sharkcorbaadmin.jar

 

set CLASSPATH=%OLDCLASSPATH%

 

}

runSA.bat如下:

{

  @echo off

cd D:\Program Files\Shark-1.0

set OLDCLASSPATH=%CLASSPATH%

set CLASSPATH=

start "Shark Admin" "D:\j2sdk1.4.2\bin\java" -Djava.ext.dirs=lib org.enhydra.shark.swingclient.workflowadmin.SharkAdmin

set CLASSPATH=%OLDCLASSPATH%

}

 

源代码分析二讨论的Shark类代表的就是Shark引擎,所以它只需配置一次,代码如下:

// the one and only instance of this class

   private static Shark shark;

   static {

      shark=new Shark();

   }

public static Shark getInstance () {

      if (!isConfigured) {

         throw new Error("Shark need to be configured properly !!!");

      }

      return shark;

   }

从上面的代码看出,Shark.conf()只需调用一次;然后每次访问Shark引擎时只要调用Shark.getInstance()就可以获得Shark的所有功能

 

在服务器Down掉后,重启时要再调用Shark.conf()进行配置;但对XPDL文件的load功能是系统会persistence,它将被保存到数据库中,所以一般对XPDL的处理,我们是做个WEB页面,进行上传,修改和下载等,即便服务器DOWN,也不需要再load流程定义

 

XPDL的处理是我们下篇文章要讨论的问题。

 

作者又名HongSoft,研究领域:1)基于工作流的BPM系统研究2)基于JAVA的信息安全技术.欢迎和大家讨论JAVA相关各方面问题 hongbosoftware@163.com

 

 

 




相关文章

相关软件