[TOC] ###1.pightml
開源地址:https://gitee.com/log4j/pig前端
基於Spring Cloud、OAuth2.0、Vue的先後端分離的系統。 通用RBAC權限設計及其數據權限和分庫分表 支持服務限流、動態路由、灰度發佈、 支持常見登陸方式, 多系統SSO登陸, 提供配套視頻開發教程 vue
功能列表:node
完善登陸:帳號密碼模式、短信驗證碼模式、社交帳號模式均整合Spring security oAuthnginx
單點登陸:基於Srping security oAuth 提供單點登陸接口,方便其餘系統對接git
用戶管理:用戶是系統操做者,該功能主要完成系統用戶配置。github
機構管理:配置系統組織機構,樹結構展示,可隨意調整上下級。web
菜單管理:配置系統菜單,操做權限,按鈕權限標識等。spring
角色管理:角色菜單權限分配、設置角色按機構進行數據範圍權限劃分。docker
動態路由:基於zuul實現動態路由,後端可配置化。
灰度發佈:自定義ribbon路由規則匹配多版本請求。
終端管理:動態配置oauth終端,後端可配置化。
字典管理:對系統中常用的一些較爲固定的數據進行維護,如:是否等。
操做日誌:系統正常操做日誌記錄和查詢;系統異常信息日誌記錄和查詢。
服務限流:多種維度的流量控制(服務、IP、用戶等)
消息總線:配置動態實時刷新
分庫分表:shardingdbc分庫分表策略
數據權限: 使用mybatis對原查詢作加強,業務代碼不用控制,便可實現。
文件系統: 支持FastDFS、七牛雲,擴展API幾行代碼實現上傳下載
消息中心:短信、郵件模板發送,幾行代碼實現發送
聚合文檔:基於zuul實現 swagger各個模塊的實現
代碼生成:先後端代碼的生成,支持Vue
緩存管理:基於Cache Cloud 保證Redis 的高可用
服務監控: Spring Boot Admin
分佈式任務調度: 基於elastic-job的分佈式任務,zookeeper作調度中心
zipkin鏈路追蹤: 數據保存ELK,圖形化展現
pinpoint鏈路追蹤: 數據保存hbase,圖形化展現
###2.zheng
開源地址:https://gitee.com/shuzheng/zheng
基於Spring+SpringMVC+Mybatis分佈式敏捷開發系統架構,提供整套公共微服務服務模塊:集中權限管理(單點登陸)、內容管理、支付中心、用戶管理(支持第三方登陸)、微信平臺、存儲系統、配置中心、日誌分析、任務和通知等,支持服務治理、監控和追蹤,努力爲中小型企業打造全方位J2EE企業級開發解決方案。
###3.Cloud-Platform 開源地址:https://gitee.com/minull/ace-security Cloud-Platform是國內首個基於Spring Cloud微服務化開發平臺,核心技術採用Spring Boot2以及Spring Cloud Gateway相關核心組件,前端採用vue-element-admin組件。具備統一受權、認證後臺管理系統,其中包含具有用戶管理、資源權限管理、網關API管理等多個模塊,支持多業務系統並行開發,能夠做爲後端服務的開發腳手架。代碼簡潔,架構清晰,適合學習和直接項目中使用。
架構摘要 服務鑑權 經過JWT的方式來增強服務之間調度的權限驗證,保證內部服務的安全性。
監控 利用Spring Boot Admin 來監控各個獨立Service的運行狀態;利用Hystrix Dashboard來實時查看接口的運行狀態和調用頻率等。
負載均衡 將服務保留的rest進行代理和網關控制,除了日常常用的node.js、nginx外,Spring Cloud系列的zuul和ribbon,能夠幫咱們進行正常的網關管控和負載均衡。其中擴展和借鑑國外項目的擴展基於JWT的Zuul限流插件,方面進行限流。
服務註冊與調用 基於Consul來實現的服務註冊與調用,在Spring Cloud中使用Feign, 咱們能夠作到使用HTTP請求遠程服務時能與調用本地方法同樣的編碼體驗,開發者徹底感知不到這是遠程方法,更感知不到這是個HTTP請求。
熔斷機制 由於採起了服務的分佈,爲了不服務之間的調用「雪崩」,採用了Hystrix的做爲熔斷器,避免了服務之間的「雪崩」。
###4.SpringBlade
開源地址:https://gitee.com/smallc/SpringBlade SpringBlade 2.0 是一個基於 Spring Boot 2 & Spring Cloud Finchley & Mybatis 等核心技術,用於快速構建中大型系統的基礎框架。
主要特性&&變化
採用先後端分離的模式,前端單獨開源出一個框架:Sword,主要選型技術爲React、Ant Design、Umi、Dva
後端採用SpringCloud全家桶,並同時對其基礎組件作了高度的封裝,單獨開源出一個框架:Blade-Tool
Blade-Tool已推送至Maven中央庫,直接引入便可,減小了工程的臃腫,也可更注重於業務開發
註冊中心選型Consul
部署使用Docker或K8s + Jenkins
使用Traefik進行反向代理
踩了踩Kong的坑,有個基本的使用方案,但不深刻,由於涉及到OpenResty。
封裝了簡單的Secure模塊,採用JWT作Token認證,可拓展集成Redis等細顆粒度控制方案
在2.0誕生以前,已經穩定生產了近一年,經歷了從Camden -> Finchley的技術架構,也經歷了從fat jar -> docker -> k8s + jenkins的部署架構
項目分包明確,規範微服務的開發模式,使包與包之間的分工清晰。
###5.Guns
開源地址:https://gitee.com/stylefeng/guns Guns基於Spring Boot 2,致力於作更簡潔的後臺管理系統,完美整合springmvc + shiro + mybatis-plus + beetl,Guns項目代碼簡潔,註釋豐富,上手容易,同時Guns包含許多基礎模塊(用戶管理,角色管理,部門管理,字典管理等10個模塊),能夠直接做爲一個後臺管理系統的腳手架!同時提供spring cloud版本!
Guns微服務版本
Guns的核心是roses-kernel項目https://gitee.com/stylefeng-Roses/roses-kernel,提供對spring cloud的支持。
Roses框架基於Spring Boot 2和Spring Cloud Finchley.RELEASE,整合Eureka + Hystrix + Ribbon + Feign + Zuul,更符合企業級的分佈式和服務化解決方案,Roses擁有高效率的開發體驗,提供可靠消息最終一致性分佈式事務解決方案,提供基於調用鏈的服務治理,提供可靠的服務異常定位方案(Log + Trace)等等,一個分佈式框架不只須要構建高效穩定的底層開發框架,更須要解決分佈式帶來的種種挑戰!
管理系統功能
1.用戶管理 2.角色管理 3.部門管理 4.菜單管理 5.字典管理 6.業務日誌 7.登陸日誌 8.監控管理 9.通知管理 10.代碼生成(旗艦版目前還沒完成)
項目特色
基於SpringBoot,簡化了大量項目配置和maven依賴,讓您更專一於業務開發,獨特的分包方式,代碼多而不亂。
完善的日誌記錄體系,可記錄登陸日誌,業務操做日誌(可記錄操做前和操做後的數據),異常日誌到數據庫,經過@BussinessLog註解和LogObjectHolder.me().set()方法,業務操做日誌可具體記錄哪一個用戶,執行了哪些業務,修改了哪些數據,而且日誌記錄爲異步執行,詳情請見@BussinessLog註解和LogObjectHolder,LogManager,LogAop類。
利用beetl模板引擎對前臺頁面進行封裝和拆分,使臃腫的html代碼變得簡潔,更加易維護。
對經常使用js插件進行二次封裝,使js代碼變得簡潔,更加易維護,具體請見webapp/static/js/common文件夾內js代碼。
利用ehcache框架對常常調用的查詢進行緩存,提高運行速度,具體請見ConstantFactory類中@Cacheable標記的方法。
controller層採用map + warpper方式的返回結果,返回給前端更爲靈活的數據,具體參見com.stylefeng.guns.modular.system.warpper包中具體類。
防止XSS攻擊,經過XssFilter類對全部的輸入的非法字符串進行過濾以及替換。
簡單可用的代碼生成體系,經過SimpleTemplateEngine可生成帶有主頁跳轉和增刪改查的通用控制器、html頁面以及相關的js,還能夠生成Service和Dao,而且這些生成項都爲可選的,經過ContextConfig下的一些列xxxSwitch開關,可靈活控制生成模板代碼,讓您把時間放在真正的業務上。
控制器層統一的異常攔截機制,利用@ControllerAdvice統一對異常攔截,具體見com.stylefeng.guns.core.aop.GlobalExceptionHandler類。
頁面統一的js key-value單例模式寫法,每一個頁面生成一個惟一的全局變量,提升js的利用效率,而且有效防止多我的員開發引發的函數名/類名衝突,而且能夠更好地去維護代碼。
業務日誌記錄
日誌記錄採用aop(LogAop類)方式對全部包含@BussinessLog註解的方法進行aop切入,會記錄下當前用戶執行了哪些操做(即@BussinessLog value屬性的內容),若是涉及到數據修改,會取當前http請求的全部requestParameters與LogObjectHolder類中緩存的Object對象的全部字段做比較(因此在編輯以前的獲取詳情接口中須要緩存被修改對象以前的字段信息),日誌內容會異步存入數據庫中(經過ScheduledThreadPoolExecutor類)。
#####關注公衆號<font color='red' size='+2'>githubcn</font>,免費獲取更多學習視頻教程