/berg-cloud

Spring Cloud示例项目

Primary LanguageJava

#Spring Cloud示例项目

  • 包含中间件,基础后台系统业务逻辑,授权管理,文件管理
  • 网管鉴权,feign服务调用,admin监控

目录结构

├── admin 监控服务
├── common 公共应用
│ ├─ all-common 公共应用所有引用
│ ├─ base-application 基础服务应用
│ ├─ kafka 消息队列
│ ├─ minio 文件
│ ├─ redis 缓存
│ ├─ util 工具
│ ├─ validator 自定义校验工具
│ └─ xxl-job 分布式任务调度
├── dao 数据交互
│ ├─ all-dao 数据交互所有引用
│ ├─ base-dao 基础数据交互引用
│ ├─ log-dao 日志数据交互引用
│ └─ system-dao 后台系统数据交互
├── generator 代码生成
│ ├─ base-generator 基础代码生成引用
│ └─ generator-modules 代码生成模块
├── manager 公共管理层
│ ├─ api feign调用
│ ├─ log 日志应用
│ ├─ request 请求应用
│ └─ system-auth 后台服务授权
├── model 公共实体层
│ ├─ all-model 所有实体引用
│ ├─ mapstruct 实体映射层
│ └─ vo 表现层对象
├── modules 业务模块层
│ ├─ gateway 网关服务
│ └─ system 后台服务
├── system 后台服务
└── sql 数据脚本

服务划分

名称 定义 端口 workerId
admin 监控服务 30000
gateway 网关 40000 0
system 后台服务 42000 1
  • 使用分布式id生成需配置workerId和datacenterId,需保证每个服务workerId和datacenterId组合均不一致,docker容器初始化时workerId为默认设置,datacenterId则根据端口号生成,如40001的datacenterId即为1,以此规则命名

Docker环境搭建

应用 获取 运行
redis docker pull redis docker run --restart=always -d --name redis -p 6379:6379 -v /etc/localtime:/etc/localtime redis redis-server --appendonly yes --requirepass "密码"
minio docker pull minio/minio docker run --restart=always --name minio -d -p 9000:9000 -e "MINIO_ACCESS_KEY=账号" -e "MINIO_SECRET_KEY=密码" -v /mnt/data:/data -v /mnt/config:/root/.minio minio/minio server /data
zookeeper docker pull wurstmeister/zookeeper docker run --restart=always -d --name zookeeper -p 2181:2181 wurstmeister/zookeeper
kafka docker pull wurstmeister/kafka docker run -d --name kafka -p 9092:9092 --link zookeeper --env KAFKA_ZOOKEEPER_CONNECT=zookeeper:2181 -e KAFKA_ADVERTISED_HOST_NAME=IP地址(服务器为内网) -e KAFKA_ADVERTISED_PORT=9092 -v /etc/localtime:/etc/localtime wurstmeister/kafka
nacos docker pull nacos/nacos-server:1.3.0 docker run --restart=always -d --name nacos -p 8848:8848 -e MODE=standalone -e SPRING_DATASOURCE_PLATFORM=mysql -e MYSQL_SERVICE_HOST=IP地址 -e MYSQL_SERVICE_PORT=端口 -e MYSQL_SERVICE_USER=用户名 -e MYSQL_SERVICE_PASSWORD=密码 -e MYSQL_SERVICE_DB_NAME=数据库名称 nacos/nacos-server:1.3.0
xxl-job-admin docker pull xuxueli/xxl-job-admin:2.2.0 docker run --restart=always -d --name xxl-job-admin -p 8080:8080 -v /tmp:/data/applogs -e PARAMS="--spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver --spring.datasource.url=jdbc:mysql://IP地址:端口号/xxl_job?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true&serverTimezone=Asia/Shanghai --spring.datasource.username=数据库账号 --spring.datasource.password=数据库密码 --xxl.job.login.username=登录账号 --xxl.job.login.password=登录密码" xuxueli/xxl-job-admin:2.2.0
seata docker pull seataio/seata-server docker run --restart=always -d --name seata -p 8091:8091 seataio/seata-server
  • 生产环境IDEA链接Docker开放端口2375请配置好ca证书
  • docker run添加--cap-add=SYS_PTRACE参数解决无法使用JVM命令问题

预设初始账号密码

  • redis

    密码:

  • Spring Boot Admin

    账号:admin 密码:admin

  • minio

    账号:admin 密码:12345678

相关环境及技术栈

  • JDK:Java 8
  • 容器化部署工具:Docker
  • 数据库:MySQL
  • 服务框架:Spring Cloud,Spring Boot
  • 监控组件:Spring Boot Admin
  • 网关组件:Gateway
  • 容错组件:Hystrix
  • 服务调用组件:Feign
  • 负载均衡组件:Ribbon
  • 服务注册与配置中心组件:Nacos
  • 缓存:Redis
  • 消息队列:Kafka
  • 协调服务:Zookeeper
  • 定时任务:xxl-job
  • 分布式事务:Seata
  • 文件服务:Minio
  • 鉴权:Shiro+JWT
  • Mybatis插件:Mybatis Plus
  • 分页插件:PageHelper
  • 多数据源组件:Dynamic Datasource
  • 接口文档组件:knife4j
  • JDBC组件:Druid
  • 公共工具组件:Hutool
  • 验证组件:Hibernate Validator
  • Excel工具:EasyExcel
  • 高性能实体映射工具:MapStruct

api使用

feign:
 hystrix:
   enabled: true

hystrix:
 command:
   default:
     execution:
       timeout:
         enabled: true
       isolation:
         thread:
           timeoutInMilliseconds: 700000
           
ribbon:
 ReadTimeout: 300000
 ConnectTimeout: 300000
 MaxAutoRetries: 0
 MaxAutoRetriesNextServer: 0
 eureka:
    enabled: false