Activiti-01
1, Activiti官网:http://www.activiti.org/ 主页可以看到jar包的下载.
2, 进入http://www.activiti.org/userguide/index.html 用户指导页进行学习研究.
3, 在maven中引入activiti jar 文件的
To include the activiti engine in your project, add following dependency (note that you need to change the version to the latest release):
- <dependency>
- <groupId>org.activiti</groupId>
- <artifactId>activiti-engine</artifactId>
- <version>5.x</version>
- </dependency>
And if you use Activiti with the Spring integration, then your dependencies could look like this:
- <dependency>
- <groupId>org.springframework</groupId>
- <artifactId>spring-context</artifactId>
- <version>spring.version</version>
- </dependency>
- <dependency>
- <groupId>org.springframework</groupId>
- <artifactId>spring-jdbc</artifactId>
- <version>spring.version</version>
- </dependency>
- <dependency>
- <groupId>org.springframework</groupId>
- <artifactId>spring-tx</artifactId>
- <version>spring.version</version>
- </dependency>
4, 如果不使用maven,可以在下载的zip包的libs文件夹中看到所有的jar文件(包括源文件jar)必须的依赖包
- org.activiti:activiti-engine:jar:5.12.1+- org.apache.commons:commons-email:jar:1.2:compile| +- javax.mail:mail:jar:1.4.1:compile| \- javax.activation:activation:jar:1.1:compile+- commons-lang:commons-lang:jar:2.4:compile+- org.mybatis:mybatis:jar:3.1.1:compile+- org.springframework:spring-beans:jar:3.1.2.RELEASE:compile| \- org.springframework:spring-core:jar:3.1.2.RELEASE:compile| +- org.springframework:spring-asm:jar:3.1.2.RELEASE:compile| \- commons-logging:commons-logging:jar:1.1.1:compile\- joda-time:joda-time:jar:2.1:compile
- Note: the mail jars are only needed if you are using the mail service task
- 得到ProcessEngine对象是很容易的,会去classpath中找
activiti.cfg.xml文件.
- ProcessEngine processEngine =ProcessEngines.getDefaultProcessEngine();
- <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
- <bean id="processEngineConfiguration" class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration"> <propertyname="jdbcUrl"value="jdbc:h2:mem:activiti;DB_CLOSE_DELAY=1000"/> <propertyname="jdbcDriver"value="org.h2.Driver"/> <propertyname="jdbcUsername"value="sa"/> <propertyname="jdbcPassword"value=""/> <propertyname="databaseSchemaUpdate"value="true"/> <propertyname="jobExecutorActivate"value="false"/> <propertyname="mailServerHost"value="mail.my-corp.com"/> <propertyname="mailServerPort"value="5025"/> </bean>
- </beans>
5 这是一个基于Spring的xml文件,但是并不意味着它只能在spring中配置
ProcessEngineConfiguration 对象可以使用配置文件创建也可以指定自己的bean名称,如
- ProcessEngineConfiguration.createProcessEngineConfigurationFromResourceDefault();ProcessEngineConfiguration.createProcessEngineConfigurationFromResource(String resource);ProcessEngineConfiguration.createProcessEngineConfigurationFromResource(String resource,String beanName);ProcessEngineConfiguration.createProcessEngineConfigurationFromInputStream(InputStream inputStream);ProcessEngineConfiguration.createProcessEngineConfigurationFromInputStream(InputStream inputStream,String beanName);
所有ProcessEngineConfiguration.createXXX() 方法返回ProcessEngineConfiguration对象,再调用buildProcessEngine()方法即可返回ProcessEngine 对象。
activiti.cfg.xml 必须有一个bean的id为 'processEngineConfiguration'.,这个bean是用来构造ProcessEngine的
<bean id="processEngineConfiguration"
class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration"> ,class可以指定的类
org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration: the process engine is used in a standalone way. Activiti will take care of the transactions. By default, the database will only be checked when the engine boots (and an exception is thrown if there is no Activiti schema or the schema version is incorrect).
org.activiti.engine.impl.cfg.StandaloneInMemProcessEngineConfiguration: this is a convenience class for unit testing purposes. Activiti will take care of the transactions. An H2 in-memory database is used by default. The database will be created and dropped when the engine boots and shuts down. When using this, probably no additional configuration is needed (except when using for example the job executor or mail capabilities).
org.activiti.spring.SpringProcessEngineConfiguration:To be used when the process engine is used in a Spring environment. See the Spring integration section for more information.
org.activiti.engine.impl.cfg.JtaProcessEngineConfiguration: To be used when the engine runs in standalone mode, with JTA transactions.
有两种方式配置Activiti引擎用到的数据库,第一种是jdbc方式
- <propertyname="jdbcUrl"value="jdbc:h2:mem:activiti;DB_CLOSE_DELAY=1000"/><propertyname="jdbcDriver"value="org.h2.Driver"/><propertyname="jdbcUsername"value="sa"/><propertyname="jdbcPassword"value=""/>
The data source that is constructed based on the provided JDBC properties will have the default MyBatis connection pool settings. The following attributes can optionally be set to tweak that connection pool (taken from the MyBatis documentation):
- 基于JDBC属性构造数据源的方式默认使用Mybatis连接池设置,下面属性可以设置调整连接池
jdbcMaxActiveConnections: 最大活动连接数. Default is 10.
jdbcMaxIdleConnections: 空闲连接数
jdbcMaxCheckoutTime: 一个连接在返回之前被检查的时间 . Default is 20000 (20 seconds).
jdbcMaxWaitTime: 这是一个低级设置,一般都是默认不修改 Default is 20000 (20 seconds).
- <bean id="dataSource"class="org.apache.commons.dbcp.BasicDataSource"> <property name="driverClassName"value="com.mysql.jdbc.Driver"/> <property name="url"value="jdbc:mysql://localhost:3306/activiti"/> <property name="username"value="activiti"/> <property name="password"value="activiti"/> <property name="defaultAutoCommit"value="false"/></bean>
- <bean id="processEngineConfiguration"class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration"> <propertyname="dataSource"ref="dataSource"/>
- ...>
- 必须确保数据源的依赖库在classpath中下面属性也应该被设置,无论是jdbc还是data source databaseType: 数据库类型 ,可能的取值 {h2, mysql, oracle, postgres, mssql, db2}
databaseSchemaUpdate: 流程引擎启动关闭时数据库的策略.
false 默认:检查数据库schema版本,在流程引擎创建或抛异常时
- true 在部署流程引擎时,检查数据库schema,不存在就创建
create-drop 在流程引擎创建时创建数据库schema,关闭时删除数据库schema
- 在 activiti-5.13/database下可以看到可以看到具体的sql dll文件
engine: 引擎执行必须的表. Required.
identity: 这些表包含用户,组,用户在组中的身份,是可选的 这些表应该被使用当使用默认的身份管理引擎的装载.
history: 包含历史和审计信息. 可选的,当历史级别设置为none时是不需要的
Activiti数据库都以ACT_开头 .
ACT_RE_*: 'RE' stands for repository. Tables with this prefix contain 'static' information such as process definitions and process resources (images, rules, etc.).
ACT_RU_*: 'RU' stands for
runtime. These are the runtime tables, that contain the runtime data of process instances, user tasks, variables, jobs, etc. Activiti only stores the runtime data during process instance execution, and removes the records when a process instance ends. This keeps the runtime tables small and fast.ACT_ID_*: 'ID' stands for
identity. These tables contain identity information, such as users, groups, etc.ACT_HI_*: 'HI' stands for
history. These are the tables that contain historic data, such as past process instances, variables, tasks, etc.ACT_GE_*:
generaldata, which is used in various use cases.
- 升级数据库需要配置databaseSchemaUpdate为true
- <beans ... >
- <beanid="processEngineConfiguration"class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration"> <!-- ... --> <propertyname="databaseSchemaUpdate"value="true"/> <!-- ... --> </bean>
- </beans>
任务执行器的激活
JobExecutor管理一对线程或者异步消息的组件,以为测试的复杂,被用于多线程。.因此它的api允许(ManagementService.createJobQuery) and执行(ManagementService.executeJob) ,为了避免执行者的冲突,经常被关闭。默认情况, JobExecutor 被激活当引擎启动时.
- <property name="jobExecutorActivate"value="false"/>
当你不想在引擎启动的时候激活JobExecutor ,可以设置上面的值为false
邮件服务配置
为了发送邮件,合法的SMTP 服务器是必须的,将下面属性设置到activiti.cfg.xml
| Property | Required? | Description |
|---|---|---|
| mailServerHost | no | 邮件服务器(e.g. mail.mycorp.com). 默认localhost |
| mailServerPort | yes, if not on the default port | The port for SMTP traffic on the mail server. The default is 25 |
| mailServerDefaultFrom | no | The default e-mail address of the sender of e-mails, when none is provided by the user. By default this is activiti@activiti.org |
| mailServerUsername | 如果适用您的服务器 | Some mail servers require credentials for sending e-mail. By default not set. |
| mailServerPassword | 如果适用您的服务器 | Some mail servers require credentials for sending e-mail. By default not set. |
| mailServerUseSSL | 如果适用您的服务器 | Some mail servers require ssl communication. By default set to false. |
定义邮件任务
- <serviceTask id="sendMail"activiti:type="mail">
邮件任务通过属性注入方式配置,. 所有的属性值都可以包含 EL 表达式,
Table 8.2. Mail server configuration
| Property | Required? | Description |
|---|---|---|
| to | yes | The recipients if the e-mail. Multiple recipients are defined in a comma-separated list |
| from | no | The sender e-mail address. If not provided, the default configured from address is used. |
| subject | no | The subject of the e-mail. |
| cc | no | The cc's of the e-mail. Multiple recipients are defined in a comma-separated list |
| bcc | no | The bcc's of the e-mail. Multiple recipients are defined in a comma-separated list |
| charset | no | Allows to change the charset of the email, which is necessary for many non-English languages. |
| html | no | A piece of HTML that is the content of the e-mail. |
| text | no | The content of the e-mail, in case one needs to send plain none-rich e-mails. Can be used in combination with html, for e-mail clients that don't support rich content. The client will then fall back to this text-only alternative. |
- 邮件任务的例子
- <serviceTaskid="sendMail"activiti:type="mail"> <extensionElements> <activiti:fieldname="from"stringValue="order-shipping@thecompany.com"/> <activiti:fieldname="to"expression="${recipient}"/> <activiti:fieldname="subject"expression="Your order ${orderId} has been shipped"/> <activiti:fieldname="html"> <activiti:expression> <![CDATA[ <html> <body> Hello ${male ? 'Mr.' : 'Mrs.' } ${recipientName},<br/><br/> As of ${now}, your order has been <b>processed and shipped</b>.<br/><br/> Kind regards,<br/> TheCompany. </body> </html> ]]> </activiti:expression> </activiti:field> </extensionElements></serviceTask>
- 历史的配置
- <propertyname="history"value="audit"/>
- 所有的流程定义都会被缓存,下面是设置缓存大小
- <propertyname="processDefinitionCacheLimit"value="10"/>使用的是LRU 算法进行缓存策略
日志
在Activiti 5.12, SLF4J日志框架被使用。所有日志(activiti, spring, mybatis, ...)被使用SLF4J ,允许你选择日志框架的实现
默认这个jar包没有在 activiti-engine中引入,需要自己引入。
- <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-log4j12</artifactId> <version>XXX</version></dependency>
t特别重要,当使用容器commons-logging在classpath时: 为了能够路由spring-logging通过SLF4J, 一个桥要被使用
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>jcl-over-slf4j</artifactId>
</dependency>
Activiti-01的更多相关文章
- Activiti从当前任务任意回退至已审批任务
http://www.verydemo.com/demo_c161_i143918.html import java.util.HashMap; import java.util.Iterator; ...
- 工作流引擎Activiti 专题
https://github.com/Activiti/Activiti Quick Start Guide This quick start assumes: Familiarity with Ma ...
- Activiti动态设置办理人扩展
关键词:Assignee.Candidate users.Candidate groups:setAssignee.taskCandidateUser.taskCandidateGroup 主要解决问 ...
- 手把手教你如何玩转Activiti工作流
手把手教你如何玩转Activiti工作流 置顶 2018年01月30日 19:51:36 Cs_hnu_scw 阅读数:24023 版权声明:本文为博主原创文章,未经博主允许不得转载. https ...
- 工作流Activiti的学习总结(十二) activiti官方十分钟快速学习 (zhuan)
http://topmanopensource.iteye.com/blog/1315341 ***************************************************** ...
- 【应用篇】Activiti外置表单实例demo(四)
在这里我想说的外置表单.是说我们将我们自己的jsp(.form,.html)等页面上传到工作流的数据库中,当任务运行到当前结点时.给我们像前台发送绑定好的表单. 此处是给表单绑定表单的过程 water ...
- 【Activiti学习之五】BPMN事件
环境 JDK 1.8 MySQL 5.6 Tomcat 7 Eclipse-Luna activiti 6.0 一.事件定义1.定时器事件(1)timeDate:指定时间触发<timerEven ...
- 【Activiti工作流引擎】官方快速入门demo
Activiti官方快速入门demo 地址: https://www.activiti.org/quick-start 0. 版本 activiti 5.22.0 JDK 1.8 1. 介绍 这个快速 ...
- Activiti工作流引擎开发系列
Activiti工作流引擎开发系列-01 作者:Jesai 没有伞的孩子,只能光脚奔跑! 前言: 初次接触工作流这个概念是自从2014年11月份开始,当时是由于我的毕业设计需要,还记得当时我毕业设计的 ...
- 01.SQLServer性能优化之----强大的文件组----分盘存储
汇总篇:http://www.cnblogs.com/dunitian/p/4822808.html#tsql 文章内容皆自己的理解,如有不足之处欢迎指正~谢谢 前天有学弟问逆天:“逆天,有没有一种方 ...
随机推荐
- Could not establish trust relationship for the SSL/TLS secure channel 问题解决方法
最近在写一个跟第三方对接的数据同步服务,在本地都没有问题,今天放到生产环境测试报错: System.Net.WebException: The underlying connection was cl ...
- ubuntu下发布asp.net core并用nginx代理之旅
asp.net core 1.0.1发布已有些日子了,怀着好奇的心情体验了把ubuntu下的asp.net core 系统运行环境:ubuntu 16.0.4 for developer 首先搭建.n ...
- Akka(21): Stream:实时操控:人为中断-KillSwitch
akka-stream是多线程non-blocking模式的,一般来说,运算任务提交到另外线程后这个线程就会在当前程序控制之外自由运行了.任何时候如果需要终止运行中的数据流就必须采用一种任务柄(han ...
- 1_NAT模式和桥接模式下的网络配置
相信当你看到这篇文章时,你一定对linux的桥接模式和NAT模式有所了解,所以你应该是能看懂这篇文件的,希望对你有所帮助,figthing ! 一.桥接模式:虚拟机和主机是连在同一个路由下的. ...
- spring学习笔记1
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAATQAAAEBCAIAAAB5VM7WAAAgAElEQVR4nOy9Z3gc13n3zZT3efPESZ
- Javascript中的浅拷贝和深拷贝
很多开发语言中都有浅拷贝和深拷贝的说法,这里简单区分一下它们在Javascript中的区别,以及jQuery中深拷贝的实现. 在谈浅拷贝和深拷贝之前,先要屡清楚Javascript中的按值访问和按引用 ...
- Ubuntu14.04下搭建VPN服务 -pptp
在Ubantu下采用PPTP搭建VPN,优点是配置简单快捷.本教程亲自测试,熟练了在新机器上5分钟搞定VPN. - - - - - - - - - - - - - - - - - - - - - - ...
- Maven生成可以直接运行的jar包的多种方式
Maven可以使用mvn package指令对项目进行打包,如果使用Java -jar xxx.jar执行运行jar文件,会出现"no main manifest attribute, in ...
- SQL Server锁类型
SQL Server锁类型(SQL)收藏 1. HOLDLOCK: 在该表上保持共享锁,直到整个事务结束,而不是在语句执行完立即释放所添加的锁. 2. NOLOCK:不添加共享锁和排它锁,当这个选项生 ...
- LINUX服务器上新增用户名
最近所里的机群停了,需要用老板的服务器跑程序,这里首先得在老板的服务器上新增一些用户名.新增用户名方法如下: 1.利用useradd添加用户名,并指定用户名目录.脚本解释器.用户名 sudo user ...