`
hongsoft
  • 浏览: 292382 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

shark工作流源代码学习(三)

阅读更多

怎么使用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>

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics