谷粒商城基础篇完结

1.分布式基础概念

1.1 微服务

单体架构是 所有业务 都由一个项目去完成。

有别于 单体 架构,微服务将服务被拆分成多个独立的小型服务,这些服务通过网络调用(如HTTP请求)相互通信,共同实现整个应用的功能。

分布式 则将这些服务部署在的不同节点上。

1.2 注册中心

注册中心为分布式系统提供服务发现功能,让这些服务可以相互发现,相互调用。

1.3 配置中心

服务读取配置中心的配置,不必修改本地配置文件,实现热部署。

1.4 远程调用&Feign

Feign 是一个声明式的 Web 服务客户端,能够通过注解和接口定义的方式,简化 HTTP 请求的过程。开发者不需要手动编写复杂的 HTTP 请求和响应处理代码,Feign 会"假装"成客户端接口的一部分,自动处理底层的请求和响应。

1.5 网关

网关实现路由转发,权限校验,限流控制。

微服务架构中,请求通常发送给网关,网关在注册中心中发现服务,转发到对应服务。

2.基础开发

2.1 SpringBoot2.0

2.2 SpringCloud

注册中心,配置中心,远程调用,网关

2.3 Mybatis-Plus

在 MyBatis 的基础上,提供了自动化的功能,如自动生成 CRUD 操作、分页查询、条件构造等

2.4 Vue组件化

2.5 阿里云对象存储

项目使用Alibaba Cloud OSS,存储和访问数据。

3. 环境

VMware、Linux、Docker、MySQL、Redis、逆向工程&人人开源

  1. VMware搭建Linux CentOS 系统
  2. 利用Docker 快速部署 MySQL、Redis
  3. 人人开源 依据数据库 快速生成CRUD代码

4.开发规范

  • 数据校验JSR303、全局异常处理、全局统一返回、全局跨域处理
  • 枚举状态、业务状态码、VO与TO与PO划分、逻辑删除
  • Lombok;@Data @slf4
相关推荐
希望永不加班9 分钟前
SpringBoot 定时任务:@Scheduled 基础与动态定时
java·spring boot·后端·spring
派大星酷9 分钟前
跨域是什么 有什么影响 怎么解决
java·网络
CV艺术家10 分钟前
mysql数据迁移到达梦数据库
java·数据库
wuqingshun31415911 分钟前
说一下mybatis里面#{}和${}的区别
java·spring·mybatis
SimonKing14 分钟前
每天白送4000万Token!这款“龙虾”AI神器,微信就能操控电脑
java·后端·程序员
橘子编程19 分钟前
编程语言全指南:从C到Rust
java·c语言·开发语言·c++·python·rust·c#
艾莉丝努力练剑21 分钟前
【Linux线程】Linux系统多线程(三):Linux线程 VS 进程,线程控制
java·linux·运维·服务器·c++·学习·ubuntu
小白天下第一30 分钟前
java+三角测量(两个工业级)+人体3d骨骼关键点获取(yolov8+HRNET_w48_2d)
java·yolo·3d·三角测量
人间打气筒(Ada)31 分钟前
「码动四季·开源同行」go语言:微服务网关如何作为服务端统一入口点?
微服务·golang·开源·微服务网关·go实战
William Dawson39 分钟前
Java 后端高频 20 题超详细解析 ①
java·开发语言