tedu 四阶段springcloud学习day02学习总结(idea连接数据库/nacos远端调用及负载均衡策略/Feign方式远端调用)

目录

查看接口有哪些实现类 ctrl + h

一、cmd方式启动Nacos的命令

二、在IDEA中打开MySQL数据库

第一步: 打开View中数据库的工具栏

第二步:添加数据库为MySql

第三步:配置链接

第四步:在打开其余库

1,生成sql脚本

2,运行sql脚本

3,在IDEA中执行sql语句 

三、pom文件中配置讲解

1,pom文件中,标签的作用是为了导入父级模块/项目的jar包,一般定义在子工程中

3,pom文件中,标签会在创建子项目的时候自动生成,需要如下配置

 四,微服务实现

一、 实现远端调用的过程

 二、获取ProviderController类中的指定方法的参数名

三、设置负载均衡

四、简化负载均衡实现的代码

五、基于fegin的方式实现远程负载均衡调用及调用异常的处理

六、修改默认的负载均衡的策略


查看接口有哪些实现类 ctrl + h

一、cmd方式启动Nacos的命令

1, 启动necos,在nacos文件中打开bin目录,然后在bin目录下打开cmd控制窗口输入以下命令打开necos服务

startup.cmd -m standalone

2, 打开浏览器,地址栏输入localhost:8848/nacos打开nacos前端页面

localhost:8848/nacos

显示数据库占用的端口号:

show global variables like 'port';

二、在IDEA中打开MySQL数据库

第一步: 打开View中数据库的工具栏

第二步:添加数据库为MySql

第三步:配置链接

 点击:Test Connection

URL:

jdbc:mysql://127.0.0.1:3306/库名?serverTimezone=Asia/shanghai&characterEncoding=utf8

第四步:在打开其余库

1,生成sql脚本

2,运行sql脚本

3,在IDEA中执行sql语句 

三、pom文件中配置讲解

1,pom文件中,<parent>标签的作用是为了导入父级模块/项目的jar包,一般定义在子工程中

创建子模块的时候会自动生成

3,pom文件中,<modules>标签会在创建子项目的时候自动生成,需要如下配置

pom文件中当创建子模块时,父模块的pom文件会自动生成以下配置,要删除子模块,pom文件中也需要删除对应的配置,

pom文件中,<scope>标签的作用时定义该依赖在项目类中得导入方式,<type>标签时当<scope>标签中得值为import,type的值必须为pom

pom文件中,<scope>定义中provided的作用时定义了此依赖仅在编译期阶段有效

pom文件中,<scope>定义中test的作用时定义了此依赖仅在test目录才可以使用此依赖

微服务中父级pom代码

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <!--当前工程的坐标-->
    <groupId>com.jt</groupId>
    <artifactId>01-sca</artifactId>
    <packaging>pom</packaging>

    <version>1.0-SNAPSHOT</version>
    <modules>
        <module>sca-provider</module>
        <module>sca-consumer</module>
        <module>sca-geteway</module>
        <module>sca-common</module>
    </modules>

    <!--有的同学在创建maven工程时,可能会有如下有两句话,这两句话用于指定
    当前项目的jdk编译版本以及运行版本,也可以不指定,后续我们自己通过maven插件方式进行配置-->
    <!--
    <properties>
         <maven.compiler.source>8</maven.compiler.source>
         <maven.compiler.target>8</maven.compiler.target>
    </properties>
    -->
    <!--maven父工程的pom文件中一般要定义子模块,
    子工程中所需依赖版本的管理,公共依赖并且父工程的
    打包方式一般为pom方式-->

    <!--第一步: 定义子工程中核心依赖的版本管理(注意,只是版本管理)-->
    <dependencyManagement>
        <dependencies>
            <!--spring boot 核心依赖版本定义(spring官方定义)-->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-dependencies</artifactId>
                <version>2.3.2.RELEASE</version>
                <type>pom</type><!--允许scope的值为import时,type的值必须为pom-->
                <scope>import</scope><!--这里import类似与java中的import-->
            </dependency>

            <!--Spring Cloud 微服务规范(由spring官方定义)-->
            <!--spring cloud中定义的是一些微服务的规范-->
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>Hoxton.SR9</version>
                <type>pom</type><!--假如scope是import,type必须为pom-->
                <scope>import</scope><!--引入三方依赖的版本设计-->
            </dependency>

            <!--Spring Cloud alibaba 依赖版本管理 (参考官方说明)-->
            <!--spring cloud alibaba (这套依赖是基于spring cloud 做了落地实现的)-->
            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-alibaba-dependencies</artifactId>
                <version>2.2.6.RELEASE</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>
    <!--第二步: 添加子工程的所需要的公共依赖-->
    <dependencies>
        <!--lombok 依赖,子工程中假如需要lombok,不需要再引入-->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <scope>provided</scope><!--provided 表示此依赖仅在编译阶段有效-->
        </dependency>
        <!--单元测试依赖,子工程中需要单元测试时,不需要再次引入此依赖了-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope><!--test表示只能在test目录下使用此依赖-->
            <!--springboot 中-->
            <exclusions>
                <exclusion><!--排除一些不需要的依赖-->
                    <groupId>org.junit.jupiter</groupId>
                    <artifactId>junit-jupiter-engine</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <!--其它依赖...-->
    </dependencies>
    <!--第三步: 定义当前工程模块及子工程的的统一编译和运行版本-->
    <build><!--项目构建配置,我们基于maven完成项目的编译,测试,打包等操作,
    都是基于pom.xml完成这一列的操作,但是编译和打包的配置都是要写到build元素
    内的,而具体的编译和打包配置,又需要plugin去实现,plugin元素不是必须的,maven
    有默认的plugin配置,常用插件可去本地库进行查看-->
        <plugins>
            <!--通过maven-compiler-plugin插件设置项目
            的统一的jdk编译和运行版本-->
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <!--假如本地库没有这个版本,这里会出现红色字体错误-->
                <version>3.8.1</version>
                <configuration>
                    <source>8</source>
                    <target>8</target>
                </configuration>
            </plugin>
        </plugins>
    </build>

</project>

 四,微服务实现

构建三个子项目

配置服务提供端和服务消费端,pom文件 

一、 实现远端调用的过程

第一种 : RestTemplate实现远程调用及负载均衡
第二种 : Feign方式远程调用及负载均衡

第一步:编写服务及yml文件

第二步:启动服务提供者的主启动类 

第三步:在服务的消费端创建一个新的启动类,将Rest Template对象交给Spring容器管理

 第四步:编写yml配置

 第五步:编写Controller实现远端调用

 二、获取ProviderController类中的指定方法的参数名

第一步:新建一个Test测试类

第二步:在父级pom文件中添加配置

 第三步:运行test类查看结果

三、设置负载均衡

业务描述 :

一个服务实例可以处理请求是有限的,假如服务实例的并发访问比较大,我们会启动多个服务实例,让这些服务实例采用一定策略均衡(轮询,权重,随机,hash等)的处理并发请求,在Nacos中服务的负载均衡(Nacos客户端负载均衡)是如何应用的?

LoadBalancerClient应用 :

LoadBalancerClient对象可以从nacos中基于服务名获取服务实例,然后在工程中基于特点算法实现负载均衡方式的调用

 第一步 : 编辑consumer访问方式(自定义负载均衡策略/使用loadBalancerClient实现负载均衡策略) 

第二步 :  设置provider中默认的主启动类的启动策略

 第三步 : 修改provider项目中的yam文件

小结面试 : 

为什么要将服务注册到nacos?(为了更好的查找这些服务)
在Nacos中服务提供者是如何向Nacos注册中心(Registry)续约的?(5秒心跳)
对于Nacos服务来讲它是如何判定服务实例的状态?(检测心跳包,15,30)
服务消费方是如何调用服务提供方的服务的?(RestTemplate)

四、简化负载均衡实现的代码

1. 在consumer的主启动类上添加方法

2. 在consumerController中进行远端调用

五、基于fegin的方式实现远程负载均衡调用及调用异常的处理

 第一步:在服务的消费方consumer中添加依赖

 第二步:在服务的消费方consumer的主启动类中添加使Feign注解生效的注解

第三步 : 新建一个接口

第四步 : 新建一个新的controller层

        一个服务提供方通常会提供很多资源服务,服务消费方基于同一个服务提供方写了很多服务调用接口,此时假如没有指定contextId,服务启动就会失败,例如,假如在服务消费方再添加一个如下接口,消费方启动时就会启动失败

 第五步 : 创建一个远端调用异常处理工厂类 

第六步 : 完善RemoteProviderService接口,避免本项目调用报错,避免获取远端服务时发生异常报错没有处理方法  第七步 : 将provider中被远程调用的服务进行睡眠,用于测试被调用超时异常

六、修改默认的负载均衡的策略 

负载均衡分析及解决方案?(提高系统的并发处理能力,通过多个服务实例处理客户端的请求)

@LoadBalanced注解是属于Spring,而不是Ribbon的,Spring在初始化容器的时候,如果检测到Bean被@LoadBalanced注解,Spring会为其设置LoadBalancerInterceptor的拦截器。

Ribbon负载均衡策略(了解)
基于Ribbon方式的负载均衡,Netflix默认提供了七种负载均衡策略,对于SpringCloud Alibaba解决方案中又提供了NacosRule策略,默认的负载均衡策略是轮训策略。如图所示:

Ribbon负载均衡策略(了解)
基于Ribbon方式的负载均衡,Netflix默认提供了七种负载均衡策略,对于SpringCloud Alibaba解决方案中又提供了NacosRule策略,默认的负载均衡策略是轮训策略。如图所示:

当系统提供的负载均衡策略不能满足我们需求时,我们还可以基于IRule接口自己定义策略.

第一步 : 

方式一:

在consumer启动配置类中添加策略

方式二:

在application.yml中修改

Feign
第一步 导入依赖

第二步  ,在主启动类上添加@EnableFeignClients注解   

第三步:创建一个业务层需要注入的接口

填写接口中方法

第四步:创建实现注入的类 

第五步,在浏览器中测试

加入访问服务超时,返回给服务器"服务器超时,稍等片刻"

想要让用户接收到服务器长时间未响应不报异常信息,而是反馈给用户浏览器一些数据需要在yml文件中添加以下配置

 在provide项目的controller中添加睡眠锁Thread.sleep(5000)进行睡眠测试

今日注解内容:

@EnableFeignClients : 注解用户描述一些配置类,告诉系统底层启动时为@FeginClient注解描述的接口创建实现类对象,然后交给Spring管理

@LoadBalanced 描述REstTemplate对象时,是告诉底层为RestTemplate对象注入一个负载均衡拦截器,当我们使用restTemplate进行远程调用时,首先执行负载均衡拦截器的方法,在访问内部,基于服务发现这种机制,从nacos获取服务实例,然后在进行远程调用,底层有默认负载均衡

学习了Spring容器设计到哪些设计模式(单例设计/模板方法设计/观察者模式/代理模式/工厂模式/策略设计模式/享元设计模式)

策略设计模式 : 负载均衡的策略(随机/权重/轮询/hash)

单例设计模式 : 

享元设计模式 : 减少对象创建,bean池中获取

 

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用IDEA创建Git暂存区的过程中,可以按照以下步骤进行操作: 1. 在IDEA的顶部菜单栏中选择VCS(Version Control System)选项,然后选择"Import into Version Control",再选择"Create Git Repository"来创建一个Git本地库。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [如何使用git接管idea项目文件、如何将idea项目中的文件添加至git暂存区、如何将idea项目中添加至暂存区的...](https://blog.csdn.net/qq_43768851/article/details/124305830)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [Git 第七章 IDEA集成Git -- IDEA集成Git(初始化本地库 & 添加到暂存区 & 提交代码到本地仓库 & 切换版本...](https://blog.csdn.net/I_r_o_n_M_a_n/article/details/120799423)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [IDEA中使用Git(史上最全最详细)(tedu2)(教学操作视频+源代码)](https://download.csdn.net/download/weixin_46411355/87264291)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值