Spring-boot-activiti
在常用的ERP系统、OA系统的开发中,工作流引擎是一个必不可少的工具。本项目旨在基于Spring boot这一平台,整合业界流行的工作流引擎Activiti,并建立了两个完整的工作流进行演示:请假OA和采购流程。
其中包含的内容如下:
1.不采用activiti自带的用户、角色功能,因为过于简单,转而自行实现一个用户、角色、权限的三级结构,用户到角色,角色到权限均为多对多映射,持久层框架使用mybatis的collection和association标签嵌套实现;
2.使用默认的用户登录后(用户名xiaomi,密码1234),可看到已部署好的两个流程,请假OA和采购流程,其中,请假OA包含了用户任务、排他网关、起始结束事件,较为简单;采购流程除此之外,还使用了异常结束事件、子流程和边界事件的使用;
3.两个流程均包含了待办任务签收、运行流程进度追踪、已运行完流程历史记录查看的功能,运行流程进度在流程图中以红色标注;
4.使用时,将流程数据和业务数据相分离,使用业务号(businessKey)建立关联流程数据和业务数据的桥梁,使其相互可以访问,业务数据的主键即为业务号;
5.本系统所有表单均使用普通表单,而不是activiti的动态表单和外置表单,这样做是为了分表存放业务数据和流程数据;
7.起始页面入口:http://localhost:8080/login
使用前,编译(可直接在myeclipse完成):
mvn clean install
9.效果图:
附录:中央技术储备仓库(Central Technique Reserve Repository)
基础篇:职业化,从做好OA系统开始
中级篇:中间件的各种姿势
高级篇:架构之美
Spring boot整合Apache dubbo v2.7.5实现分布式服务治理(SOA架构)
包含组件Spring boot v2.2.2+Dubbo v2.7.5+Nacos v1.1.1
效果图
使用Spring Cloud Alibaba v2.1.0实现微服务架构(MSA架构)
包含组件Nacos+Feign+Gateway+Ribbon+Sentinel+Zipkin
效果图
使用jenkins+centos+git+maven搭建持续集成环境自动化部署分布式服务
使用docker+compose+jenkins+gitlab+spring cloud实现微服务的编排、持续集成和动态扩容
使用FastDFS搭建分布式文件系统(高可用、负载均衡)
搭建高可用nginx集群和Tomcat负载均衡
使用mycat实现Mysql数据库的主从复制、读写分离、分表分库、负载均衡和高可用
特别篇:分布式事务和并发控制
基于可靠消息最终一致性实现分布式事务(activeMQ)
Spring boot dubbo整合seata实现分布式事务
包含组件nacos v1.1.0 + seata v0.7.1 +spring boot dubbo v2.7.5
效果图
Spring cloud alibaba v2.1.0整合seata实现分布式事务
包含组件nacos v1.1.0 + seata v0.7.1 +spring cloud alibaba v2.1.0
效果图
并发控制:数据库锁机制和事务隔离级别的实现
并发控制:使用redis实现分布式锁
并发控制:使用zookeeper实现分布式锁
并发控制:Java多线程编程实例
并发控制:使用netty实现高性能NIO通信
视频演示&PPT讲解
第一讲:技术架构演进史和分布式系统
第二讲 分布式服务治理(SOA和微服务)的搭建方法
第三讲:分布式事务的原理和实现(事务消息、TCC、seata)
第四讲:消息队列的使用讲解(activeMQ、rabbitMQ,kafka)
第五讲:分布式锁的三种实现(zookeeper、mysql、redis)
第六讲:elastic search全文检索和大数据分析的实现(ELK平台)
第七讲:分布式缓存redis、文件系统(fastdfs,hdfs)、数据库(mycat,hbase)和负载均衡(nginx)的原理介绍
购买入口