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

文章目录

  • 一、
    • 服务治理
    • 网路
    • 数据支撑
    • 日志处理ELK
    • 应用监控
    • 集成工具
    • 开发工具
  • 二、环境创建
    • 1、虚拟机创建
    • 2、虚拟机安装docker等
      • 1. 安装docker
      • 1. 配置阿里docker
      • 3.docker安装mysql
        • 错误
      • 4、docker安装redis
    • 3、软件
      • 1.Maven 阿里云镜像+1.8jdk
      • 2、idea +lombok+mybatisX ,
      • 3、 visualStudioCode
      • 4、安装 git
  • 三、项目环境搭建
    • 1、创建后台项目
      • 1. 创建远程仓库,添加shh key 连接远程仓库
      • 2. 下拉项目 gulimsll
      • 3. 创建五个模块product/order/ware/coupon/member
      • 4. 设置主项目的.gitignore和pom.xml
    • 2、数据库
      • 1. 设置redis 和mysql自动启动
      • 2. 连接数据库
      • 3. 创建各个数据库 注意 字符集为utf8mb4 排序为默认
    • 3、拉取克隆人人资源公开项目,前端和后端
      • 1. 把项目中的。git删除,并吧fast后台放到主项目中,主项目pom添加模块
      • 2. 用visual code 打开前端项目
      • 3. 下载安装Node.js
      • 4. npm install 下载依赖(根据packag.json)
    • 4、项目框架启动
  • 四、项目基础功能
    • 1、利用代码生成器开发基础功能,生成product
    • 2、创建gulimall-common公共模块
    • 3、生成Coupon优惠模块
    • 4、生成member会员系统
    • 5、订单系统
    • 6、ware库存
    • 7、错误
    • 8、整合mybatis-plus
  • 五、安装中间件 阿里组件
    • 1、介绍
      • 1. SpringCloud 的几大痛点
      • 2. SpringCloud Alibaba 的优势:
      • 3. 当前项目 SpringCloud Alibaba 我们最终的技术搭配方案:
      • 4. 版本选择
    • 2、安装
      • 1. nocas-alibaba 注册中心
      • 2.openFeign-SpringCloud 远程调用
      • 3.nocas 配置中心
        • 配置中心详细内容
      • 4. 配置gateway网关
  • 参考文章


在这里插入图片描述

一、

服务治理

  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. 在这里插入图片描述
  3. 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 : 创建映射
3. 在这里插入图片描述在这里插入图片描述
4. 修改配置信息 添加开启 aof新版的默认开启了
5. 查看redis官方的配置信息,这个会了很重要

3、软件

1.Maven 阿里云镜像+1.8jdk

2、idea +lombok+mybatisX ,

3、 visualStudioCode

在这里插入图片描述

4、安装 git

三、项目环境搭建

1、创建后台项目

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

在这里插入图片描述

2. 下拉项目 gulimsll

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

在这里插入图片描述在这里插入图片描述选择spring在这里插入图片描述

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

![在这里插入图片描述](https://img-blog.csdnimg.cn/4a5e5248143a4d9bb946103457611698.png在这里插入图片描述

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文件
    <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. 导入依赖
<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映射文件位置
 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文件
   <!-- 注册中心-->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
  1. 配置主要看nacos的部分
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. 引包,之前的跟视频走的一个已经引过包了
     <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>
  1. 编写一个接口,告诉spring cloud 这个接口需要 gulimall-coupon 这个服务的远程调用
package com.atguigu.gulimall.member.feign;

/**
 * 这是一个声明式服务
 */
@FeignClient("gulimall-coupon")
public interface CouponFeignService {
    @RequestMapping("coupon/categorybounds/member/list")
    public R memberCoupons();
}

在这里插入图片描述

  1. 声明这个接口
@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"));
    }

在这里插入图片描述
5. 开启远程服务调用

@EnableFeignClients(basePackages = "com.atguigu.gulimall.member.feign")

在这里插入图片描述
6. 测试
在这里插入图片描述
原理

3.nocas 配置中心

  1. 映入依赖
        <!--配置中心 -->
        <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分组可以根据组名称去选择配置
    在这里插入图片描述
    在选择组

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

可以用命名空间来区分不同的微服务,分组来区分环境在这里插入图片描述
5. 同时加载多个配置集,把对应的配置放到对应创建的配置级里面 other放剩下的(nacos配置里面不要加空行,不要加中文)
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
6. 微服务的任何配置信息,和配置文件都可以放到配置中心 不改变之前取配置信息的方式
7. 只需要在bootstrap.properties说明加载配置中心哪个配置文件即可
8. 以前SpringBoot任何方法从配置文件中获取值,都能使用。
9. 配置中心和配置文件中的配置优先级:

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规则
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
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. 测试
    在这里插入图片描述

参考文章

个人笔记,不同意见,望有交流
直接可以点击跳转连接

作者 尚硅谷

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/450829.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

算法之滑动窗口

题目1:209. 长度最小的子数组 - 力扣&#xff08;LeetCode&#xff09; 解法⼀(暴力求解): 思路&#xff1a; 从前往后, 枚举数组中的任意⼀个元素, 把它当成起始位置, 然后从这个起始位置开始, 然 后寻找⼀段最短的区间, 使得这段区间的和「⼤于等于」⽬标值. 将所有元素作为…

Docker容器化技术(数据卷的管理)

数据卷 是一个可供容器使用的特殊目录&#xff0c;它将主机操作系统目录直接 映射进容器&#xff0c;类似于 Linux 中的 mount 行为 。 数据卷&#xff1a;可以提供很多有用的特性 数据卷可以在容器之间共事和重用&#xff0c;容器间传递数据将变得高效与方便&#xff1b;对数…

二分查找【详解】

本期介绍&#x1f356; 主要介绍&#xff1a;二分查找的简单思路&#xff0c;为什么必须在有序的前提下才能使用二分查找&#xff0c;该怎么用C程序来实现二分查找&#xff0c;二分查找的局限性&#x1f440;。 文章目录 1. 题目2. 思路3. 前提条件4. 编写程序 1. 题目 在一个有…

详解mfc140.dll文件,修复mfc140.dll缺失的多种方法

mfc140.dll文件是Windows操作系统中的一个非常重要的动态链接库文件。它不仅被广泛用于操作系统本身的正常运行&#xff0c;还被许多应用程序所依赖。 一、详解mfc140.dll文件 mfc140.dll是Microsoft Foundation Classes&#xff08;MFC&#xff09;库中的一个动态链接库&…

SpringBoot整合阿里云文件上传OSS以及获取oss临时访问url

SpringBoot整合阿里云文件上传OSS 1. 引入相关依赖<!--阿里云 OSS依赖--><dependency><groupId>com.aliyun.oss</groupId><artifactId>aliyun-sdk-oss</artifactId><version>3.10.2</version></dependency><dependen…

106. Dockerfile通过多阶段构建减小Golang镜像的大小

我们如何通过引入具有多阶段构建过程的Dockerfiles来减小Golang镜像的大小&#xff1f; 让我们从一个通用的Dockerfile开始&#xff0c;它负责处理基本的事务&#xff0c;如依赖项、构建二进制文件、声明暴露的端口等&#xff0c;以便为Go中的一个非常基础的REST API提供服务。…

常见的排序算法的时间复杂度

常见的排序算法的时间复杂度 排序算法的时间复杂度通常取决于输入数据的规模&#xff08;通常表示为n&#xff09;。以下是一些常见排序算法及其平均、最好和最坏情况下的时间复杂度&#xff1a; 1、冒泡排序&#xff08;Bubble Sort&#xff09; 平均时间复杂度&#xff1a;…

进程打开文件

目录 一、预备知识 二、操作文件函数 三、操作文件系统调用 四、理解进程打开文件 函数 vs 系统调用 open的返回值 fd 如何理解一切皆文件&#xff1f; 理解struct file 内核对象 fd的分配规则 && 重定向 理解标准错误流&#xff08;2号文件描述符&#xff0…

得帆助力大族激光主数据平台建设,用数据为企业生产力赋能

本期客户 大族激光科技产业集团股份有限公司&#xff08;以下简称“大族激光”&#xff09;是一家从事工业激光加工设备与自动化等配套设备及其关键器件的研发、生产、销售&#xff0c;激光、机器人及自动化技术在智能制造领域的系统解决方案的优质提供商&#xff0c;是国内激光…

如何通过四维轻云SDK开发打造智慧景区管理平台?

智慧景区管理平台通常是基于GIS技术&#xff0c;在三维实景地图的基础上&#xff0c;接入景区各类传感设备、第三方系统数据&#xff0c;进行业务功能的梳理及开发。但对于没有GIS开发经验的团队而言&#xff0c;地图开发具有一定的技术门槛&#xff0c;尤其是需要在前端解决好…

VR全景在智慧园区中的应用

VR全景如今以及广泛的应用于生产制造业、零售、展厅、房产等领域&#xff0c;如今720云VR全景更是在智慧园区的建设中&#xff0c;以其独特的优势&#xff0c;发挥着越来越重要的作用。VR全景作为打造智慧园区的重要角色和呈现方式已经受到了越来越多智慧园区企业的选择和应用。…

记事小本本

记事小本本 实现效果 相关代码 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document</titl…

Zookeeper详解

1.Zookeeper概述 1.Zookeeper概念 Zookeeper是 Apache Hadoop 项目下的一个子项目&#xff0c;是一个树形目录服务 Zookeeper 翻译过来就是动物园管理员&#xff0c;他是用来管 Hadoop&#xff08;大象&#xff09;、Hive(蜜蜂)、Pig(小猪)的管理员。简称zk Hadoop: 存储海…

Java项目:46 ssm005基于SSM框架的购物商城系统+jsp(含文档)

作者主页&#xff1a;源码空间codegym 简介&#xff1a;Java领域优质创作者、Java项目、学习资料、技术互助 文中获取源码 项目介绍 项目是单体ssm电商水果平台&#xff0c;包括前台商城平台及后台管理系统 前台商城系统包含首页门户、商品推荐、商品搜索、商品展示、购物车、…

Buuctf-Web-[极客大挑战 2019]EasySQL 1 题解及思路总结

​ 启动靶机 目录 题要做题过程第一步——找到页面与数据库产生交互的地方第二步——查看SQL语句闭合方式判断SQL注入闭合方式&#xff1a;方法一&#xff1a;使用\(转义字符)来判断SQL注入的闭合方式方法二&#xff1a;输入1、1、1"判断SQL语句闭合方式 第三步——进行SQ…

代理IP如何应对自动化测试和爬虫检测

目录 一、代理IP在自动化测试和爬虫中的作用 二、代理IP的优缺点分析 1.优点 2.缺点 三、应对自动化测试和爬虫检测的策略 1.选择合适的代理IP 2.设置合理的请求频率和间隔 3.模拟人类行为模式 4.结合其他技术手段 四、案例与代码示例 五、总结 在自动化测试和爬虫开…

Alpha突触核蛋白神经退行性疾病介绍

StressMarq——Alpha突触核蛋白&神经退行性疾病 Alpha突触核蛋白科研背景 • Alpha突触核蛋白约 15kDa, 140个氨基酸 • StressMarq/欣博盛生物在E. coli中过表达人源基因然后将蛋白从细胞质基质中纯化出来 • 未折叠的alpha突触核蛋白单体在12% SDS-PAGE上为~15 kDa的条…

CentOS本地部署Tale博客并结合内网穿透实现公网访问本地网站

文章目录 前言1. Tale网站搭建1.1 检查本地环境1.2 部署Tale个人博客系统1.3 启动Tale服务1.4 访问博客地址 2. Linux安装Cpolar内网穿透3. 创建Tale博客公网地址4. 使用公网地址访问Tale 前言 今天给大家带来一款基于 Java 语言的轻量级博客开源项目——Tale&#xff0c;Tale…

2022年吉林省大学生电子设计竞赛(D题)

一. 使用技术 PWM调速&#xff0c;PID&#xff0c;串口通信&#xff0c;陀螺仪测角度&#xff0c;蓝牙 二. 项目描述 大学的第一个比赛&#xff0c;项目采用主控stm32&#xff0c;车体采用一个四路电机驱动来驱动减速电机&#xff0c;小车依靠8路灰度循迹模块&#xff0c;实…

Keepalive+LVS群集部署

引言 Keepalived 是一个基于VRRP协议来实现的LVS服务高可用方案&#xff0c;可以解决静态路由出现的单点故障问题。 一、Keepalive概述 keepalive软件起初是专为 LVS 负载均衡软件设计的&#xff0c;用来管理并监控 LVS集群中各个服务节点的状态&#xff0c;后来又加入了可以…