NutzWk 开源企业级Java Web开发框架
https://wizzer.cn/donation 捐赠者列表
前言
本项目发展自2010年,2012年开始用于商业项目,至今已服务于全国各地公司大大小小数百个项目,行业涉及政务、电商、物联网等,随着个人经验积累及从事行业的不同分别发布了1.0至5.0多个版本,每个版本都是完整运行且完全开源免费的,您可以根据项目规模选择不同版本。本项目案例众多,省厅级项目、市级平台、大数据项目、电商平台、物联网平台等等,issues里有部分案例截图,限于篇幅不一一罗列。
我们有强大的后援 —— Nutz 社区支持 https://nutz.cn 及 Nutz 使用手册 https://nutzam.com/core/nutz_preface.html
QQ交流群
- 1群: 68428921
- 2群: 24457628
版本说明
- NutzWk v5.x 微服务版本(分支名:nutzboot-dubbo,微服务dubbo分布式版本)
- NutzWk v4.x 模块化版本(分支名:modular,统一提供代码生成器及IDEA可视化插件)
- NutzWk v3.x 单应用版本(分支名:bootstrap-3.3.x,CMS+微信+系统+权限+常用功能封装 beetl/velocity)
- NutzWk v1.0 传统版(分支名:master,velocity 支持IE6)
本版说明(v5.x)
NutzWk 5.x 运行必备环境:
- JDK 8 181 + 或 OpenJDK 11 +
- Maven 3.5.3 +
- Redis 4.0.8 +
- MySql 5.7 + 或 MariaDB、Oracle、SqlServer、达梦等
- Zookeeper 3.4.11 +
NutzWk 5.x 技术选型:
- 核心框架:Nutzboot
- 分布式框架:Dubbo、Zookeeper、Sentinel
- 安全框架:Shiro
- 任务调度:Quartz
- 数据库连接池:Druid
- 支持数据库:MySql、MariaDB、Oracle、SqlServer、达梦等
- 缓存框架:Redis、Ehcache、Wkcache
- 订阅发布:Redis
- 可扩展功能:WebSocket-Nutz、消息队列-Rabbitmq、搜索引擎-Elasticsearch、工作流-Activiti等
- 前端框架:Bootstrap+JQuery或Vue +Element
NutzWk 5.x 使用说明:
名称 | 介绍 |
---|---|
wk-framework | 一些基类及公共方法的封装 |
wk-model | POJO类 |
wk-common | 接口类 |
wk-nb-service-sys | 系统管理模块,dubbo服务端,NB项目,权限体系 |
wk-nb-service-cms | CMS管理模块,dubbo服务端,NB项目,ig及wkcache演示 |
wk-nb-service-wx | 微信管理模块,dubbo服务端,NB项目,微信及微信支付功能演示 |
wk-nb-task | 定时任务模块,dubbo服务端,NB项目,支持quartz集群 |
wk-nb-web-api | API JWT Token示例,dubbo消费端,NB项目,Mvc |
wk-nb-web-platform | WEB管理后台(可选),dubbo消费端,NB项目,Mvc |
wk-nb-web-vue | WEB管理后台Vue.js混合版(可选),dubbo消费端,NB项目,Mvc |
- 确保 MySql、Redis、Zookeeper 默认端口配置并已启动好
- MySql 创建名为
nutzwk_nb
的空数据库,在每个NB(nutzboot缩写)模块启动时会自动建表,同时初始化数据 - 项目根目录执行
mvn clean install -Dmaven.test.skip=true
- 在单个NB模块下执行
mvn compile nutzboot:run
运行或mvn package nutzboot:shade
生成可执行jar包 - 在项目根目录执行
mvn -Dnutzboot.dst=E:/dst clean package nutzboot:shade
可将所有可运行jar包生成到指定位置 - 启动顺序是 sys --> cms[可选] --> wx[可选] --> task[可选] --> web-platform 或 web-vue --> web-api[可选]
- 正常启动后访问
http://127.0.0.1:8080/sysadmin
用户名 superadmin 密码 1 - 框架详细介绍及代码生成器的使用等内容请仔细阅读 wk-wiki
- 若觉得项目复杂上手较难,可以从最简单的一个NB项目学起 wizzer.cn 源码
项目部署
- 内置配置文件启动
nohup jar -jar wk-nb-service-sys.jar &
带参数-Dnutz.profiles.active=prod
可加载 application-prod.properties 文件 - 外置配置文件启动
nohup jar -Dnutz.boot.configure.properties.dir=/data/nutzwk/sys/ -jar wk-nb-service-sys.jar &
此时加载文件夹所有 *.properties 配置文件 - 生产环境可以使用 PythonWk 进行部署,登陆后台运维中心可在线更新jar包及配置文件等
分布式事务
- 业务走过的链路所有NB模块, pom.xml 添加
<dependency> <groupId>org.nutz</groupId> <artifactId>nutzboot-starter-fescar</artifactId> </dependency> <dependency> <groupId>com.alibaba.fescar</groupId> <artifactId>fescar-dubbo-alibaba</artifactId> <version>${fescar.version}</version> </dependency>
- 业务走过的链路所有NB模块, 配置文件中添加
fescar.enabled=true # applicationId 在本项目中会自动获取无需赋值 # fescar.applicationId= fescar.txServiceGroup=my_test_tx_group
- 下载并启动 fescar服务端
- 业务方法上加上注解
@GlobalTransactional
即可,可选参数timeoutMills = 300000, name = "my_test"
- 与本地事务注解
@Aop(TransAop.READ_COMMITTED)
不冲突 - 业务方法内不要加 try catch (与本地事务注解一样)要让异常抛出来事务才能工作
- 分布式事务不是越多越好,可以在核心业务如交易环节增加,建议实现乐观锁来预防脏数据产生
鸣谢
- @wendal (代码贡献者,技术大牛,Nutz主要作者,无所不知且乐于助人)
- @rekoe (代码贡献者)
- @enilu (3.x 代码生成器及IDEA插件贡献者)
- @loyalove (3.x Vue代码贡献者)
- @threefish (控制类快速定位模板页面IDEA插件贡献者)
- 以及交流群里热心的小伙伴们~ QQ交流群: 24457628
关于
- 本项目完全开源,商用完全免费
- 推荐商业用户打赏500¥以上,支持项目持续发展,以及得到更好的技术支持
- 另外提供付费的培训服务,含源码解析、设计思路、疑难解答、项目辅导等
- 联系方式 QQ:11624317 微信:wizzer
- 欢迎打赏,以资鼓励 https://wizzer.cn/donation
Credits
Contributors
This project exists thanks to all the people who contribute.
Backers
Thank you to all our backers!
Sponsors
Support this project by becoming a sponsor. Your logo will show up here with a link to your website. [Become a sponsor]