Skip to content

HelloWorld

架构小郎君 edited this page Jul 7, 2020 · 1 revision

Cloud-Platform

Cloud-Platform是国内首个基于Spring Cloud服务开发平台,具有统一授权、认证后台管理系统,其中包含具备用户管理、资源权限管理、网关API 管理等多个模块,支持多业务系统并行开发,可以作为后端服务的开发脚手架。代码简洁,架构清晰,适合学习和直接项目中使用。 核心技术采用Spring Boot 2.1.2以及Spring Cloud (Greenwich.RELEASE) 相关核心组件,采用Nacos注册和配置中心,集成流量卫兵Sentinel,前端采用vue-element-admin组件,Elastic Search自行集成。

系统架构

image.png


架构详解

监控

利用Spring Boot Admin 来监控各个独立Service的运行状态;利用Hystrix Dashboard来实时查看接口的运行状态和调用频率等。

负载均衡

将服务保留的rest进行代理和网关控制,除了平常经常使用的node.js、nginx外,Spring Cloud系列的zuul和rebbion,可以帮我们进行正常的网关管控和负载均衡。

服务注册与调用

基于Nacos来实现的服务注册与调用,在Spring Cloud中使用Feign, 我们可以做到使用HTTP请求远程服务时能与调用本地方法一样的编码体验,开发者完全感知不到这是远程方法,更感知不到这是个HTTP请求。

熔断机制

因为采取了服务的分布,为了避免服务之间的调用“雪蹦”,我采用了Hystrix的作为熔断器,避免了服务之间的“雪蹦”。


后端工程启动

项目结构

ace-security
    
  ace-modules--------------公共服务模块(基础系统和JWT鉴权、搜索、OSS)
  
  ace-dev-base---------------通用脚手架(基础jwtsdk、开发常用工具类)
   
  ace-gate-----------------网关负载中心
     
  ace-control--------------运维中心(监控、链路)
  
  ace-sidebar--------------调用第三方语言服务

环境须知!

  • mysql一个,redis一个,sentiel一个,nacos注册中心一个
  • jdk1.8
  • IDE插件一个,lombok插件,具体百度即可
  • 搭建

须知

因为Cloud-Platform是一个前后端分离的项目,所以后端的服务必须先启动,在后端服务启动完成后,再启动前端的工程。

最多人问:代码有漏

下载完后端代码后,记得先安装lombok插件,否则你的IDE会报代码缺失。

运行步骤

  • 先启动redis、redis、mysql以及nacos注册中心
  • 运行数据库脚本:依次运行数据库:ace-admin/db/init.sql、ace-auth-server/db/init.sql
  • 依次配置修改并导入nacos注册中心:ace-auth-server/src/main/resources/application.yml、ace-admin/src/main/resources/application.yml、ace-gate/src/main/resources/application.yml
  • 顺序运行main类:AuthBootstrap(ace-auth-server)、AdminBootstrap(ace-admin)、GatewayServerBootstrap(ace-gate)

UI工程启动[Cloud-Admin-UI]点击打开

环境搭建

node 版本:v6.11.2
npm 版本:3.10.10

开发(在UI目录下)

    
    # 安装依赖
    npm install

    ## 若上述不行则采取下面命令
    npm install --registry=https://registry.npm.taobao.org

    # 本地开发 开启服务
    npm run dev

浏览器访问 http://localhost:9527

发布

    # 构建生成环境
    npm run build:prod

目录结构

 build                      // 构建相关  
 config                     // 配置相关
 src                        // 源代码
    api                    // 所有请求
    assets                 // 主题 字体等静态资源
    components             // 全局公用组件
    directive              // 全局指令
    filtres                // 全局filter
    mock                   // mock数据
    router                 // 路由
    store                  // 全局store管理
    styles                 // 全局样式
    utils                  // 全局公用方法
    view                   // view
    App.vue                // 入口页面
    main.js                // 入口 加载组件 初始化等
 static                     // 第三方不打包资源
    Tinymce                // 富文本
 .babelrc                   // babel-loader 配置
 eslintrc.js                // eslint 配置项
 .gitignore                 // git 忽略项
 favicon.ico                // favicon图标
 index.html                 // html模板
 package.json               // package.json

更多文档

https://item.taobao.com/item.htm?id=587275617620
(2019年最新文档,淘宝购买,留言邮箱)

Boot SaaS版

淘宝地址:https://item.taobao.com/item.htm?id=589442411015
体验地址:http://118.126.104.133:81

入门课程

考虑许多码友对于Spring Cloud的前后端分离和微服务实战以及Cloud-Platform有较多的疑问,故本人录制了相关课程

License

Apache License Version 2.0