微服务(二)-微服务实例

本文涉及的产品
应用型负载均衡 ALB,每月750个小时 15LCU
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
云原生网关 MSE Higress,422元/月
简介: 微服务(二)-微服务实例

代码说明:提供一个微服务实例

创建两个模块:micro-provider:服务提供者,micro-consumer:服务消费者

micro-consumer可以有很多个,去消费。

1、常见micro-provider的工程:

1.1、引入相关的依赖如下

1.2、配置一些属性的配置信息:

1.3、提供一个domain的UserInfo的实体类:用户信息

类的结构就是get和set方法的结构

1.4、提供一个mapper的接口:

1.5、在主类里面加上MapperScan的注解,去把mapper接口生成的代理实现类去交给Spring容器管理。

1.6、由于接口会形成映射的,由于是单表操作的就不去写xml文件了。直接用注解的方式,代码如下:

1.7、新建一个service接口和实现类,代码如下:

1.8、新建一个controller,由于provider是要提供服务的。由于服务是rest风格的。所以说在spring4.3以后出现一个统一接口的注解@RestController

上面就是一个简单的springBoot应用就搭建成功了。

1.9、运行下上面的应用:

访问的结果如下 :是一个json的格式。因为它默认是使用jackson来序列化对象的。


restAPI来源于controller里面提供的路径。SpringBoot是一个入门的微框架。springBoot的项目就可以称之为简单的微服务应用。


2、在建一个micro-consumer的springBoot项目,因为它相当于一个前端的应用,所以依赖只要是一个web就可以了。既然是前端的服务,只需要提供json字符串就可以了。

2.1、新建一个vo->userVo的实体类用于给前台展示的,代码如下:

2.2、在微服务中应用通信的两种方式

A、RestTemplate

写一个配置类来获取RestTemplate对象,代码如下:

  1. package com.boot.micro.demo.microconsumer.config;
  2. import org.springframework.boot.SpringBootConfiguration;
  3. import org.springframework.context.annotation.Bean;
  4. import org.springframework.web.client.RestTemplate;
  5. @SpringBootConfiguration
  6. public class RestTemplateConfig {
  7.    @Bean
  8.    public RestTemplate restTemplate(){
  9.        return new RestTemplate();
  10.    }
  11. }

客户端通过RestTemplate的一个模板完成了对rest风格的调用,代码如下:

  1. package com.boot.micro.demo.microconsumer.controller;
  2. import com.boot.micro.demo.microconsumer.vo.UserVo;
  3. import org.springframework.beans.factory.annotation.Autowired;
  4. import org.springframework.web.bind.annotation.GetMapping;
  5. import org.springframework.web.bind.annotation.PathVariable;
  6. import org.springframework.web.bind.annotation.RestController;
  7. import org.springframework.web.client.RestTemplate;
  8. @RestController
  9. public class UserWrapController {
  10.    @Autowired
  11.    private RestTemplate  restTemplate;
  12.    @GetMapping("warp/user/{id}")
  13.    public UserVo getUser(@PathVariable("id") Integer userId){
  14.        return restTemplate.getForObject("http://localhost:8080/user/"+userId,
  15.         UserVo.class);
  16.    }
  17. }

现在运行下客户端,然后访问下:

vo的实体类中的字段也可以不和提供服务的项目中的实体类的属性一样也可以,只要能够映射成一样就可以,代码如下:

再次运行下:

提问:如果micro-provider部署了三台服务器的话,客户端来调用,到底调用的是哪一个呢?这就涉及到了,多服务实例部署的时候就涉及到了负载均衡。所以说上面的方式是做不了负载均衡的。

负载均衡:让很多的实例去减少原有服务的压力然后把它做成了多个节点部署了多个节点,从而减少原有一个服务实例的压力。能力越强的承担的越大。

如果想要做负载均衡的话,需要把micro-provider定义一个应用名称:

然后把micro-provider配置三台:

把上面的三个微服务的实例给启动起来:

如果想要做负载均衡的话,用上面的方式是不行的,因为端口不一样了,上面的方式是写死的方式的。如果想要做负载均衡的话,必须引入一个负载均衡框架,这三个微服务实例是有注册的。然后客户端才能去发现的。需要有一个路由,来路由上面的三个微服务实例的才行。

1、加入服务注册中心,要把服务发现组件加进来才行,需要把服务的地址放到服务注册中心上去。正常的情况是客户端去访问哪一个服务端的地址是不知道的,而且为了保证服务端的的安全,不可能把服务端的ip地址告诉客户端。zookeeper其实是一个协调服务的一个组件。没有什么具体业务功能的实现。在zk中有watcher机制(有点类似于javaWeb中的监听器)和节点类型

下面的图是发布和订阅的模式。客户端去服务注册中心去提取列表,然后去做整个的负载均衡。

1、引入springCloud的依赖管理:

  1. <dependencyManagement>
  2.        <dependencies>
  3.            <dependency>
  4.                <groupId>org.springframework.cloud</groupId>
  5.                <artifactId>spring-cloud-dependencies</artifactId>
  6.                <version>Finchley.SR2</version>
  7.                <type>pom</type>
  8.                <scope>import</scope>
  9.            </dependency>
  10.        </dependencies>
  11.    </dependencyManagement>

2、引入zookeeper

  1.   <!--引入zookeeper-->
  2.        <dependency>
  3.            <groupId>org.springframework.cloud</groupId>
  4.            <artifactId>spring-cloud-starter-zookeeper-all</artifactId>
  5.            <exclusions>
  6.                <exclusion>
  7.                    <groupId>org.apache.zookeeper</groupId>
  8.                    <artifactId>zookeeper</artifactId>
  9.                </exclusion>
  10.            </exclusions>
  11.        </dependency>
  12.        <dependency>
  13.            <groupId>org.apache.zookeeper</groupId>
  14.            <artifactId>zookeeper</artifactId>
  15.            <version>3.4.12</version>
  16.            <exclusions>
  17.                <exclusion>
  18.                    <groupId>org.slf4j</groupId>
  19.                    <artifactId>slf4j-log4j12</artifactId>
  20.                </exclusion>
  21.            </exclusions>
  22.        </dependency>

3、配置zookeeper:

4、如果想要被客户端发现的话,需要加上一个注解:

5、然后分别去启动下服务端的三个实例:

这个就是把三个微服务的实例注册上了zookeeper上了。

每个节点的内容如下:name为provider。id:是每一个节点的uuid的值。

address是本机的名字,也就是代表主机。port:8081。在每一个节点都已经记录好了这些内容的。最重要的是端口号和ip地址。

6、客户端也需要引入zookeeper的依赖:

客户端就可以运用zookeeper中的ribbon的负载均衡机制

ribbon当中其实有两个组件:httpclient(客户端调用)和loadbalancer(负载均衡器,因为它是从客户端拉取到可用的服务列表)

loadbalancer:这个自动有负载均衡策略的。它 针对SpringCloud所有的服务发现都可以来做的。

7、客户端的配置文件的配置如下:

8、客户端的主类函数如下,

9、由于客户端是发现zookeeper上的服务列表的,所以也需要加上启用服务发现的注解,代码如下:

10、然后启动消费端,连续访问6次:

下面的结果就是轮巡的方式做了负载的。

服务端每个节点都打印两条sql.

上面的方式就可以做到了负载均衡。

第三种方式:

1、加上@LoadBalanced注解

这种方式默认的方式也是轮巡的方式。


下面的接口里面是负载均衡的机制:这个接口里面有随机的策略,重试的策略。

轮巡策略,权重策略。

总结:在微服务中服务与服务的通信是通过restf风格的方式来进行通信的,上面的方式是ribbon加上restTemplate方式来实现的,ribbon在微服务中做客户端的负载均衡充当了重要的角色。服务端的负载均衡可以通过nginx来做。

相关实践学习
基于MSE实现微服务的全链路灰度
通过本场景的实验操作,您将了解并实现在线业务的微服务全链路灰度能力。
相关文章
|
Java 微服务 Spring
从0到1 手把手搭建spring cloud alibaba 微服务大型应用框架(六)(优化篇)开发篇-如何解决微服务开发环境请求实例转发到别人机器问题
从0到1 手把手搭建spring cloud alibaba 微服务大型应用框架(六)(优化篇)开发篇-如何解决微服务开发环境请求实例转发到别人机器问题
从0到1 手把手搭建spring cloud alibaba 微服务大型应用框架(六)(优化篇)开发篇-如何解决微服务开发环境请求实例转发到别人机器问题
|
5月前
|
微服务
微服务多机房部署大揭秘:全局单一实例、全局多实例,一文让你彻底解锁!
【8月更文挑战第25天】本文探讨了微服务架构中的多机房部署策略,包括全局单一与多实例、区域及机房多实例等方法,分析了它们在可用性、容错性、扩展性和成本上的差异。示例展示了如何利用AWS CloudFormation实现跨不同机房的微服务部署。这为实际应用场景提供了有价值的参考和指导。
159 2
|
缓存 Nacos 微服务
Nacos2.2.3版本,微服务注册上去了,然后关闭,注册实例还是显示健康,一直在那,要等大概一小时以后才消失
Nacos2.2.3版本,微服务注册上去了,然后关闭,注册实例还是显示健康,一直在那,要等大概一小时以后才消失,怎么解决?
758 1
|
8月前
|
监控 负载均衡 Java
【阿里云云原生专栏】微服务架构在阿里云云原生平台上的应用实例与优化策略
【5月更文挑战第20天】本文介绍了在阿里云云原生平台实现微服务架构的步骤,包括基于Spring Cloud的Docker化部署、使用ACK部署微服务,以及优化策略:服务发现与负载均衡(借助Istio)和监控日志管理。通过这种方式,企业能提升应用的可扩展性、可维护性和敏捷性。
277 5
|
负载均衡 前端开发 Java
从0到1 手把手搭建spring cloud alibaba 微服务大型应用框架(六)开发篇-如何解决微服务开发环境请求实例转发到别人机器问题
从0到1 手把手搭建spring cloud alibaba 微服务大型应用框架(六)开发篇-如何解决微服务开发环境请求实例转发到别人机器问题
从0到1 手把手搭建spring cloud alibaba 微服务大型应用框架(六)开发篇-如何解决微服务开发环境请求实例转发到别人机器问题
|
缓存 负载均衡 Cloud Native
【云原生&微服务四】SpringCloud之Ribbon和Erueka/服务注册中心的集成细节(获取服务实例列表、动态更新服务实例信息、负载均衡出一个实例、IPing机制判断实例是否存活)
【云原生&微服务四】SpringCloud之Ribbon和Erueka/服务注册中心的集成细节(获取服务实例列表、动态更新服务实例信息、负载均衡出一个实例、IPing机制判断实例是否存活)
469 0
【云原生&微服务四】SpringCloud之Ribbon和Erueka/服务注册中心的集成细节(获取服务实例列表、动态更新服务实例信息、负载均衡出一个实例、IPing机制判断实例是否存活)
|
监控 Dubbo Cloud Native
近万服务实例稳定运行 0 故障,携程微服务架构是如何落地的?
本文整理自作者于 2020 年云原生微服务大会上的分享《携程微服务框架实践及思考》,主要介绍了从携程自研框架遇到的问题,转到落地 Dubbo 微服务框架,携程是如何实践的,以及实践过程中遇到的问题;未来转型 service mesh 的道路上,dubbo 协议存在的问题,我们需要怎么样的协议层以及微服务 SDK 的定位。
近万服务实例稳定运行 0 故障,携程微服务架构是如何落地的?
|
Web App开发 Java 测试技术
分布式、微服务架构Spring Boot入门及实例介绍
spring boot入门 -- 介绍和第一个例子 “越来越多的企业选择使用spring boot 开发系统,spring boot牛在什么地方?难不难学?心动不如行动,让我们一起开始学习吧!” 使用Spring boot ,可以轻松的创建独立运行的程序,非常容易构建独立的服务组件,是实现分布式架构、微服务架构利器。
1824 0
|
Java Maven 微服务
微服务实战之春云与刀客(三)—— 面向接口调用代码结构实例
概述 在上一篇中提到了spring cloud 面向接口调用的开发风格,这一篇会举一个简单的但完整的例子来说明整个代码结构。代码已上传到 https://github.com/maruixiang/spring-cloud-demo/tree/master/demo1 代码结构 整个代码在demo1目录下面,包含了一个根级的parent pom文件和三个maven应用。
3002 0