玩转springcloud(三):服务的提供者与调用者(注册于发现)
一、简介
上文我们实践了cloud的注册中心的单服务于多节点的搭建,房子造好了得有人来住不是,这篇我们实践下服务提供者于调用者的案例,也就是服务端和客户端的调用。
本文会设计三个module:注册中心(eureka),服务提供方(server),服务调用方(client)。其中注册中心,我们就用上文搞的,不能重复造轮子啊~~
简单说下项目执行及调用过程:首先启动注册中心,然后在启动服务端和客户端,服务端会注册到注册中心,
二、实践演练
服务提供方
我们在服务端创建一个接口可接收字符串参数,然后拼接这个参数输出("hello " + 参数 + ",this is first messge,我是8079服务哦")
1、老生常谈,先上pom依赖
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
</dependencies>
2、配置文件走起
spring:
application:
name: spring-cloud-eureka-producer
server:
port: 8079
eureka:
client:
serviceUrl:
defaultZone: http://xjy1:8097/eureka/
参数之前都结实过啦,这里不再赘述
3、启动类添加注解@EnableDiscoveryClient
package com.oldmonk.cloud; import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient; /**
* @program: cloud
* @description: 启动类
* @author: xujingyang
* @create: 2019-10-09 12:06
**/
@SpringBootApplication
@EnableDiscoveryClient
public class ErkaProducerApplication {
public static void main(String[] args) {
SpringApplication.run(ErkaProducerApplication.class);
}
}
添加@EnableDiscoveryClient注解后,项目就具有了服务注册的功能。启动工程后,就可以在注册中心的页面看到SPRING-CLOUD-PRODUCER服务。
4、提供的接口服务
package com.oldmonk.cloud.controller; import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController; /**
* @program: cloud
* @description: 测试接口
* @author: xujingyang
* @create: 2019-10-08 14:45
**/
@RestController
public class Hello { @RequestMapping("/hello")
public String index(String name) {
return "hello " + name + ",this is first messge,我是8079服务哦";
} }
5、启动注册中心,然后启动服务提供方,得下图

至此服务提供方就配置完成了!
服务调用方
1、老生常谈,先上pom依赖 ,与提供方是一样的
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
</dependencies>
2、配置文件走起
spring:
application:
name: spring-cloud-eureka-consumer
server:
port: 9009
eureka:
client:
serviceUrl:
defaultZone: http://xjy1:8097/eureka/
3、启动类添加注解
package com.oldmonk.cloud; import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.openfeign.EnableFeignClients; /**
* @program: cloud
* @description: 启动类
* @author: xujingyang
* @create: 2019-10-09 12:06
**/
@SpringBootApplication
@EnableDiscoveryClient
@EnableFeignClients
public class ErkaConsumerApplication {
public static void main(String[] args) {
SpringApplication.run(ErkaConsumerApplication.class);
}
}
@EnableDiscoveryClient:启用服务注册与发现@EnableFeignClients:启用feign进行远程调用
Feign是一个声明式Web Service客户端。使用Feign能让编写Web Service客户端更加简单, 它的使用方法是定义一个接口,然后在上面添加注解,同时也支持JAX-RS标准的注解。Feign也支持可拔插式的编码器和解码器。Spring Cloud对Feign进行了封装,使其支持了Spring MVC标准注解和HttpMessageConverters。Feign可以与Eureka和Ribbon组合使用以支持负载均衡。
4、客户端接口
package com.oldmonk.cloud.controller; import com.oldmonk.cloud.service.remote.HelloRemote;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController; /**
* @program: cloud
* @description: 测试接口
* @author: xujingyang
* @create: 2019-10-08 14:45
**/
@RestController
public class HelloController { @Autowired
HelloRemote remote; @RequestMapping("/hi/{name}")
public String index(@PathVariable("name") String name) {
return remote.hello(name);
} }
5、feign调用
package com.oldmonk.cloud.service.remote; import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam; /**
* @program: cloud-lx
* @description: 远程服务调用
* @author: xujingyang
* @create: 2019-10-09 13:07
**/
@FeignClient(name = "spring-cloud-eureka-producer")
public interface HelloRemote { @RequestMapping("/hello")
String hello(@RequestParam("name") String name);
}
参数必须保持一致与服务提供方的接口
6、启动

至此,服务调用方配置完成
测试
简单调用
1、先输入:http://localhost:8079/hello?name=xjy检查服务提供方服务是否正常

说服务提供方正常启动,提供的服务也正常。
2、浏览器中输入:http://localhost:9009/hi/xjy

说明客户端已经成功的通过feign调用了远程服务hello,并且将结果返回到了浏览器。
多节点负载均衡
1、把生产者配置文件做下改动
---
spring:
application:
name: spring-cloud-eureka-producer
profiles:
active: xjy1
server:
port: 8079
eureka:
client:
serviceUrl:
defaultZone: http://xjy1:8097/eureka/ ---
spring:
application:
name: spring-cloud-eureka-producer
profiles:
active: xjy2
server:
port: 8078
eureka:
client:
serviceUrl:
defaultZone: http://xjy1:8097/eureka/
2、controller也要修改下
package com.oldmonk.cloud.controller; import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController; /**
* @program: cloud
* @description: 测试接口
* @author: xujingyang
* @create: 2019-10-08 14:45
**/
@RestController
public class Hello { @Value("${spring.profiles}")
private String profile; @RequestMapping("/hello")
public String index(String name) {
return "hello " + name + ",this is first messge,我是【" + profile + "】服务哦";
} }
2、打包,按照之前说的方式启动两次
启动2个服务形成集群注册中心,启动命令:
java -jar eureka-producer-cluster-0.0.-SNAPSHOT.jar --spring.profiles.active=xjy1
java -jar eureka-producer-cluster-0.0.-SNAPSHOT.jar --spring.profiles.active=xjy2
3、然后看到注册中心两个服务都注册进来了,加上消费方一共三个服务

4、然后在浏览器再次输入:http://localhost:9009/hi/xjy 进行测试:
第一次返回结果:hello xjy,this is first messge,我是【xjy1】服务哦
第二次返回结果:hello xjy,this is first messge,我是【xjy2】服务哦
不断的进行测试下去会发现两种结果交替出现,说明两个服务中心自动提供了服务均衡负载的功能。
如果我们将服务提供者的数量在提高为N个,测试结果一样,请求会自动轮询到每个服务端来处理。
三、案例源码
连接点不动时请复制粘贴此链接:https://github.com/oIdmonk/springcloud-xjy
代码基于boot2.1.9.RELEASE版本,cloudGreenwich.SR3版本
玩转springcloud(三):服务的提供者与调用者(注册于发现)的更多相关文章
- 十七、springcloud(三)服务的注册与调用
1.启动服务注册中心Eureka(见上篇) 启动成功后,暂时无服务 2.项目框架 3.创建服务提供者(spring-cloud-houge-provider)jar a.application.pro ...
- SpringCloud微服务小白入门之Eureka注册中心和服务中心搭建示例
一.注册中心配置文件 代码复制区域: spring: application: name: spring-cloud-server server: port: 7000 eureka: instanc ...
- 微服务通信之feign的注册、发现过程
前言 feign 是目前微服务间通信的主流方式,是springCloud中一个非常重要的组件.他涉及到了负载均衡.限流等组件.真正意义上掌握了feign可以说就掌握了微服务. 一.feign的使用 f ...
- SpringCloud的入门学习之概念理解、Eureka服务注册与发现入门
1.微服务与微服务架构.微服务概念如下所示: 答:微服务强调的是服务的大小,它关注的是某一个点,是具体解决某一个问题.提供落地对应服务的一个服务应用,狭意的看,可以看作Eclipse里面的一个个微服务 ...
- 微服务框架SpringCloud(Dalston版)学习 (一):Eureka服务注册与发现
eureka-server eureka服务端,提供服务的注册与发现,类似于zookeeper 新建spring-boot工程,pom依赖: <dependency> <groupI ...
- SpringColud Eureka的服务注册与发现
一.Eureka简介 本文中所有代码都会上传到git上,请放心浏览 项目git地址:https://github.com/839022478/Spring-Cloud 在传统应用中,组件之间的调用,通 ...
- 玩转SpringCloud(F版本) 三.断路器(Hystrix)RestTemplate+Ribbon和Feign两种方式
此文章基于: 玩转SpringCloud 一.服务的注册与发现(Eureka) 玩转SpringCloud 二.服务消费者(1)ribbon+restTemplate 转SpringCloud 二.服 ...
- 三. SpringCloud服务注册与发现
1. Eureka 1.1 Eureka理解 什么是服务治理 Spring Cloud封装了Netflix公司开发的Eurkeka模块来实现服务治理 在传统的rpc远程调用框架中,管理每个服务与服务之 ...
- springcloud(第三篇)springcloud eureka 服务注册与发现 *****
http://blog.csdn.net/liaokailin/article/details/51314001 ******************************************* ...
随机推荐
- jQuery.fn.extend与jQuery.extend的区别
jquery 本身并不提供 jQuery.color() 这个方法,如果我们需要对jQuery本身提供的方法进行扩展,则我们就需要是用jQuery.fn.extend: jQuery.fn.exten ...
- CG标准函数
- 使用FRP配置Windows远程控制
一款很好用的内网穿透工具--FRP 前言 使用内网穿透工具--FRP,以及一台云服务器当做服务端,进行简单配置后即可远程访问 配置 FRP 服务端的前提条件是需要一台具有公网 IP 的设备,得益于 F ...
- 关于Angular+ngx-perfect-scrollbar自定义各大浏览器滚动条样式的解决方法
资料: http://manos.malihu.gr/jquery-custom-content-scroller/ (此项是结合Jquery使用的,在此并未采用) https://www.npmj ...
- mysql常用引擎
经常用MySQL数据库,但是,你在用的时候注意过没有,数据库的存储引擎,可能有注意但是并不清楚什么意思,可能根本没注意过这个问题,使用了默认的数据库引擎,当然我之前属于后者,后来成了前者,然后就有了这 ...
- 破周三,前不着村后不着店的,只好学pandas了,你该这么学,No.9
如果图片无法观看,请移步 https://blog.csdn.net/hihell 周三了,一个星期最难的一天 大中间的,今天还这么热 5月份,36度的高温 天空飘过几个字 屋里学pandas最得劲 ...
- 亿级Web系统搭建――单机到分布式集群 转载
当一个Web系统从日访问量10万逐步增长到1000万,甚至超过1亿的过程中,Web系统承受的压力会越来越大,在这个过程中,我们会遇到很多的问题.为了解决这些性能压力带来问题,我们需要在Web系统架构层 ...
- java源码--HashMap
一.HashMap简介 1.1.HashMap概述 HashMap是基于哈希表的Map接口实现的,它存储的是内容是键值对<key,value>映射.此类不保证映射的顺序,假定哈希函数将元素 ...
- Redis 常用命令整理
哈希表:设置秒中某个字段 HMSET KEY_NAME FIELD1 VALUE1 ...FIELDN VALUEN EX: 127.0.0.1:6380> hmset set_map LOGD ...
- 列表推导:python2和python3中作用域的问题
python2中: x = 'my love' dummy = [x for x in 'ABC'] print x 此时x打印为:'C' python3中: x = 'my love' dummy ...