shark工作流源代码学习(三)
发布时间:2006.03.10 06:14 来源:优快云 作者: 怎么使用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的处理是我们下篇文章要讨论的问题。