码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • springcloud微服务(一)(了解微服务、eureka注册中心、Ribbon负载均衡)


    文章目录

    • 一 微服务技术栈介绍
    • 二、认识微服务
      • 2.1 服务架构演变
      • 2.2 Spring Cloud
    • 三 服务拆分
      • 3.1 服务拆分注意事项
      • 3.2 服务拆分
        • 3.2.1 如何发送http请求,做远程调用
    • 四、 Eureka注册中心
      • 4.1 Eureka的作用
      • 4.2 Eureka实栈
        • 4.2.1 创建maven模块,继承父模块、引入maven引来
        • 4.2.2 创建启动类
        • 4.2.3 配置好application.yml文件
        • 4.2.4 将user-service服务注册到EurekaServer
        • 4.2.5 服务拉取
    • 五 负载均衡Ribbon
      • 5.1 负载均衡流程
      • 5.2 负载均衡策略
      • 5.3 Ribbon的懒加载


    一 微服务技术栈介绍

    在这里插入图片描述

    微服务治理、缓存技术、异步通信、分布式搜索技术、持续继承(DevOps)
    
    • 1

    在这里插入图片描述

    在这里插入图片描述

    二、认识微服务

    2.1 服务架构演变

    单体结构优缺点:
    
    • 1

    在这里插入图片描述

    微服务:
    
    • 1

    在这里插入图片描述

    2.2 Spring Cloud

    在这里插入图片描述

    三 服务拆分

    3.1 服务拆分注意事项

    1.不同微服务,不能重复开发相同业务
    2.微服务数据独立,不要访问其他微服务的数据库 
    3.微服务可以将自己的业务暴露为接口,供其他微服务调用
    
    • 1
    • 2
    • 3

    源码在D/idea Project/cloudcode-master
    在这里插入图片描述

    3.2 服务拆分

    案例分析:
    
    • 1

    在这里插入图片描述

    3.2.1 如何发送http请求,做远程调用

    spring提供的RestTemplate可以发送各种各样的http请求。
    
    • 1

    在这里插入图片描述
    步骤:

    1.注册RestTemplate(在启动器中)

    /**
        * Description: 创建RestTemplate并注入Spring容器
        * @date:2022/7/27 12:07
        * @params: []
        * @return: org.springframework.web.client.RestTemplate
        */
        @Bean
        public RestTemplate restTemplate(){
            return new RestTemplate();
        }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    1. 修改order-service中的OrderService的queryOrderById方法(利用RestTemplate中的getForObject方法,告诉它请求的路径和返回值的类型,就会把返回的json转换成对应的类型)
    public Order queryOrderById(Long orderId) {
            // 1.查询订单
            Order order = orderMapper.findById(orderId);
            // TODO: 2021/8/15  2.查询用户
            User user = restTemplate.getForObject("http://localhost:8081/user/" + order.getUserId(), User.class);
            // 3. 将用户信息封装进订单
            order.setUser(user);
            // 4.返回
            return order;
        }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    在这里插入图片描述

    四、 Eureka注册中心

    4.1 Eureka的作用

    Eureka架构中,微服务角色有两类:
    	*EurekaServer: 服务端,注册中心
    			** 记录服务信息
    			** 心跳监控
    	*EurekaClient:客户端
    			**Provoder:服务提供者
    						*** 注册自己的信息到EurekaServer
    						*** 每隔30秒向EurekaServer发送心跳
    			** consumer:服务消费者,例如案例中的order-service
    						***根据服务名称从EurekaServer中拉取服务列表
    						***基于服务列表做负载均衡,选中一个微服务后发起远程调用				
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    在这里插入图片描述

    在这里插入图片描述

    4.2 Eureka实栈

    4.2.1 创建maven模块,继承父模块、引入maven引来

    <dependencies>
            <dependency>
                <groupId>org.springframework.cloudgroupId>
                <artifactId>spring-cloud-starter-netflix-eureka-serverartifactId>
            dependency>
        dependencies>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    4.2.2 创建启动类

    @EnableEurekaServer
    @SpringBootApplication
    public class EurekaApplication {
        public static void main(String[] args) {
            SpringApplication.run(EurekaApplication.class, args);
    
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    4.2.3 配置好application.yml文件

    server:
      port: 10086 # 服务端口
    spring:
      application:
        name: eurekaserver # eureka的服务名称
    eureka:
      client:
        service-url: # eureka的地址信息
          defaultZone: http://127.0.0.1:10086/eureka
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    访问地址,服务注册
    在这里插入图片描述

    4.2.4 将user-service服务注册到EurekaServer

    1.引入依赖(user-service模块中)
    
    • 1
    
            <dependency>
                <groupId>org.springframework.cloudgroupId>
                <artifactId>spring-cloud-starter-netflix-eureka-clientartifactId>
            dependency>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    2.在user-service的application.yml文件中,配置如下:
    
    • 1
    spring:
      application:
        name: eurekaserver # eureka的服务名称
    eureka:
      client:
        service-url: # eureka的地址信息
          defaultZone: http://127.0.0.1:10086/eureka
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    如果想给一个服务启动多个实例,idea中 Copy Configuration
    
    • 1

    在这里插入图片描述

    4.2.5 服务拉取

    order-service可以基于服务名称拉取到user-service的两个实例信息,实现负载均衡。
    
    • 1

    在这里插入图片描述
    访问http://localhost:8080/order/101和http://localhost:8080/order/102
    发现user-service控制台有信息,说明两次服务均被拉取到,实现了负载均衡和远程调用。

    五 负载均衡Ribbon

    5.1 负载均衡流程

    在这里插入图片描述

    5.2 负载均衡策略

    配置文件方式和代码方式
    轮询和随机
    
    • 1
    • 2

    在这里插入图片描述

    5.3 Ribbon的懒加载

    Ribbon默认是用懒加载,即第一次访问时才会去创建LoadBalanceClient,请求时间会很长。而饥饿加载则会在项目启动时创建,降低第一次访问的耗时,通过配置开启饥饿加载。
    在这里插入图片描述

  • 相关阅读:
    计算机网络学习易错点
    Java之反射
    基于工程车辆/物流车辆/消防车辆远程通信的车队管理解决方案
    MCU(单片机)datasheet(规格说明书)
    2022年全国大学生数学建模竞赛E题目-小批量物料生产安排详解+思路+Python代码时序预测模型(二)
    【数据结构】单链表按位序插入元素e【前插】(带头结点的和不带头结点的)这篇很重要,文字说明比起其他篇是正确的
    gin框架常见用法大全
    SpringBoot-打印请求的入参和出参
    杂记1234
    类之间的关系
  • 原文地址:https://blog.csdn.net/weixin_45139640/article/details/125999023
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号