项目:KCloud-Platform-Alibaba
作者:老寇
语言:Java
职位:Java工程师
时间:2022.06.15 ~ 至今
http://175.178.69.253
系统账号
admin/admin123
test/test123
laok5/test123
系统租户
tenant/tenant123
特此说明,与Spring Boot版本保持一致
🚀 在线用户:强制踢出在线用户
🚀 用户管理:用户信息增删改查(字段隔离&分库分表)(可重置密码)
🚀 角色管理:角色信息增删改查,基于部门的数据权限、角色权限(字段隔离)
🚀 菜单管理:菜单信息增删改查(字段隔离)(自定义菜单图标)
🚀 部门管理:部门信息增删改查(字段隔离)
🚀 日志管理:操作日志、登录日志查询、导出(字段隔离)
🚀 字典管理:字典信息管理(数据库隔离)
🚀 消息管理:消息提醒和消息通知(数据库隔离)
🚀 搜索管理:通过关键字搜索并高亮显示(默认ES)
🚀 流程定义:流程定义、挂起、激活、查看、删除(默认数据库)
🚀 接口文档:Swagger2升级为Open Api Doc 3
🚀 服务监控:服务内存监控及报警
🚀 缓存监控:Redis内存监控
🚀 主机监控:服务器内存或磁盘监控
🚀 存储管理:存储信息增删改查,兼容Amazon S3(数据库隔离)
🚀 租户管理:租户信息增删改查增删改查(默认数据库)
🚀 套餐管理:自定义租户菜单增删改查(默认数据库)
🚀 数据源管理:数据源信息增删改查(默认数据库)
🚀 资源管理:视频、图片、音频信息增删改查,资源审批(Seata AT模式)、处理、转办、委派,审批日志,数据同步(批量同步到ES)(默认数据库)
🚀 用户登录:账号密码、(多租户)、授权码登录(默认数据库)、手机号、邮件(请运行认证模式测试脚本.http)
🚀 统计报表:用户画像(未开发)
🚀 代码生成器:(未开发)
🚀 微信公众号管理:微信公众号一体化管理(未开发)
组件 | 版本 |
---|---|
Spring Boot | 3.0.6 |
Spring Cloud | 2022.0.2 |
Spring Cloud Alibaba | 2022.0.0.0-RC1 |
Spring Boot Admin | 3.0.2 |
Spring Authorization Server | 1.0.2 |
Mybatis Plus | 3.5.3.1 |
Nacos | 2.2.0.1 |
Seata | 1.6.1 |
Sentinel | 1.8.6 |
Mysql | 8.0.31 |
Redis | 7.0.8 |
Elasticsearch | 8.6.2 |
RocketMQ | 5.0.0 |
Flowable | 7.0.0.M1 |
ShardingSphere | 5.3.2 |
OpenResty | 1.21.4.1 |
HBase | 2.5.3 |
- 配置中心&服务注册&发现:Nacos
- API网关:Spring Cloud Gateway
- 认证授权:Spring Security OAuth2 Authorization Server
- 服务消费:Spring Cloud OpenFeign & OkHttp & HttpClient & WebClient
- 负载均衡:Spring Cloud Loadbalancer
- 服务熔断&降级&限流:Sentinel
- 分库分表&读写分离:ShardingSphere
- 分布式事务:Seata
- 消息队列:RocketMQ & Kafka
- 分布式数据库:HBase
- 服务监控:Spring Boot Admin & Prometheus
- 链路跟踪:SkyWalking
- 任务调度:Power Job
- 日志分析:EFK
- 负载均衡:OpenResty
- 多级缓存:Caffeine & Redis
- 统计报表:MongoDB
- 对象存储:Amazon S3
- 服务部署:Docker
- 持续集成&交付:Jenkins
- 持久层框架:Mybatis Plus
- JSON序列化:Jackson
- 数据库:Mysql
- 工作流:Flowable
├── laokou-common
└── laokou-common-log --- 日志组件
└── laokou-common-sms --- 短信组件
└── laokou-common-mail --- 邮箱组件
└── laokou-common-core --- 核心组件
└── laokou-common-cors --- 跨域组件
└── laokou-common-redis --- 缓存组件
└── laokou-common-p6spy --- 日志组件
└── laokou-common-kafka --- 消息组件
└── laokou-common-wechat --- 微信组件
└── laokou-common-pulsar --- 消息组件
└── laokou-common-swagger --- 文档组件
└── laokou-common-reptile --- 爬虫组件
└── laokou-common-mongodb --- 报表组件
└── laokou-common-graphql --- 查询组件
└── laokou-common-rocketmq --- 消息组件
└── laokou-common-power-job --- 工作组件
└── laokou-common-freemarker --- 模板组件
└── laokou-common-prometheus --- 监控组件
└── laokou-common-elasticsearch --- 搜索组件
└── laokou-common-bom --- 依赖版本库
└── laokou-common-i18n --- 国际化组件
└── laokou-common-tenant --- 多租户组件
└── laokou-common-easy-captcha --- 验证码组件
└── laokou-common-api --- API调用组件
└── laokou-common-banner --- Banner组件
└── laokou-common-oss --- 对象存储组件
└── laokou-common-trace --- 链路跟踪组件
└── laokou-common-hbase --- 海量存储组件
└── laokou-common-dubbo --- 远程调用组件
└── laokou-common-jasypt --- 加密解密组件
└── laokou-common-xxl-job --- 任务调度组件
└── laokou-common-security --- 认证授权组件
└── laokou-common-openfeign --- 远程调用组件
└── laokou-common-easy-excel --- 导入导出组件
└── laokou-common-clickhouse --- 列式存储组件
└── laokou-common-data-cache --- 数据缓存组件
└── laokou-common-data-filter --- 数据过滤组件
└── laokou-common-redis-search --- 高效搜索组件
└── laokou-common-mybatis-plus --- 对象映射组件
└── laokou-common-dynamic-router --- 动态路由组件
└── laokou-common-shardingsphere --- 分库分表组件
└── laokou-common-ip-region --- IP归属地组件
└── laokou-common-neo4j --- 图形数据库组件
└── laokou-common-seata --- 分布式事务组件
└── laokou-common-r2dbc --- 响应式数据库组件
└── laokou-common-sentinel --- 服务限流&熔断降级组件
├── laokou-cloud
└── laokou-gateway --- API网关
└── laokou-monitor --- 服务监控
└── laokou-xxl-job --- 任务调度
└── laokou-register --- 服务治理
└── laokou-sentinel --- 流量治理
└── laokou-power-job --- 任务调度
└── laokou-seata --- 分布式事务
├── laokou-service
└── laokou-auth --- 认证授权模块
└── laokou-admin --- 后台管理模块
└── laokou-modlule
└── laokou-test --- 测试模块
└── laokou-im --- 即时通讯模块
└── laokou-flowable --- 工作流程模块
├── laokou-release
mvn clean package
spring:
# https://www.kancloud.cn/tracy5546/dynamic-datasource/2264611
# 多数据源
datasource:
dynamic:
primary: master
datasource:
master:
type: com.zaxxer.hikari.HikariDataSource
driver-class-name: com.mysql.jdbc.Driver
url: jdbc:mysql://127.0.0.1:3306/kcloud_platform_alibaba?useUnicode=true&characterEncoding=UTF-8&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=Asia/Shanghai&useSSL=false
username: root
password: 123456
hikari:
max-lifetime: 120000
maximum-pool-size: 16
minimum-idle: 16
# redis
data:
redis:
#主机
host: 127.0.0.1
#端口
port: 6379
#连接超时时长(毫秒)
timeout: 6000ms
# elasticsearch
elasticsearch:
#主机
host: 127.0.0.1:9200
#节点
cluster-name: elasticsearch-node
# seata
seata:
config:
type: nacos
nacos:
server-addr: 127.0.0.1:8848
namespace: xxx-xxx-xxx-xx
group: SEATA_GROUP
registry:
type: nacos
nacos:
namespace: xxx-xxx-xxx-xx
group: SEATA_GROUP
server-addr: 127.0.0.1:8848
enabled: true
tx-service-group: default_tx_group
data-source-proxy-mode: AT
--add-opens=java.base/java.lang=ALL-UNNAMED
@Service
@RequiredArgsConstructor
public class SysUserApplicationServiceImpl implements SysUserApplicationService {
private final SysUserService sysUserService;
@Override
@DataFilter(tableAlias = "boot_sys_user")
public IPage<SysUserVO> queryUserPage(SysUserQO qo) {
IPage<SysUserVO> page = new Page<>(qo.getPageNum(),qo.getPageSize());
return sysUserService.getUserPage(page,qo);
}
}
public class SysUserApiController {
@DataCache(name = "user", key = "#id")
public HttpResult<SysUserVO> detail(@RequestParam("id") Long id) {
return new HttpResult<SysUserVO>().ok(sysUserApplicationService.getUserById(id));
}
}
@Service
@Slf4j
@RequiredArgsConstructor
public class SysResourceApplicationServiceImpl implements SysResourceApplicationService {
/**
* 使用openfeign调用时,每个被调用服务都需要加 @Transactional
*/
@Transactional(rollbackFor = Exception.class,propagation = Propagation.REQUIRES_NEW)
@GlobalTransactional
public Boolean insertResource(SysResourceAuditDTO dto) {
log.info("分布式事务 XID:{}", RootContext.getXID());
SysResourceDO sysResourceDO = ConvertUtil.sourceToTarget(dto, SysResourceDO.class);
sysResourceDO.setEditor(UserUtil.getUserId());
sysResourceService.save(sysResourceDO);
Long id = sysResourceDO.getId();
String instanceId = startTask(id, sysResourceDO.getTitle());
dto.setResourceId(id);
return insertResourceAudit(dto,instanceId);
}
}
- 1.必须启动Mysql、Redis
- 2.可选启动Sentinel、RocketMQ、ElasticSearch、MongoDB
- 3.将doc/config/dev目录下的zip压缩文件都导入Nacos
- 4.运行doc/db/db_init.sql、shardingsphere_init.sql、db_update.sql(如果使用租户,需要运行doc/db/db_tenant_init.sql)
- 5.按顺序启动laokou-register、laokou-seata、laokou-gateway、laokou-auth、laokou-admin、laokou-flowable、laokou-im(其他的服务根据实际情况启动)
- 6.使用flowable审批,第一次启动,需要在流程定义上传流程图(下载模板,然后上传即可)
- 严格遵循阿里规范,注重代码质量
- 集群部署,减少单点故障
- 服务限流
- 超时和重试机制
- 熔断机制
- 异步调用
- 多级缓存
- 服务监控报警
- 采用Apache2.0开源协议,并且承诺永不参与商业用途,仅供大家无偿使用(点个star,拜托啦~🙏)
- 采用Apache2.0开源协议,并且承诺永不参与商业用途,仅供大家无偿使用(点个star,拜托啦~🙏)
- 采用Apache2.0开源协议,并且承诺永不参与商业用途,仅供大家无偿使用(点个star,拜托啦~🙏)
欢迎各路英雄好汉参与KCloud-Platform-Alibaba代码贡献,期待您的加入!
Fork本仓库 新建 feat_xxx_环境_时间(如 feat_laokou_dev_20230116) 分支提交代码,新建Pull Request!
我觉得没问题就会合并到主干分支,你也就成为正式贡献者啦!
KCloud-Platform-Alibaba 开源软件遵循 Apache 2.0 协议 请务必保留作者、Copyright信息
Github 后端地址:KCloud-Platform-Alibaba
Github 前端地址:KCloud-Antdv-Alibaba
Gtiee 后端地址:KCloud-Platform-Alibaba
Gitee 前端地址:KCloud-Antdv-Alibaba
Spring官网
阿里巴巴社区
人人社区
若依社区
苞米豆社区
livk-cloud社区
博客:https://kcloud.blog.csdn.net
QQ:2413176044