谷粒商城——分布式基础(全栈开发篇第一部分)

文章目录


一、

服务治理

  1. Nacos 注册中心
  2. Nacos 配置中心
  3. Seata 分布式事务
  4. Sentinel 服务熔断降级

网路

  1. Feign 远程调用&负载均衡
  2. Gateway 网关
  3. Sleuth 链路追踪
  4. Zipkin 可视化追踪

数据支撑

  1. redis 缓存
  2. mysql 持久化
  3. rebbitMa 消息队列
  4. ElasticSearch 全文检索
  5. Oss 阿里云存储服务

日志处理ELK

  1. Kibnan 将Es中的日志可视化
  2. LogStash 日志捕获
  3. ES 存放日志

应用监控

  1. Prometheus 分析监控信息
  2. Grafana 可视化监控信息
  3. Prometheus 的Altermananger 发送监控信息

集成工具

  1. GItHub 上传代码
  2. Jenkins 获取代码
  3. Docker 打包成docker镜像
  4. Kuberneters 集成docker服务

开发工具

  1. Virtualbox 虚拟机 https://www.virtualbox.org/
  2. vagrant linux镜像工具 https://developer.hashicorp.com/vagrant/downloads?host=www.vagrantup.com

二、环境创建

1、虚拟机创建

  1. 下载Virtualbox 安装

  2. 下载vagrant 安装 重启 判断是否安装成功

  3. 安装centos7镜像文件 vagrant init centos/7设置环境

  4. vagrant up启动环境

    需要很长时间

    启动成功Virtualbox 也会自动运行虚拟机

    直接在命令窗口 vagrant shh 就可以连接虚拟机了,

  5. 配置网络

    cmd 查看IP


    这个文件的这里

    改成对应的IP地址,然后重启 vagrant reload

    如果无法重启就通过Virtualbox 直接关机在打开,

  6. ipaddr查看一下IP改对没,然后在ping一下外机

使用vagrant ssh启动时一定保证在vagrantfile文件目录下打开

2、虚拟机安装docker等

1. 安装docker

官网地址

  1. 删除以前记录

    sudo yum remove docker

    docker-client

    docker-client-latest

    docker-common

    docker-latest

    docker-latest-logrotate

    docker-logrotate

    docker-engine

  2. 设置存储库sudo yum install -y yum-utils

    sudo yum-config-manager --add-repo \https://download.docker.com/linux/centos/docker-ce.repo

  3. 安装sudo yum install docker-ce docker-ce-cli containerd.io docker-compose-plugin

  4. 启动docker sudo systemctl start docker

  5. 设置docker开机自起 sudo systemctl enable docker

1. 配置阿里docker

  1. 登录阿里云,在产品服务里计算里面找到容器镜像服务
  2. sudo mkdir -p /etc/docker ( 创建文件夹)
    sudo tee /etc/docker/daemon.json <<-'EOF'
    {
    "registry-mirrors": ["https://oxxsyw0h.mirror.aliyuncs.com"]
    }
    EOF (设置路径)
    sudo systemctl daemon-reload (重启docker的线程)
    sudo systemctl restart docker (重启docker)

3.docker安装mysql

地址

  1. sudo docker pull mysql:版本

  2. sudo docker images 查看是否安装

  3. 切换成root用户完成创建实例操作 su root 密码为 vagrant whoami 查看当前用户

  4. docker run -p 3306:3306 --name mysql \

    -v /mydata/mysql/log:/var/log/mysql \

    -v /mydata/mysql/data:/var/lib/mysql \

    -v /mydata/mysql/conf:/etc/mysql \

    -e MYSQL_ROOT_PASSWORD=root \

    -d mysql:5.7

    参数说明

    -p 3306:3306:将容器的 3306 端口映射到主机的 3306 端口

    --name mysql :起一个容器名字

    -v /mydata/mysql/conf:/etc/mysql:将配置文件夹挂载到主机

    -v /mydata/mysql/log:/var/log/mysql:将日志文件夹挂载到主机

    -v /mydata/mysql/data:/var/lib/mysql/:将配置文件夹挂载到主机

    -e MYSQL_ROOT_PASSWORD=root:初始化 root 用户的密码

错误

这一步发送了错误
docker: invalid reference format. See 'docker run --help'.

查看错误 $ sudo dockerd --debug

INFO[2022-11-10T05:42:34.344590302Z] Starting up

DEBU[2022-11-10T05:42:34.346441844Z] Listener created for HTTP on unix (/var/run/docker.sock)

failed to start daemon: Unable to get the TempDir under /var/lib/docker: mkdir /var/lib/docker/tmp: no space left on device

在unix上为HTTP创建的侦听器(/var/run/docker.sock)

无法启动守护程序:无法获取/var/lib/docker:mkdir/var/lib/docker/tmp下的TempDir:设备上没有剩余空间

尝试删除docker.sock 还是失败

什么事docker.sock

查看dev/sdal 发现他妈的占了40g

发现问题

vagrant提供了将本机目录挂载到虚拟机目录下的功能,默认是将vagrant配置文件所在目录挂载到虚拟机/vagrant目录下。

参考文章
参考文章2

  1. 设置配置
    docker run -p 3306:3306 --name mysql \ -v /mydata/mysql/log:/var/log/mysql \ -v /mydata/mysql/data:/var/lib/mysql \ -v /mydata/mysql/conf:/etc/mysql \ -e MYSQL_ROOT_PASSWORD=root \ -d mysql:5.7

    第一次还是失败了,然后把换行符删除了就成功了
  2. docker ps 查看当前运行的容器
  3. 查看容器原理 每一个容器其实就是一个精简版的linux
  4. 设置mysql cof内容
    退出进入conf文件夹 vi my.cnf 把配置复制进去就行了
    vi /mydata/mysql/conf/my.cnf

[client] default-character-set=utf8 [mysql] default-character-set=utf8 [mysqld] init_connect='SET collation_connection = utf8_unicode_ci' init_connect='SET NAMES utf8' character-set-server=utf8 collation-server=utf8_unicode_ci skip-character-set-client-handshake skip-name-resolve

  1. docker restart mysql 重启mysql

  2. cat查看 my.cof 有没有

4、docker安装redis

  1. docker pull redis
  2. 创建文件映射
    mkdir -p /mydata/redis/conf :创建文件夹

touch /mydata/redis/conf/redis.conf :创建配置文件

docker run -p 6379:6379 --name redis -v /mydata/redis/data:/data -v /mydata/redis/conf/redis.conf:/etc/redis/redis.conf -d redis redis-server /etc/redis/redis.conf : 创建映射

  1. 修改配置信息 添加开启 aof新版的默认开启了

  2. 查看redis官方的配置信息,这个会了很重要

3、软件

1.Maven 阿里云镜像+1.8jdk

2、idea +lombok+mybatisX ,

3、 visualStudioCode

安装前端插件

4、安装 git

三、项目环境搭建

1、创建后台Spring项目

1. 创建远程仓库,添加shh key 连接远程仓库

2. 下拉项目 gulimsll

3. 创建五个模块product/order/ware/coupon/member

选择spring

4. 设置主项目的.gitignore和pom.xml

![在这里插入图片描述](https://img-blog.csdnimg.cn/4a5e5248143a4d9bb946103457611698.png![在这里插入图片描述](https://file.jishuzhan.net/article/1768074884358868993/bcdd9088985b33695b166cc4c578590e.webp)

2、数据库

1. 设置redis 和mysql自动启动

sudo docker update mysql --restart=always
sudo docker update redis --restart=always重启查看是否自动启动

2. 连接数据库

3. 创建各个数据库 注意 字符集为utf8mb4 排序为默认

3、拉取克隆人人资源公开项目,前端和后端

1. 把项目中的。git删除,并吧fast后台放到主项目中,主项目pom添加模块

2. 用visual code 打开前端项目

3. 下载安装Node.js

官网

检查版本

设置阿里镜像 npm config set registry http://registry.npm.taobao.org/

大家如果 npm install 安装依赖出现 chromedriver 之类问题,先在项目里运行下面命令 npm install chromedriver --chromedriver_cdnurl=http://cdn.npm.taobao.org/dist/chromedriver 然后再运行 npm install

4. npm install 下载依赖(根据packag.json)

无错误信息表示下载成功,如果下载失败请退出要管理员身份运行,或者退出新建终端,确认网络

4、项目框架启动

  1. npm run dev 启动前端项目
  2. 启动后台 renren-fast
    默认用户名密码 admin admin

四、项目基础功能

1、利用代码生成器开发基础功能,生成product

利用人人开源代码生成器

  1. git clone generator代码生成工具

  2. 吧文件中的git删除,吧generator放到项目中并添加maven模块名称

  3. 修改配置信息生成代码,先生成pms数据库,product模块

  4. 注意修改正确代码生成模板

  5. 修改完成后启动项目

  6. 全选点击生成代码生成一个压缩包

  7. 将生成的product模块的main文件直接粘贴在项目中,

2、创建gulimall-common公共模块

  1. 创建模块
  2. 在其他模块pom中引入公共模块
  3. 将需要的renrenfast中utils的类放到common模块中
  4. 导入公共包需要的pom文件
xml 复制代码
    <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.2.0</version>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.8</version>
        </dependency>
        <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>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.17</version>
        </dependency>
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>servlet-api</artifactId>
            <version>2.5</version>
            <scope>provided</scope>
        </dependency>
        <!-- nacos 注册发现-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
        <!-- nacos 配置管理-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
        </dependency>

3、生成Coupon优惠模块

修改generator的配置路径根据对应的模块和数据库然后新增就OK了

生成之后启动一下测试一下

4、生成member会员系统

  1. 一样的方式,

  2. 注意pom文件的引要公共模块文件

  3. 注意设置服务端口号如果端口号被占用就可以参考这个文章

  4. 弄好后运行,测试一下http://localhost:8000/member/growthchangehistory/list

5、订单系统

  1. 改generator配置
  2. 导入公共模块
  3. 启动测试
    http://localhost:9000/order/order/list

6、ware库存

和上面差不多

7、错误

java.lang.IllegalStateException: Failed to load ApplicationContext

Cannot instantiate interface org.springframework.context.ApplicationListener : org.springframework.cloud.bootstrap.BootstrapApplicationListener

org/springframework/cloud/bootstrap/BootstrapApplicationListener has been compiled by a more recent version of the Java Runtime (class file version 61.0), this version of the Java Runtime only recognizes class file versions up to 52.0

原因我创建的时候不能选择视频中的版本,然后jdk为17

这个我只改了jdk ,没该下面cloud的版本哭死

8、整合mybatis-plus

  1. 导入依赖
xml 复制代码
<dependency>
          <groupId>com.baomidou</groupId>
          <artifactId>mybatis-plus-boot-starter</artifactId>
          <version>3.4.1</version>
       </dependency>
  1. 配置
    1. 配置数据源;
      导入数据库驱动
      在application.yml配置数据源
    1. 配置mybatis-plus
      使用@MapperScan
      告诉mybatis-plus,sql映射文件位置
yaml 复制代码
 mybatis-plus:
  mapper-locations: classpath:/mapper/*Mapper.xml
   type-aliases-package: com.atguigu.gulimall.product.entity
 global-config:
      db-config:  #全局配置
      id-type: auto  #主键策略

五、安装中间件 阿里组件

1、介绍

Spring Cloud Alibaba 致力于提供微服务开发的一站式解决方案。此项目包含开发分布式应用微服务的必需组件,方便开发者通过 Spring Cloud 编程模型轻松使用这些组件来开发分布式应用服务。

依托 Spring Cloud Alibaba,您只需要添加一些注解和少量配置,就可以将 Spring Cloud 应用接入阿里微服务解决方案,通过阿里中间件来迅速搭建分布式应用系统。

https://github.com/alibaba/spring-cloud-alibaba

1. SpringCloud 的几大痛点

  • SpringCloud 部分组件停止维护和更新,给开发带来不便;
  • SpringCloud 部分环境搭建复杂,没有完善的可视化界面,我们需要大量的二次开发和定制
  • SpringCloud 配置复杂,难以上手,部分配置差别难以区分和合理应用

2. SpringCloud Alibaba 的优势:

阿里使用过的组件经历了考验,性能强悍,设计合理,现在开源出来大家用成套的产品搭配完善的可视化界面给开发运维带来极大的便利

搭建简单,学习曲线低。

3. 当前项目 SpringCloud Alibaba 我们最终的技术搭配方案:

SpringCloud Alibaba - Nacos:注册中心(服务发现/注册): 一个更容易构建云原生应用的动态服务发现、配置管理和服务管理平台。

SpringCloud Alibaba - Nacos:配置中心(动态配置管理)

SpringCloud - Ribbon:负载均衡

SpringCloud - Feign:声明式 HTTP 客户端(调用远程服务)

SpringCloud Alibaba - Sentinel:服务容错(限流、降级、熔断) :Sentinel以"流量"为切入点,提供流控、并发、熔断、负载保护等方面的解决方案,保障服务稳定性。

SpringCloud - Gateway:API 网关(webflux 编程模式)

SpringCloud - Sleuth:调用链监控

SpringCloud Alibaba - Seata:原 Fescar,即分布式事务解决方案 :阿里巴巴开源产品,一个易于使用的高性能微服务分布式事务解决方案。

4. 版本选择

由于 Spring Boot 1 和 Spring Boot 2 在 Actuator 模块的接口和注解有很大的变更,且

spring-cloud-commons 从 1.x.x 版本升级到 2.0.0 版本也有较大的变更,因此我们采取跟

SpringBoot 版本号一致的版本:

 1.5.x 版本适用于 Spring Boot 1.5.x

 2.0.x 版本适用于 Spring Boot 2.0.x

 2.1.x 版本适用于 Spring Boot 2.1.x

2、安装

1. nocas-alibaba 注册中心

网站https://github.com/alibaba/spring-cloud-alibaba/blob/2022.x/spring-cloud-alibaba-examples/nacos-example/nacos-config-example/readme-zh.md

  1. pom文件
xml 复制代码
   <!-- 注册中心-->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
  1. 配置主要看nacos的部分
yaml 复制代码
spring:
  application:
    name: gulimall-coupon
  datasource:
    username: root
    password: root
    url: jdbc:mysql://192.168.56.10:3306/gulimall_sms?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=Asia/Shanghai
    driver-class-name: com.mysql.cj.jdbc.Driver
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848


mybatis-plus:
  mapper-locations: "classpath:/mapper/**/*.xml"
  global-config:
    db-config:
      #      自增主键
      id-type: auto


server:
  port: 7000

'加注解'使用@EnableDiscoveryClient开启服务注册发现功能

  1. 下载启动

问题新版本默认启动为集群 "nacos is starting with cluster
解决参考文章

bin目录下 命令启动 startup.cmd -m standalone

中间我遇到了个麻烦,我选择了高版本的spring 然后又切换回了老师的版本,junit在2.1上和下是不同的写法
参考文章 作者:大佬腿好粗

  1. 打开

  2. 慢慢把其他的服务都注册上

2.openFeign-SpringCloud 远程调用

Feign是一个声明式的HTTP客户端,它的目的就是让远程调用更加简单。Feign提供了HTTP

请求的模板,通过编写简单的接口和插入注解,就可以定义好HTTP请求的参数、格式、地

址等信息。
Feign整合了Ribbon(负载均衡)和Hystrix(服务熔断),可以让我们不再需要显式地使用这 两个组件。
SpringCloudFeign在NetflixFeign的基础上扩展了对SpringMVC注解的支持,在其实现下,我

们只需创建一个接口并用注解的方式来配置它,即可完成对服务提供方的接口绑定。简化了

SpringCloudRibbon自行封装服务调用客户端的开发量。

  1. 引包,之前的跟视频走的一个已经引过包了
xml 复制代码
     <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>
  1. 编写一个接口,告诉spring cloud 这个接口需要 gulimall-coupon 这个服务的远程调用
java 复制代码
package com.atguigu.gulimall.member.feign;

/**
 * 这是一个声明式服务
 */
@FeignClient("gulimall-coupon")
public interface CouponFeignService {
    @RequestMapping("coupon/categorybounds/member/list")
    public R memberCoupons();
}
  1. 声明这个接口
java 复制代码
@RestController
@RequestMapping("member/member")
public class MemberController {
   

    @Autowired
    CouponFeignService couponFeignService;

    /**
     * 测试openfeign
     * @return
     */
    @RequestMapping("/coupons")
    public R test(){
        MemberEntity member = new MemberEntity();
        member.setNickname("张三");
        R r = couponFeignService.memberCoupons();
        return R.ok().put("member",member).put("coupons",r.get("coupons"));
    }
  1. 开启远程服务调用
java 复制代码
@EnableFeignClients(basePackages = "com.atguigu.gulimall.member.feign")
  1. 测试

原理

3.nocas 配置中心

  1. 映入依赖
xml 复制代码
        <!--配置中心 -->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
        </dependency>
  1. 创建一个bootstrap.properties 配置用户名和用户中心地址

  2. 在配置中心配置数据

    NacosConfig主要通过dataId和group来唯一确定一条配置。

  3. 给 应用名.properties 添加任何配置

  4. 动态获取配置。

    @RefreshScope:动态获取并刷新配置

    @Value("s配置项的名》"): 获取到配置。如果配置中心和当前应用的配置文件中都配置了相同的项,优先使用配置中心的配置

  5. 修改配置发布测试

配置中心详细内容
  1. 命名空间: 配置隔离

    默认public(保留空间)默认新增的都在public,可以配置测试空间,生产空间之类的,通过切换id来切换空间,也可以把每个微服务创建一个命名空间

  2. 配置集

    配置的集合

  3. 配置集id

    配置文件名称

  4. 配置分组 添加1111分组可以根据组名称去选择配置

    在选择组

yml 复制代码
spring.application.name=gulimall-coupon
spring.cloud.nacos.config.server-addr=127.0.0.1:8848
spring.cloud.nacos.config.namespace=abbe2e42-a212-4480-8533-3c7545adf963
spring.cloud.nacos.config.group=111

可以用命名空间来区分不同的微服务,分组来区分环境

  1. 同时加载多个配置集,把对应的配置放到对应创建的配置级里面 other放剩下的(nacos配置里面不要加空行,不要加中文)


  2. 微服务的任何配置信息,和配置文件都可以放到配置中心 不改变之前取配置信息的方式

  3. 只需要在bootstrap.properties说明加载配置中心哪个配置文件即可

  4. 以前SpringBoot任何方法从配置文件中获取值,都能使用。

  5. 配置中心和配置文件中的配置优先级:

4. 配置gateway网关

让所有的请求都通过gateway这个服务去访问其他服务,那么就只需要对这个外观服务进行限流熔断等操作就可以了。

Spring官方网站
Spring Gateway中文网

  1. 通过spring模板新建一个模块,只选择getaway的jar包,在把公共模块的包引过去 (@SpringBootApplication(exclude = DataSourceAutoConfiguration.class)排除数据库包)

  2. nacos注册服务,在创建配置文件

    别忘记写注册服务的注解@EnableDiscoveryClient

  3. application.properties

spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848

spring.application.name=gulimall-gateway

server.port=88

  1. application.yml
    配置的路由规则,在spring官网上有很多规则
    这里配置的是query规则
yaml 复制代码
spring:
  cloud:
    gateway:
      routes:
        - id: baidu_route
          uri: https://www.baidu.com
          predicates:
            - Query=url,baidu

        - id: qq_route
          uri: https://www.qq.com
          predicates:
            - Query=url,qq
  1. bootstrap.properties
yaml 复制代码
spring.application.name=gulimall-gateway
spring.cloud.nacos.config.server-addr=127.0.0.1:8848
spring.cloud.nacos.config.namespace=1f986a10-dfe9-493d-a63a-b1fe11c310eb
  1. 测试

参考文章

个人笔记,不同意见,望有交流

直接可以点击跳转连接

作者 尚硅谷

相关推荐
Re.不晚3 分钟前
Java入门15——抽象类
java·开发语言·学习·算法·intellij-idea
雷神乐乐9 分钟前
Maven学习——创建Maven的Java和Web工程,并运行在Tomcat上
java·maven
码农派大星。12 分钟前
Spring Boot 配置文件
java·spring boot·后端
顾北川_野19 分钟前
Android 手机设备的OEM-unlock解锁 和 adb push文件
android·java
江深竹静,一苇以航22 分钟前
springboot3项目整合Mybatis-plus启动项目报错:Invalid bean definition with name ‘xxxMapper‘
java·spring boot
confiself37 分钟前
大模型系列——LLAMA-O1 复刻代码解读
java·开发语言
Wlq041542 分钟前
J2EE平台
java·java-ee
XiaoLeisj1 小时前
【JavaEE初阶 — 多线程】Thread类的方法&线程生命周期
java·开发语言·java-ee
鹿屿二向箔1 小时前
基于SSM(Spring + Spring MVC + MyBatis)框架的汽车租赁共享平台系统
spring·mvc·mybatis
材料苦逼不会梦到计算机白富美1 小时前
golang分布式缓存项目 Day 1
分布式·缓存·golang