设为首页 收藏本站
查看: 383|回复: 0

[经验分享] tomcat + mysql 环境下osworkflow的持久化

[复制链接]

尚未签到

发表于 2016-10-18 07:31:15 | 显示全部楼层 |阅读模式
1、将osworkflow-2.7.0-example.war复制到tomcat_home\webapps下!启动服务后自动部署

2、在mysql中建立数据库,名称osworkflow(各人自定)

3、将mysql的jdbc引擎复制到tomcat_home\common\lib中!

4、在tomcat_homt\conf\Catalina\localhost中建立文件osworkflow-2.7.0-example.xml
      内容如下:
      <?xml version='1.0' encoding='utf-8'?>
<Context path="/osworkflow-2.7.0-example"docBase="osworkflow-2.7.0-example" debug="0" reloadable="true"crossContext="true">
   <Logger className="org.apache.catalina.logger.FileLogger"prefix="localhost_sessiontest_log." suffix=".txt" timestamp="true"/>
    <Environment name="maxExemptions" type="java.lang.Integer" value="15"/>
    <Parameter name="context.param.name" value="context.param.value" override="false"/>
    <Resource name="jdbc/oswf" auth="Container" type="javax.sql.DataSource"/>
    <ResourceParams name="jdbc/oswf">
    <parameter>
      <name>factory</name>
      <value>org.apache.commons.dbcp.BasicDataSourceFactory</value>
    </parameter>
    <parameter>
      <name>maxActive</name>
      <value>100</value>
    </parameter>
    <parameter>
      <name>maxIdle</name>
      <value>30</value>
    </parameter>
    <parameter>
      <name>maxWait</name>
      <value>10000</value>
    </parameter>
    <parameter>
     <name>username</name>
     <value>root</value>
    </parameter>
    <parameter>
     <name>password</name>
     <value></value>
    </parameter>
    <parameter>
       <name>driverClassName</name>
       <value>org.gjt.mm.mysql.Driver</value>
    </parameter>
    <parameter>
      <name>url</name>
      <value>jdbc:mysql://localhost:3306/osworkflow</value>
    </parameter>
</ResourceParams>
</Context>

5、修改tomcat_home\webapps\osworkflow-2.7.0-example\WEB-INF\classes中的下列文件,没有的则新增
(1)、osuser.xml
<opensymphony-user>
     <provider class="com.opensymphony.user.provider.jdbc.JDBCAccessProvider">
         <property name="user.table">OS_USER</property>
         <property name="group.table">OS_GROUP</property>
         <property name="membership.table">OS_MEMBERSHIP</property>
         <property name="user.name">USERNAME</property>
         <property name="user.password">PASSWORDHASH</property>
         <property name="group.name">GROUPNAME</property>
         <property name="membership.userName">USERNAME</property>
         <property name="membership.groupName">GROUPNAME</property>
         <property name="datasource">java:comp/env/jdbc/oswf</property>
     </provider>
     <provider class="com.opensymphony.user.provider.jdbc.JDBCCredentialsProvider">
         <property name="user.table">OS_USER</property>
         <property name="group.table">OS_GROUP</property>
         <property name="membership.table">OS_MEMBERSHIP</property>
         <property name="user.name">USERNAME</property>
         <property name="user.password">PASSWORDHASH</property>
         <property name="group.name">GROUPNAME</property>
         <property name="membership.userName">USERNAME</property>
         <property name="membership.groupName">GROUPNAME</property>
         <property name="datasource">java:comp/env/jdbc/oswf</property>
     </provider>
     <provider class="com.opensymphony.user.provider.jdbc.JDBCProfileProvider">
         <property name="user.table">OS_USER</property>
         <property name="group.table">OS_GROUP</property>
         <property name="membership.table">OS_MEMBERSHIP</property>
         <property name="user.name">USERNAME</property>
         <property name="user.password">PASSWORDHASH</property>
         <property name="group.name">GROUPNAME</property>
         <property name="membership.userName">USERNAME</property>
         <property name="membership.groupName">GROUPNAME</property>
         <property name="datasource">java:comp/env/jdbc/oswf</property>
     </provider>

     
     <!--
Authenticators can take properties just like providers.
  This smart authenticator should work for "most" cases - it dynamically looks up
the most appropriate authenticator for the current server.
-->
<!-- authenticator class="com.opensymphony.user.authenticator.SmartsAuthenticator" /-->
</opensymphony-user>

(2)、osworkflow.xml
<osworkflow>
<!--
     <persistence class="com.opensymphony.workflow.spi.memory.MemoryWorkflowStore"/>
-->
<persistence class="com.opensymphony.workflow.spi.jdbc.MySQLWorkflowStore">
<property key="datasource" value="jdbc/oswf"/>
<property key="entry.sequence"
                       value="select max(id)+1 from OS_WFENTRY"/>
<property key="entry.table" value="OS_WFENTRY"/>
<property key="entry.id" value="ID"/>
<property key="entry.name" value="NAME"/>
<property key="entry.state" value="STATE"/>
<property key="step.sequence"
                        value="select max(ID)+1 from OS_STEPIDS"/>
                        
<property key="step.sequence.increment"
      value="INSERT INTO OS_STEPIDS (ID) values (null)"/>
    <property key="step.sequence.retrieve"
      value="select max(ID) from OS_STEPIDS"/>                        
      
<property key="history.table" value="OS_HISTORYSTEP"/>
<property key="current.table" value="OS_CURRENTSTEP"/>
<property key="historyPrev.table" value="OS_HISTORYSTEP_PREV"/>
<property key="currentPrev.table" value="OS_CURRENTSTEP_PREV"/>
<property key="step.id" value="ID"/>
<property key="step.entryId" value="ENTRY_ID"/>
<property key="step.stepId" value="STEP_ID"/>
<property key="step.actionId" value="ACTION_ID"/>
<property key="step.owner" value="OWNER"/>
<property key="step.caller" value="CALLER"/>
<property key="step.startDate" value="START_DATE"/>
<property key="step.finishDate" value="FINISH_DATE"/>
<property key="step.dueDate" value="DUE_DATE"/>
<property key="step.status" value="STATUS"/>
<property key="step.previousId" value="PREVIOUS_ID"/>
</persistence>     
     <factory class="com.opensymphony.workflow.loader.XMLWorkflowFactory">
         <property key="resource" value="workflows.xml" />
     </factory>
</osworkflow>

(3)、propertyset.xml
<propertysets>
     <propertyset name="jdbc"
       class="com.opensymphony.module.propertyset.database.JDBCPropertySet">
         <arg name="datasource" value="jdbc/oswf"/>
         <arg name="table.name" value="OS_PROPERTYENTRY"/>
         <arg name="col.globalKey" value="GLOBAL_KEY"/>
         <arg name="col.itemKey" value="ITEM_KEY"/>
         <arg name="col.itemType" value="ITEM_TYPE"/>
         <arg name="col.string" value="STRING_VALUE"/>
         <arg name="col.date" value="DATE_VALUE"/>
         <arg name="col.data" value="DATA_VALUE"/>
         <arg name="col.float" value="FLOAT_VALUE"/>
         <arg name="col.number" value="NUMBER_VALUE"/>
     </propertyset>
</propertysets>

红色标记处都是数据库连接设置,全部一样!
蓝色部分必须写上,否则连不上,至少我是这样!呵呵~

启动tomcat以后,进入osworkflow-2.7.0-example,首先创建拥护和组,用户名为test,密码为test,创建组为foos,将用户test分配到foos组中,这样就可以用test用户登陆,并且可以开始运行example流程了!

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-287641-1-1.html 上篇帖子: 在tomcat+mysql下配置jbpm3.3.1 下篇帖子: MySQL数据库中的Show命令具体用法
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表