微服务分布式电商项目《谷粒商城》学习笔记

大家好!今天让小编来大家介绍下关于微服务分布式电商项目《谷粒商城》学习笔记的问题,以下是酷知号的小编对此问题的归纳整理,让我们一起来看看吧。

微服务分布式电商项目《谷粒商城》学习笔记

文章目录

    • 一、基本架构图
    • 二、配置
    • 三、项目搭建
    • 四、数据库
      • 1.开启虚拟机,在windows下通过navicat连接上
      • 2.人人开源:https://gitee.com/renrenio
    • 五、微服务-注册中心、配置中心、网关
      • 1.导入公共依赖
      • 2.配置Nacos Server地址
      • 3.使用 @EnableDiscoveryClient 注解开启服务注册与发现功能
      • 4.登录nacos
      • 5.版本确定
      • 6.openFeign远程调用
      • 7.命名空间(配置隔离)和配置分组
      • 8.gateway
  • 六、商品服务
    • (一) 分类维护
      • 1.添加商品分类信息
      • 2.前端发送请求获取商品分类信息
      • 3.配置网关路由和路径重写
      • 4.跨域解决
      • 9.Mybatis-plus逻辑删除
    • (二) 品牌管理
  • 七、文件存储
    • (一)上传方式
      • 1.方式一
      • 2.方式二:推荐使用
    • (二)创建RAM子账号
    • (三)整合第三方服务
    • (四)使用服务端签名后直传
    • (五)设置跨域
    • (六)添加JSR303数据校验
      • 1.JSR303数据校验
      • 2.系统错误码定义
      • 3.JSR303分组校验(多场景的复杂校验)
      • 4.自定义校验注解
      • 5.SPU&SKU&规格参数&销售属性
      • 6.属性分组
      • 7.品牌分组
      • 8.下载插件mybatisX
      • 9.p84的pubsub、publish
      • 10.项目配置-设置批量启动或内存设置
      • 11.采购单需求
      • 12.p100问题解决
      • 13.分布式基础篇总结

一、基本架构图

二、配置

1、安装linux虚拟机
2、下载docker容器
3、在docker容器上添加mysql和redis容器
4、windows下载redis、maven、vscode、node.js、数据库、git
5、git配置github免密登录

三、项目搭建

1、在github/码云创建仓库并拉取到本地,在本地创建并且到分支develop
1)、创建仓库

2)、拉取代码

github拉取master代码

码云拉取分支feature代码

2、windows下的idea创建项目微服务
商品服务:com.atguigu.gulimall.product
仓储服务:com.atguigu.gulimall.ware
订单服务:com.atguigu.gulimall.order
会员(用户)服务:com.atguigu.gulimall.member
优惠卷服务:com.atguigu.gulimall.coupon

1)、IDEA打开项目

2)、新建模块(Springboot版本控制在2.2.0,可创建后修改版本号2.2.0)

其他同理可得

四、数据库

1.开启虚拟机,在windows下通过navicat连接上

注意需要先将文件设置为UTF-8,否则会中文乱码。

复制相应内容粘贴,运行代码

2.人人开源:https://gitee.com/renrenio

将三个项目clone到本地(记得删除.git文件再放入目录),renren-fast-vue作为前台管理系统,renren-fast和renren-generator放在gulimall项目下:
0)、renren-fast-vue
使用vscode打开renren-fast-vue项目

npm install

报错请看:
如使用npm i node-sass –sass_binary_site=https://npm.taobao.org/mirrors/node-sass
https://www.cnblogs.com/tw6668/p/12507369.html
https://blog.csdn.net/hancoder/article/details/113821646

npm run dev运行项目

1)、放入renren-fast
创建gulimall_admin数据库,然后运行sql文件。

刷新renren-fast-vue的前端页面(账号:admin、密码:admin)

即完成前后联调。

2)、导入renren-generator,用于逆向生成

把import导入的删除,注解注释。

补充:导入文件后,缺少工具类,需要从renren-fast中拿。(通过创建gulimall-common共用)

其他同理可得。

3)、公共依赖

gulimall-common添加公共依赖

<dependencies><!--mybatis-plus--><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus</artifactId><version>3.2.0</version></dependency><!--lombok--><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.8</version></dependency><!-- httpcomponent包。发送http请求 --><dependency><groupId>org.apache.httpcomponents</groupId><artifactId>httpcore</artifactId><version>4.4.12</version></dependency><dependency><groupId>commons-lang</groupId><artifactId>commons-lang</artifactId><version>2.6</version></dependency><!--导入mysql驱动--><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.17</version></dependency><!--tomcat里一般都带--><dependency><groupId>javax.servlet</groupId><artifactId>servlet-api</artifactId><version>2.5</version><scope>provided</scope></dependency>
</dependencies>

gulimall-product项目及application.yml

auto表示实体id设置成自增

#application.yml
server:port: 10000
spring:datasource:username: rootpassword: rooturl: jdbc:mysql://192.168.129.129:3306/gulimall_pms?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=Asia/Shanghaidriver-class-name: com.mysql.cj.jdbc.Driver# MapperScan
# sql映射文件位置
mybatis-plus:mapper-locations: classpath:/mapper/**/*.xmlglobal-config:db-config:id-type: auto

编写测试类

说明:
可以用shift+F6修改模块名

coupon=>sms 端口号:7000
member=》ums 端口号:8000
order=>oms 端口号:9000
product=》pms 端口号:10000
ware=》wms 端口号:11000
记得数据库连接要配置

五、微服务-注册中心、配置中心、网关

项目文档地址:https://github.com/alibaba/spring-cloud-alibaba/

1.导入公共依赖

https://spring.io/projects/spring-cloud-alibaba

spring-cloud-alibaba-dependencies
spring-cloud-starter-alibaba-nacos-discovery

	<dependencies><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency></dependencies><dependencyManagement><dependencies><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-alibaba-dependencies</artifactId><version>2.2.0.RELEASE</version><type>pom</type><scope>import</scope></dependency></dependencies></dependencyManagement>

注:下载Nacos Server1.1.3的
https://github.com/alibaba/nacos/archive/refs/tags/1.1.3.zip

2.配置Nacos Server地址

server:port: 7000
spring:datasource:username: rootpassword: rooturl: jdbc:mysql://192.168.129.129:3306/gulimall-sms?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=Asia/Shanghaidriver-class-name: com.mysql.cj.jdbc.Drivercloud:nacos:discovery:server-addr: 127.0.0.1:8848application:name: gulimall-coupon# MapperScan
# sql映射文件位置
mybatis-plus:mapper-locations: classpath:/mapper/**/*.xmlglobal-config:db-config:id-type: auto

3.使用 @EnableDiscoveryClient 注解开启服务注册与发现功能

4.登录nacos

5.版本确定

版本选择:Spring Cloud Hoxton.SR9(SpringCloud)=》2.2.6.RELEASE(SpringCloud)=》2.3.2.RELEASE(SpringBoot)
=>1.4.2(Nacos)

1.Spring Cloud Alibaba Version
地址: https://spring.io/projects/spring-cloud-alibaba=》确认 Spring Cloud Alibaba: 2.2.6.RELEASE
2.选择Spring Boot Version,选择 Nacos Version
https://github.com/alibaba/spring-cloud-alibaba/wiki/版本说明
=》确认 Spring Boot: 2.3.2.RELEASE
=》确认 Nacos: 1.4.2

6.openFeign远程调用

声明式远程调用:编写一个接口,告诉SpringCloud这个接口需要远程调用

模拟远程调用

开启远程调用功能

测试结果

7.配置中心-统一处理

<!--配置中心来做配置管理-->
<dependencies><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId></dependency>
</dependencies>

bootstrap.properties(优先级最高)优于application.yml,application.properties

点击发布

通过配置中心完成配置,无需修改文件

7.命名空间(配置隔离)和配置分组

每个微服务可以创建自己的命名空间,使用配置分组区分环境:dev,testing,prod

(1)新建命名空间

(2)配置分组

(3)bootstrap.properties配置命名空间和分组

例1:

例2:

7.加载多个配置集(从配置文件迁移到配置中心)

将application.yml的文件注释掉

测试连接

8.gateway

修改版本

<dependency><groupId>com.atguigu.gulimall</groupId><artifactId>gulimall-common</artifactId><version>0.0.1-SNAPSHOT</version></dependency>
<!--引入gateway网关-->
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-gateway</artifactId><!--排除gateway 内部不兼容的 spring-web --><exclusions><exclusion><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></exclusion></exclusions>
</dependency>

开启网关服务注册和发现

配置路由转发

六、商品服务

(一) 分类维护

1.添加商品分类信息

将pms_catelog.sql文件的插入语句导入到表里

2.前端发送请求获取商品分类信息

可配置请求端口

3.配置网关路由和路径重写

renren-fast添加服务注册

没有请求到对应路径:
http://localhost:88/api =》http://localhost:88/api/captcha.jpg

真实目标路径:http://localhost:8080/renren-fast/captcha.jpg

使用网关重写功能:即可进行访问

进行登录:产生跨域问题

4.跨域解决

4.1

解决方案一:

解决方案二:使用后端网关进行跨域配置

4.2

不允许有多个 ‘Access-Control-Allow-Origin’ CORS =》同源策略堵塞

9.Mybatis-plus逻辑删除

(二) 品牌管理

七、文件存储

使用云存储:阿里云对象存储

(一)上传方式

1.方式一

2.方式二:推荐使用

(二)创建RAM子账号

(三)整合第三方服务

(四)使用服务端签名后直传

(五)设置跨域

通过服务端加密,然后前端请求拿到相关签名数据,然后上传图片到OSS

使用vue插件查看logo地址

(六)添加JSR303数据校验

1.JSR303数据校验

1)给Bean添加校验注解:javax.validation.constraints,并定义自己的message提示
2)开始校验功能@Valid
效果:校验错误以后会有默认的响应
3)给校验的bean后紧跟一个BindingResult,就可以获取到校验的结果

gulimall-common添加依赖

Spring2.3.0及以后版本没有集成validation包,需要导入Spring Boot Starter Validation

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-validation</artifactId>
</dependency>

2.系统错误码定义

3.JSR303分组校验(多场景的复杂校验)

1)@NotBlank(message = “品牌名不能为空”, groups = {AddGroup.class, UpdateGroup.class})给注解标注什么情况需要进行校验
2)@Validated({AddGroup.class})
3) 默认没有指定分组的校验注解@NotBlank,在分组校验情况@Validated({AddGroup.class})下不生效

4.自定义校验注解

1)编写一个自定义的校验注解
2)编写一个自定义的校验器
3)关联自定义的校验器和自定义的校验注解

注意:(以及国际化相关的)
ValidationMessages.properties =》涉及校验注解的message默认值配置

@Constraint(validateBy={})=>指定用什么东西来校验,点击validatedBy了解ConstraintValidator,有两个方法initialize和isValid

5.SPU&SKU&规格参数&销售属性

6.属性分组

在gulimall_admin删除sys_menus,重新导入

7.品牌分组

重新导入到pms_category

让分类维护恢复初始数据

8.下载插件mybatisX

9.p84的pubsub、publish

p84 关于pubsub、publish报错,无法发送查询品牌信息的请求:
1、npm install –save pubsub-js
2、在src下的main.js中引用:
① import PubSub from ‘pubsub-js’
② Vue.prototype.PubSub = PubSub

如果 npm install –save pubsub-js 安装报错的话,可以试一下 cnpm install –save pubsub-js

10.项目配置-设置批量启动或内存设置

11.采购单需求

12.p100问题解决

插入sql

INSERT INTO sys_menu (menu_id, parent_id, name, url, perms, type, icon, order_num) VALUES (76, 37, '规格维护', 'product/attrupdate', '', 2, 'log', 0);

index.js的children: []添加

{ path: '/product-attrupdate', component: _import('modules/product/attrupdate'), name: 'attr-update', meta: { title: '规格维护', isTab: true } }

attrupdate.vue添加if (item.attrs != null) {}判断

13.分布式基础篇总结

以上就是小编对于微服务分布式电商项目《谷粒商城》学习笔记问题和相关问题的解答了,微服务分布式电商项目《谷粒商城》学习笔记的问题希望对你有用!

文章来自互联网,只做分享使用。发布者:酷知号,转转请注明出处:https://www.kuzhihao.com/article/438516.html

(0)
上一篇 2023年9月29日
下一篇 2023年9月29日

相关推荐