/funiture

github: https://github.com/kanwangzjm/funiture, spring项目,权限管理、系统监控、定时任务动态调整、qps限制、sql监控(邮件)、验证码服务、短链接服务、动态配置等

Primary LanguageJava

Funiture

微信公众号

TechDevPro

更多组件代码演练

https://github.com/kanwangzjm/practice

项目需要

  • JDK 1.8及以上
  • Maven 管理jar包
  • Mysql 数据库存储
  • Tomcat 运行用服务器
  • Redis 非必须, 缓存用, 可在配置中调整
  • Rabbit 非必须, 队列用, 可在配置中调整
  • Zookeeper 非必须, 可在配置中打开
  • Lombok, 需要开发环境(IDEA或eclipse)支持

前端 - 只有管理界面

后端 - 各种技术演练

  • 通用的 spring 框架搭建
  • 系统全局配置维护, 能实时刷新内存中最新配置
  • 通用的权限管理系统 - 通过角色维护用户和权限之间的关系
  • 系统监控, 内存、CPU、线程状态、GC情况等
  • 系统服务降级, 临时禁止某些url请求及切流量放行
  • 实时对系统url做QPS控制
  • 系统定时任务调度(Quartz)管理, 动态开启、关闭、调整调度及执行开始结束状态监控
  • 执行系统shell命令
  • 验证码生成、校验
  • redis缓存使用
  • logback, email通知异常
  • mybatis, sql监控(sql中异常, 返回行过多等)
  • 线程池使用, 异步回调, 抛弃请求监控等
  • json(jackson)序列化与反序列化
  • 通用邮件配置及发送
  • 文件上传与管理,md5 计算
  • httpClient 封装, 按需指定各项参数
  • cookie 管理
  • excel XSSFWorkbook(大数据量)使用, 相关报表导出
  • hibernate validator校验
  • threadLocal 管理进程信息, 按需使用
  • Junit 测试
  • RabbitMQ 队列, 生产-消费, 控制台管理
  • zookeeper client 封装
  • 支持多个数据源(aop切面里确定连接串), 根据需要切换数据库
  • 短链接服务, 生成、跳转及过期处理
  • 支持请求使用代理, 及动态选择代理
  • 添加druid监控,使用/acl/druid/index.html访问

其他[必看]

  • 强烈建议使用Intellij IDEA作为开发工具,eclipse需要手动做些设置才能正常使用, 项目启动要加载Resources包括:resources和resource.dev(或prod,区分环境选择)
  • 项目中log基本都使用@Slf4j提供,需要开发工具支持Lombok插件,相关注解包括:@Getter,@Setter,@ToString,@AllArgsConstuctor, @NoArgsConstructor,@Builder
  • 可直接访问 /admin/page.do 进入后台, 用户的密码只是普通做了md5加密,登录细节参考LoginServlet.java里实现

avatar

之后计划

  • 在之前切库的基础上, 做动态切库(分库)操作
  • mybatis层的分表操作, 借助org.shardbatis包的com.google.code.shardbatis.plugin.ShardPlugin
  • 完成主备操作, 借助org.apache.curator包选择zk leader