怎么使用Shark<!----><o:p></o:p>
<o:p> </o:p>
前面写了两篇Shark源代码分析的文章,但有很多同行来信讨论的是怎么使用Shark,所以这篇先用Shark的源代码来讨论怎么使用Shark的问题。<o:p></o:p>
<o:p> </o:p>
Shark的使用有两种方式:作为Corba服务和调用API。实际上,在我们安装Shark安装版后,根目录下有多个批处理文件,其中runAll.bat就是将它作为Corba服务启动,而runSA就是将它作为调用API,如下:<o:p></o:p>
runAll.bat如下<o:p></o:p>
{ @echo off<o:p></o:p>
cd D:\Program Files\Shark-1.0<o:p></o:p>
<o:p> </o:p>
find "nameserverhost" < Shark.conf > nshost.txt<o:p></o:p>
for /F "tokens=1,2* delims==" %%i in (nshost.txt) do SET NS_HOST=%%j<o:p></o:p>
<!----><st1:state><st1:place>del</st1:place></st1:state> nshost.txt>nul<o:p></o:p>
<o:p> </o:p>
find "nameserverport" < Shark.conf > nsport.txt<o:p></o:p>
for /F "tokens=1,2* delims==" %%i in (nsport.txt) do SET NS_PORT=%%j<o:p></o:p>
<st1:state><st1:place>del</st1:place></st1:state> nsport.txt>nul<o:p></o:p>
<o:p> </o:p>
set OLDCLASSPATH=%CLASSPATH%<o:p></o:p>
set CLASSPATH=<o:p></o:p>
<o:p> </o:p>
//启动名字服务<o:p></o:p>
start "Name Server" "D:\j2sdk1.4.2\bin\tnameserv" -ORBInitialPort 10123<o:p></o:p>
//启动Shark服务器<o:p></o:p>
start "Shark Server" "D:\j2sdk1.4.2\bin\java" -Djava.ext.dirs=lib org.enhydra.shark.corba.SharkCORBAServer Shark.conf<o:p></o:p>
//启动管理控制台<o:p></o:p>
start "Shark Admin" "D:\j2sdk1.4.2\bin\java" -jar lib\sharkcorbaadmin.jar<o:p></o:p>
<o:p> </o:p>
set CLASSPATH=%OLDCLASSPATH%<o:p></o:p>
<o:p> </o:p>
}<o:p></o:p>
runSA.bat如下:<o:p></o:p>
{<o:p></o:p>
@echo off<o:p></o:p>
cd D:\Program Files\Shark-1.0<o:p></o:p>
set OLDCLASSPATH=%CLASSPATH%<o:p></o:p>
set CLASSPATH=<o:p></o:p>
start "Shark Admin" "D:\j2sdk1.4.2\bin\java" -Djava.ext.dirs=lib org.enhydra.shark.swingclient.workflowadmin.SharkAdmin<o:p></o:p>
set CLASSPATH=%OLDCLASSPATH%<o:p></o:p>
}<o:p></o:p>
<o:p> </o:p>
源代码分析二讨论的Shark类代表的就是Shark引擎,所以它只需配置一次,代码如下:<o:p></o:p>
// the one and only instance of this class<o:p></o:p>
private static Shark shark;<o:p></o:p>
static {<o:p></o:p>
shark=new Shark();<o:p></o:p>
}<o:p></o:p>
public static Shark getInstance () {<o:p></o:p>
if (!isConfigured) {<o:p></o:p>
throw new Error("Shark need to be configured properly !!!");<o:p></o:p>
}<o:p></o:p>
return shark;<o:p></o:p>
}<o:p></o:p>
从上面的代码看出,Shark.conf()只需调用一次;然后每次访问Shark引擎时只要调用Shark.getInstance()就可以获得Shark的所有功能。<o:p></o:p>
<o:p> </o:p>
在服务器Down掉后,重启时要再调用Shark.conf()进行配置;但对XPDL文件的load功能是系统会persistence的,它将被保存到数据库中,所以一般对XPDL的处理,我们是做个WEB页面,进行上传,修改和下载等,即便服务器DOWN掉,也不需要再load流程定义。<o:p></o:p>
<o:p> </o:p>
对XPDL的处理是我们下篇文章要讨论的问题。<o:p></o:p>
<o:p> </o:p>
作者又名HongSoft,研究领域:1)基于工作流的BPM系统研究2)基于JAVA的信息安全技术.欢迎和大家讨论JAVA相关各方面问题 hongbosoftware@163.com<o:p></o:p>
<o:p> </o:p>
<o:p> </o:p>
<o:p> </o:p>
分享到:
相关推荐
shark工作流xpdl制作工具,版本jawe1.4.2源代码
shark 开发文档 工作流 代码解释 shark 开发文档 工作流 代码解释
工作流引擎shark的技术分析与改进探讨 转自别人的论文,希望对大家对于shark的使用有所帮助。
Shark工作流解决方案英文版.ppt,详细介绍了shark工作流解决方案
shark工作流实例配置说明.为建购这个workflow的细部流程介绍
学习工作流不可缺少的资源,对于研究xpdl非常难得的资料,现在很难找的资料,
吐血分享 非常全面的jbpm和shark工作流引擎对比
Shark 是 Enhydra 开发的完全基于 WFMC 和 OMG 的标准, 使用 XPDL 来进行定义的工作流引擎。本文通过对其最核 心的工作模块调度方式的研究, 根据各种实际测量的数据详细地从两个方面分析了其作用和各种优缺点, 探讨...
工作流基本概念简介及Shark工作流介绍,Jawe工作流建模及Shark工作流引擎使用说明和一个小例子.公司原来工作流内部培训课件!
Jawe工作流建模及Shark工作流引擎使用说明
从j2ee应用服务器,到o/rmapping工具,到这个工作流引擎等等。为什么Shark的持久层采用DODS来实现?就是因为他们是一家人。 Jbpm的靠山是jboss。Jbpm3的持久层采用hibernate3来实现,也是因为这个原因吧。Jbpm3的...
详细介绍在MyEclipse中如何运行shark源代码程序,包括每一步操作
本文对shark工作流引擎进行了分析介绍,通过对企业办公自动化系统的需求分析.给出了系统的功能模块 结构,详细设计了基于web的工作流管理系统。重点阐述了两个关键系统模块一一公文管理子系统和流程自定义模块的实 ...
shark-1.1-2 是Shark最后的开源工作流源代码,以后再也没有了。学习工作流非常好的资料