一、使用LoadBalancerClient

LoadBalancerClient接口的命名中,可以看出这是一个负载均衡客户端的抽象定义,spring提供了一个实现

org.springframework.cloud.netflix.ribbon.RibbonLoadBalancerClient

1、pom.xml

<parent>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-parent</artifactId>

<version>2.1.7.RELEASE</version>

<relativePath /> <!-- lookup parent from repository -->

</parent>

<dependencies>

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-actuator</artifactId>

</dependency>

<dependency>

<groupId>org.springframework.cloud</groupId>

<artifactId>spring-cloud-starter-consul-discovery</artifactId>

</dependency>

<!-- https://mvnrepository.com/artifact/com.alibaba/fastjson -->

<dependency>

<groupId>com.alibaba</groupId>

<artifactId>fastjson</artifactId>

<version>1.2.47</version>

</dependency>

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-thymeleaf</artifactId>

</dependency>

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-web</artifactId>

</dependency>

<!-- spring boot test -->

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-test</artifactId>

<scope>test</scope>

</dependency>

</dependencies>

2、application.yml

server:

#服务端口号

port: 8080

spring:

application:

#服务名称

name: vis-basic-report

thymeleaf:

cache: false

cloud:

consul:

host: 192.168.12.125

port: 8500

discovery:

#是否需要注册到consul中

register: true

#服务地址直接为IP地址

hostname: 192.168.12.1

management:

endpoints:

web:

exposure:

include: '*'

3、启动类

package com.wzl.springcloud.basic.report;

import org.springframework.boot.SpringApplication;

import org.springframework.boot.autoconfigure.SpringBootApplication;

import org.springframework.boot.web.servlet.ServletRegistrationBean;

import org.springframework.cloud.client.discovery.EnableDiscoveryClient;

import org.springframework.context.annotation.Bean;

import com.netflix.hystrix.contrib.metrics.eventstream.HystrixMetricsStreamServlet;

@SpringBootApplication

@EnableDiscoveryClient

public class ReportServerApplication {

public static void main(String[] args) {

SpringApplication.run(ReportServerApplication.class, args);

}

}

4、相关实现类

package com.wzl.springcloud.basic.report.service;

import java.util.List;

import com.wzl.springcloud.basic.report.vo.City;

import com.wzl.springcloud.basic.report.vo.WeatherResponse;

public interface WeatherReportService {

// 根据城市ID同步天气

WeatherResponse getDataByCityId(String cityId);

// 根据城市name同步天气

WeatherResponse getDataByCityName(String cityName);

// 获取所有城市列表

List<City> getDataByCities();

}

package com.wzl.springcloud.basic.report.service.impl;

import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.cloud.client.ServiceInstance;

import org.springframework.cloud.client.loadbalancer.LoadBalancerClient;

import org.springframework.http.ResponseEntity;

import org.springframework.stereotype.Service;

import org.springframework.web.client.RestTemplate;

import com.alibaba.fastjson.JSON;

import com.wzl.springcloud.basic.report.service.WeatherReportService;

import com.wzl.springcloud.basic.report.vo.City;

import com.wzl.springcloud.basic.report.vo.WeatherResponse;

/**

* LoadBalancer客户端

*/

@Service

public class WeatherReportServiceLoadBalancerClientImpl implements WeatherReportService {

@Autowired

private LoadBalancerClient loadBalancer;

@Override

public WeatherResponse getDataByCityId(String cityId) {

WeatherResponse weatherResponse = null;

ServiceInstance serviceInstance = loadBalancer.choose("vis-basic-weather");

String uri = serviceInstance.getUri().toString() + "/weather/cityId/" + cityId;

// 调用服务接口来获取

ResponseEntity<String> respString = new RestTemplate().getForEntity(uri, String.class);

// 判断ResponseEntity的状态码是否为200,为200时取出strBody

if (respString.getStatusCodeValue() == 200) {

String jsonStr = respString.getBody();

weatherResponse = JSON.parseObject(jsonStr, WeatherResponse.class);

}

return weatherResponse;

}

@Override

public WeatherResponse getDataByCityName(String cityName) {

WeatherResponse weatherResponse = null;

ServiceInstance serviceInstance = loadBalancer.choose("vis-basic-weather");

String uri = serviceInstance.getUri().toString() + "/weather/cityName/" + cityName;

// 调用服务接口来获取

ResponseEntity<String> respString = new RestTemplate().getForEntity(uri, String.class);

// 判断ResponseEntity的状态码是否为200,为200时取出strBody

if (respString.getStatusCodeValue() == 200) {

String jsonStr = respString.getBody();

weatherResponse = JSON.parseObject(jsonStr, WeatherResponse.class);

}

return weatherResponse;

}

@Override

public List<City> getDataByCities() {

List<City> cityList = null;

ServiceInstance serviceInstance = loadBalancer.choose("vis-basic-city");

String uri = serviceInstance.getUri().toString() + "/cities/getList";

// 调用服务接口来获取

ResponseEntity<String> respString = new RestTemplate().getForEntity(uri, String.class);

// 判断ResponseEntity的状态码是否为200,为200时取出strBody

if (respString.getStatusCodeValue() == 200) {

String jsonStr = respString.getBody();

cityList = JSON.parseArray(jsonStr, City.class);

}

return cityList;

}

}

二、使用Ribbon

Spring Cloud Ribbon是基于Netflix Ribbon实现的一套客户端负载均衡的工具。它是一个基于HTTP和TCP的客户端负载均衡器。它可以通过在客户端中配置ribbonServerList来设置服务端列表去轮询访问以达到均衡负载的作用。

1、pom.xml

<parent>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-parent</artifactId>

<version>2.1.7.RELEASE</version>

<relativePath /> <!-- lookup parent from repository -->

</parent>

<dependencies>

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-actuator</artifactId>

</dependency>

<dependency>

<groupId>org.springframework.cloud</groupId>

<artifactId>spring-cloud-starter-consul-discovery</artifactId>

</dependency>

<!-- https://mvnrepository.com/artifact/com.alibaba/fastjson -->

<dependency>

<groupId>com.alibaba</groupId>

<artifactId>fastjson</artifactId>

<version>1.2.47</version>

</dependency>

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-thymeleaf</artifactId>

</dependency>

<dependency>

<groupId>org.springframework.cloud</groupId>

<artifactId>spring-cloud-starter-netflix-ribbon</artifactId>

</dependency>

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-web</artifactId>

</dependency>

<!-- spring boot test -->

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-test</artifactId>

<scope>test</scope>

</dependency>

</dependencies>

2、application.yml

server:

#服务端口号

port: 8080

spring:

application:

#服务名称

name: vis-basic-report

thymeleaf:

cache: false

cloud:

consul:

host: 192.168.12.125

port: 8500

discovery:

#是否需要注册到consul中

register: true

#服务地址直接为IP地址

hostname: 192.168.12.1

management:

endpoints:

web:

exposure:

include: '*'

3、启动类 & RestConfiguration

package com.wzl.springcloud.basic.report;

import org.springframework.boot.SpringApplication;

import org.springframework.boot.autoconfigure.SpringBootApplication;

import org.springframework.cloud.openfeign.EnableFeignClients;

@SpringBootApplication

@EnableFeignClients

public class ReportServerApplication {

public static void main(String[] args) {

SpringApplication.run(ReportServerApplication.class, args);

}

}

package com.wzl.springcloud.basic.report.config;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.boot.web.client.RestTemplateBuilder;

import org.springframework.cloud.client.loadbalancer.LoadBalanced;

import org.springframework.context.annotation.Bean;

import org.springframework.context.annotation.Configuration;

import org.springframework.web.client.RestTemplate;

@Configuration

public class RestConfiguration {

@Autowired

private RestTemplateBuilder builder;

@Bean

@LoadBalanced

public RestTemplate restTemplate() {

return builder.build();

}

}

@LoadBalanced注解表明这个restRemplate开启负载均衡的功能,用外汇返佣LoadBalancerClient配置,并且会替换URL中的服务名称为具体的IP地址

4、相关实现类

package com.wzl.springcloud.basic.report.service;

import java.util.List;

import com.wzl.springcloud.basic.report.vo.City;

import com.wzl.springcloud.basic.report.vo.WeatherResponse;

public interface WeatherReportService {

// 根据城市ID同步天气

WeatherResponse getDataByCityId(String cityId);

// 根据城市name同步天气

WeatherResponse getDataByCityName(String cityName);

// 获取所有城市列表

List<City> getDataByCities();

}

package com.wzl.springcloud.basic.report.service.impl;

import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.http.ResponseEntity;

import org.springframework.stereotype.Service;

import org.springframework.web.client.RestTemplate;

import com.alibaba.fastjson.JSON;

import com.wzl.springcloud.basic.report.service.WeatherReportService;

import com.wzl.springcloud.basic.report.vo.City;

import com.wzl.springcloud.basic.report.vo.WeatherResponse;

/**

* Ribbon客户端

*/

@Service

public class WeatherReportServiceRibbonImpl implements WeatherReportService {

@Autowired

// 对rest客户端的封装

private RestTemplate restTemplate;

@Override

public WeatherResponse getDataByCityId(String cityId) {

WeatherResponse weatherResponse = null;

String uri = "http://vis-basic-weather/weather/cityId/" + cityId;

// 调用服务接口来获取

ResponseEntity<String> respString = restTemplate.getForEntity(uri, String.class);

// 判断ResponseEntity的状态码是否为200,为200时取出strBody

if (respString.getStatusCodeValue() == 200) {

String jsonStr = respString.getBody();

weatherResponse = JSON.parseObject(jsonStr, WeatherResponse.class);

}

return weatherResponse;

}

@Override

public WeatherResponse getDataByCityName(String cityName) {

WeatherResponse weatherResponse = null;

String uri = "http://vis-basic-weather/weather/cityName/" + cityName;

// 调用服务接口来获取

ResponseEntity<String> respString = restTemplate.getForEntity(uri, String.class);

// 判断ResponseEntity的状态码是否为200,为200时取出strBody

if (respString.getStatusCodeValue() == 200) {

String jsonStr = respString.getBody();

weatherResponse = JSON.parseObject(jsonStr, WeatherResponse.class);

}

return weatherResponse;

}

@Override

public List<City> getDataByCities() {

List<City> cityList = null;

String uri = "http://vis-basic-city/cities/getList";

// 调用服务接口来获取

ResponseEntity<String> respString = restTemplate.getForEntity(uri, String.class);

// 判断ResponseEntity的状态码是否为200,为200时取出strBody

if (respString.getStatusCodeValue() == 200) {

String jsonStr = respString.getBody();

cityList = JSON.parseArray(jsonStr, City.class);

}

return cityList;

}

}

SpringCloud服务消费有哪几种方式?的更多相关文章

  1. XFire构建服务端Service的两种方式(转)

    XFire构建服务端service的两种方式,一是用xfire构建,二是和spring集成构建. 一,xifre构建,确保把xfire的jar包导入到工程中或classpath. 1,service的 ...

  2. XFire构建服务端Service的两种方式

    1.原声构建: 2.集成spring构建 http://blog.csdn.net/carefree31441/article/details/4000436XFire构建服务端Service的两种方 ...

  3. SpringCloud系列-整合Hystrix的两种方式

    Hystrix [hɪst'rɪks],中文含义是豪猪,因其背上长满棘刺,从而拥有了自我保护的能力.本文所说的Hystrix是Netflix开源的一款容错框架,同样具有自我保护能力. 本文目录 一.H ...

  4. kbmmw 做REST 服务签名认证的一种方式

    一般对外提供提供REST 服务,由于信息安全的问题, 都要采用签名认证,今天简单说一下在KBMMW 中如何 实现简单的签名服务? 整个签名服务,模仿阿里大鱼的认证方式,大家可以根据实际情况自己修改. ...

  5. WCF服务使用(IIS+Http)和(Winform宿主+Tcp)两种方式进行发布

    1.写在前面 刚接触WCF不久,有很多地方知其然不知其所以然.当我在[创建服务->发布服务->使用服务]这一过程出现过许多问题.如客户端找不到服务引用:客户端只在本机环境中才能访问服务,移 ...

  6. 使用RestTemplate进行服务调用的几种方式

    首先我们在名为MSG的服务中定义一个简单的方法 @RestController public class ServerController { @GetMapping("/msg" ...

  7. Servlet实现的三种方式

    实现Servlet的三种方式:一个实现,两个继承 /*========================================== * servlet的执行过程: * 1.创建servlet对 ...

  8. 创建servlet的三种方式

    第一种方式,实现Servlet接口 package com.example.servlet; import java.io.IOException; import javax.servlet.Serv ...

  9. SparkStreaming消费kafka中数据的方式

    有两种:Direct直连方式.Receiver方式 1.Receiver方式: 使用kafka高层次的consumer API来实现,receiver从kafka中获取的数据都保存在spark exc ...

随机推荐

  1. react使用总结

    1.拿到页面首先需要设计好,每个组件该怎么实现,划分好组件可以减少重复代码,有的时候需要和后端确认才能形成正确的划分 2.页面上的需要展示的数据都是由后端数据而来,所以任何增删改查的数据都要从后端重新 ...

  2. nginx进行获取阿里云slb真实ip配置操作

    环境: 1.使用阿里云的slb进行配置nginx,nginx无法获取用户的真实ip解决方案 参考阿里云: https://help.aliyun.com/knowledge_detail/40535. ...

  3. 分布式锁实现(二):Zookeeper

    目录 前言 设计实现 一.基本算法 二.关键点 临时有序节点 监听 三.代码实现 Curator源码分析 一.基本使用 二.源码分析 后记 前言 紧跟上文的:分布式锁实现(一):Redis ,这篇我们 ...

  4. sql update语句

    如果要更新数据库表中的记录,我们就必须使用UPDATE语句. UPDATE语句的基本语法是: UPDATE <表名> SET 字段1=值1, 字段2=值2, ... WHERE ...; ...

  5. vue基础三

    1.模板语法 在底层的实现上, Vue 将模板编译成虚拟 DOM 渲染函数.如果你熟悉虚拟 DOM 并且偏爱 JavaScript 的原始力量,你也可以不用模板,直接写渲染(render)函数,使用可 ...

  6. AcWing 202. 最幸运的数字 (欧拉定理)打卡

    8是中国的幸运数字,如果一个数字的每一位都由8构成则该数字被称作是幸运数字. 现在给定一个正整数L,请问至少多少个8连在一起组成的正整数(即最小幸运数字)是L的倍数. 输入格式 输入包含多组测试用例. ...

  7. 20165239 2018——2019Exp8 Web基础

    Exp8 Web基础 基础问题回答 (1)什么是表单 •表单在网页中主要负责数据采集功能. •一个表单有三个基本组成部分: ◦表单标签,这里面包含了处理表单数据所用CGI程序的URL以及数据提交到服务 ...

  8. appium无法定位连接的真机元素

    报错信息: com.android.ddmlib.SyncException:Remote object dosen't exist! 解决办法: 错误原因是因为没有dump下来界面的信息保存到uid ...

  9. on() 不支持hover事件

    因为 .hover() 是 jQuery 自己定义的事件… 是为了方便用户绑定调用 mouseenter 和 mouseleave 事件而已,它并非一个真正的事件,所以当然不能当做 .bind() 中 ...

  10. HDU 6656 Kejin Player (期望DP 逆元)

    2019 杭电多校 7 1011 题目链接:HDU 6656 比赛链接:2019 Multi-University Training Contest 7 Problem Description Cub ...