# berg-cloud **Repository Path**: Nyberg/berg-cloud ## Basic Information - **Project Name**: berg-cloud - **Description**: Spring Cloud示例项目 - **Primary Language**: Java - **License**: Not specified - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2021-01-26 - **Last Updated**: 2021-04-08 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README #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](https://baomidou.com/guide/) * 分页插件:PageHelper * 多数据源组件:Dynamic Datasource * 接口文档组件:knife4j * JDBC组件:Druid * 公共工具组件:[Hutool](https://www.hutool.cn/docs/#/) * 验证组件:Hibernate Validator * Excel工具:[EasyExcel](https://www.yuque.com/easyexcel/doc/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 ```