java ribbon_SpringCloud 中使用 Ribbon的方法详解

在前两章已经给大家讲解了Ribbon负载均衡的规则 以及 如何搭建Ribbon并调用服务,那么在这一章呢 将会给大家说一说如何在SpringCloud中去使用Ribbon。在搭建之前 我们需要做一些准备工作。

1. 搭建Eureka服务器:springCloud-ribbon-server(项目名称)

2. 服务提供者:springCloud-ribbon-police(项目名称)

3. 服务调用者:springCloud-ribbon-person(项目名称)

搭建Eureka服务器

配置 pom.xml,加入springCloud核心依赖、配置及eureka服务器依赖

org.springframework.boot

spring-boot-starter-parent

1.5.13.RELEASE

org.springframework.cloud

spring-cloud-dependencies

Dalston.SR5

pom

import

org.springframework.cloud

spring-cloud-starter-config

org.springframework.cloud

spring-cloud-starter-eureka-server

配置 application.yml(红色部分是必须要写的,黑色部分不写也能正常运行 但是建议写上,在这里笔者将官网的代码贴上)

server:

port: 8761

eureka:

instance:

hostname: localhost

client:

registerWithEureka: false 禁止向eureka注册服务,因为它自己本身就是服务器

fetchRegistry: false 这里不需要抓取注册表

serviceUrl:

defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/

创建启动类:Application.java(将服务跑起来放着,稍后会用到)配置 pom.xml,加入springCloud核心依赖、配置及eureka服务依赖

@SpringBootApplication

@EnableEurekaServer

public class Application {

public static void main(String[] args) {

new SpringApplicationBuilder(Application.class).web(true).run(args);

}

}

552e8586389d80cabcb92d6fa7b5f02c.png

服务提供者

配置 pom.xml,加入springCloud核心依赖、配置及eureka客户端依赖

org.springframework.boot

spring-boot-starter-parent

1.5.13.RELEASE

org.springframework.cloud

spring-cloud-dependencies

Dalston.SR5

pom

import

org.springframework.cloud

spring-cloud-starter-config

org.springframework.cloud

spring-cloud-starter-eureka

配置 application.yml(需要使用defaultZone向服务器注册服务,否则就算该服务运行起来了,但没有向服务器注册服务,也是使用不了的)(name 这个名称是显示在服务列表中的名称,养成好习惯,一定要起有意义的名称)

spring:

application:

name: springCloud-ribbon-police

eureka:

client:

serviceUrl:

defaultZone: http://localhost:8761/eureka/

因为该服务是提供服务的,所以下面会建一个实体类及Controller用来对外提供服务,创建实体类:Police.java

public class Police {

private String id;// 警察编号,用来保存用户输入的参数

private String url;// 处理请求的服务器url

private String message;// 提示信息

public String getId() {

return id;

}

public void setId(String id) {

this.id = id;

}

public String getUrl() {

return url;

}

public void setUrl(String url) {

this.url = url;

}

public String getMessage() {

return message;

}

public void setMessage(String message) {

this.message = message;

}

}

创建对外提供服务的Controller:PoliceController.java(@RestController注解中包含了@Controller+@ResponseBody)

@RestController

public class PoliceController {

@RequestMapping(value="/getPolice", method=RequestMethod.GET, produces=MediaType.APPLICATION_JSON_VALUE)

public Police getPolice(HttpServletRequest request){

Police p = new Police();

p.setUrl(request.getRequestURL().toString());

p.setMessage("警察派出成功");

return p;

}

@RequestMapping(value="/getPoliceById/{id}", method=RequestMethod.GET, produces=MediaType.APPLICATION_JSON_VALUE)

public Police getPolice(HttpServletRequest request, @PathVariable("id") String id){

Police p = new Police();

p.setId(id);

p.setUrl(request.getRequestURL().toString());

p.setMessage("指定警察派出成功");

return p;

}

}

因为我们要测试负载均衡,所以这里的服务提供者需要开启多个服务实例,下面我们用读取手动输入端口号的方法,启动多个服务实例,笔者在这里启动了两个服务实例:8080、8081

@SpringBootApplication

@EnableEurekaClient

public class PoliceApplication {

public static void main(String[] args) {

Scanner scan = new Scanner(System.in);

String port = scan.nextLine();

new SpringApplicationBuilder(PoliceApplication.class).properties("server.port="+port).run(args);

}

}

如下图,出现了两个服务实例,分别是:8080、8081,红色的信息咱们先不管他,如果实在有看着不顺眼的小伙伴,可以配置心跳(简单的来说,就是配置服务器每隔多久检查一次服务实例状态,如果某个服务因为某些原因停掉 不能用了,那么就将该服务 从服务列表中移除掉)

b65c9317cd7598fbaa2dab50f5f93bdd.png

服务调用者

配置 pom.xml,加入springCloud核心依赖、配置及eureka客户端依赖、Ribbon依赖

org.springframework.boot

spring-boot-starter-parent

1.5.13.RELEASE

org.springframework.cloud

spring-cloud-dependencies

Dalston.SR5

pom

import

org.springframework.cloud

spring-cloud-starter-config

org.springframework.cloud

spring-cloud-starter-eureka

org.springframework.cloud

spring-cloud-starter-ribbon

配置 application.yml(这里也将该服务注册到服务器,一定要进行注册)

server:

port: 9090

spring:

application:

name: springCloud-ribbon-person

eureka:

client:

serviceUrl:

defaultZone: http://localhost:8761/eureka/

创建调用服务Controller:PersonController.java

RestTemplate 是由 Spring Web 模块提供的工具类,与 SpringCloud 无关,是独立存在的

因 SpringCloud 对 RestTemplate 进行了一定的扩展,所以 RestTemplate 具备了负载均衡的功能

@RestController

@Configuration

public class PersonController {

@Bean

@LoadBalanced

public RestTemplate getRestTemplate(){

return new RestTemplate();

}

@RequestMapping("/getPolice")

public String getPolice(){

RestTemplate rt = getRestTemplate();

String result = rt.getForObject("http://springCloud-ribbon-police/getPolice", String.class);

return result;

}

@RequestMapping("/getPoliceById/{id}")

public String getPoliceById(@PathVariable("id") String id){

RestTemplate rt = getRestTemplate();

String result = rt.getForObject("http://springCloud-ribbon-police/getPoliceById/"+id, String.class);

return result;

}

}

创建启动类:PersonApplication.java

@SpringBootApplication

@EnableEurekaClient

public class PersonApplication {

public static void main(String[] args) {

new SpringApplicationBuilder(PersonApplication.class).web(true).run(args);

}

}

84097dc028d0d9636069f340d69e319a.png

到目前为止,eureka服务器、服务提供者、服务调用者(负载均衡)就已经全写好了,下面我们访问接口,来试一下 服务到底能不能调通

4321500ef9bc58a37c58334c21c0fa82.png

c2da5cc933870e43dc70ff5de2ec0e35.png

总结

以上所述是小编给大家介绍的SpringCloud 中使用 Ribbon的方法详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值