Spring Eureka的使用入门--服务端与客户端
接上篇:
Eureka作为注册中心,连接服务端与客户端;
服务端:
依赖包:
- apply plugin: 'org.springframework.boot'
- apply plugin: 'io.spring.dependency-management'
- ext {
- springCloudVersion = 'Edgware.SR4'
- }
- dependencies {
- compile 'org.springframework.boot:spring-boot-starter-web'
- compile 'org.springframework.boot:spring-boot-starter-actuator'
- compile 'org.springframework.cloud:spring-cloud-starter-eureka'
- compile 'org.springframework.cloud:spring-cloud-config-client'
- compile 'org.springframework.cloud:spring-cloud-starter-bus-amqp'
- compile 'org.springframework:springloaded'
- compile 'org.springframework.boot:spring-boot-devtools'
- }
- dependencyManagement {
- imports {
- mavenBom "org.springframework.cloud:spring-cloud-dependencies:${springCloudVersion}"
- }
- }
启动类:
- import org.springframework.boot.SpringApplication;
- import org.springframework.boot.autoconfigure.SpringBootApplication;
- import org.springframework.cloud.client.circuitbreaker.EnableCircuitBreaker;
- import org.springframework.cloud.context.config.annotation.RefreshScope;
- import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
- @SpringBootApplication
- @EnableEurekaClient
- @EnableCircuitBreaker
- public class ServerApplication {
- public static void main(String[] args) {
- SpringApplication.run(ServerApplication .class, args);
- }
- }
配置文件app.yml
- server:
- port: 1800
- eureka:
- client:
- service-url:
- defaultZone: http://localhost:8761/eureka
- instance:
- instance-id: server
- prefer-ip-address: true
- info:
- app.name: a-server
- company.name: www.*.com
核心代码:服务提供者
- import java.util.List;
- import org.springframework.cloud.netflix.feign.FeignClient;
- import org.springframework.web.bind.annotation.PostMapping;
- import org.springframework.web.bind.annotation.RequestBody;
- import org.springframework.web.bind.annotation.ResponseBody;
- @FeignClient(name = "hello", fallbackFactory = HelloFallbackFactory.class)
- @ResponseBody
- public interface HelloApi {
- @PostMapping(path = "/api/hello")
- public String sayHI(@RequestBody SayHiRequest request);
- }
服务已接想口形式提供,注册到Eurka注册中心里:
- import org.springframework.stereotype.Component;
- import feign.hystrix.FallbackFactory;
- @Component
- public class HelloFallbackFactory implements FallbackFactory<HelloApi> {
- @Override
- public HelloApicreate(Throwable cause) {
- return new HelloApi() {
- @Override
- public String sayHi(SayHiRequest request) {
- // TODO Auto-generated method stub
- }
- };
- }
- }
接口实现:
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.stereotype.Controller;
- import org.springframework.validation.annotation.Validated;
- import org.springframework.web.bind.annotation.RequestBody;
- @Controller
- public class HelloApiImpl implements HelloApi {
- @Override
- public String sayHi(@RequestBody @Validated SayHiRequest request) {
- //do somenting
- return "";
- }
- }
服务端搭建完成;
微服务架构里,接口一般抽象出来,将接口和接口实现抽离,放到不同的服务里面;
启动服务,当我注册中心htttp://127.0.0.1:8761/eureka 查看服务注册情况;
客户端:
通过注册中心查找服务,进行服务调用;
依赖包:重点是引入接口方提供jar包
- apply plugin: 'io.spring.dependency-management'
- dependencies {
- compile 'org.springframework.cloud:spring-cloud-starter-eureka'
- compile 'org.springframework.cloud:spring-cloud-starter-ribbon'
- compile 'org.springframework.cloud:spring-cloud-starter-feign'
- compile 'org.springframework.cloud:spring-cloud-starter-config'
- compile 'org.springframework.boot:spring-boot-starter-web'
- compile 'org.springframework.boot:spring-boot-starter-actuator'
- compile(project(':hello-api'))
- }
- ext {
- springCloudVersion = 'Edgware.SR4'
- }
- dependencyManagement {
- imports {
- mavenBom "org.springframework.cloud:spring-cloud-dependencies:${springCloudVersion}"
- }
- }
启动类:
- import org.springframework.boot.SpringApplication;
- import org.springframework.cloud.client.SpringCloudApplication;
- import org.springframework.cloud.netflix.feign.EnableFeignClients;
- @SpringCloudApplication
- @EnableFeignClients
- public class ClientApplication {
- public static void main(String[] args) {
- SpringApplication.run(ClientApplication .class, args);
- }
- }
调用服务类:
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.web.bind.annotation.PostMapping;
- import org.springframework.web.bind.annotation.RequestBody;
- import org.springframework.web.bind.annotation.RequestMapping;
- import org.springframework.web.bind.annotation.RequestMethod;
- import org.springframework.web.bind.annotation.ResponseBody;
- import org.springframework.web.bind.annotation.RestController;
- @RestController
- @RequestMapping("/api/test/")
- public class TestRS {
- @Autowired
- private TestService _testService;
- @RequestMapping(value = "/say", method = RequestMethod.GET, produces = "application/json;charset=UTF-8")
- @ResponseBody
- public ResponseBase<String> test() {
String test = _testService.sayHi();- return new ResponseBase<String>("0", "success", "");
- }
- }
- @service
public class TestService {
- @Autowired
- private HelloApi _helloApi;
- public String sayHi() {
String test = _helloApi.sayHi();- return test;
- }
- }
配置文件app.yml
- server:
- port: 1668
- contextPath: /hello
- eureka:
- client:
- service-url:
- defaultZone: http://127.0.0.1:8761/eureka
- instance:
- prefer-ip-address: true
- info:
- app.name: hello
- feign:
- client:
- config:
- default:
- connectTimeout: 60000
- readTimeout: 60000
启动服务,访问注册中心查看是否注册成功;调用接口测试;
Spring Eureka的使用入门--服务端与客户端的更多相关文章
- 【Eureka】服务端和客户端
[Eureka]服务端和客户端 转载:https://www.cnblogs.com/yangchongxing/p/10778357.html Eureka服务端 1.添加依赖 <?xml v ...
- eureka服务端和客户端的简单搭建
本篇博客简单记录一下,eureka 服务端和 客户端的简单搭建. 目标: 1.完成单机 eureka server 和 eureka client 的搭建. 2.完成eureka server 的添加 ...
- Spring Boot 集成 WebSocket 实现服务端推送消息到客户端
假设有这样一个场景:服务端的资源经常在更新,客户端需要尽量及时地了解到这些更新发生后展示给用户,如果是 HTTP 1.1,通常会开启 ajax 请求询问服务端是否有更新,通过定时器反复轮询服务端响应的 ...
- seata服务端和客户端配置(使用nacos进行注册发现,使用mysql进行数据持久化),以及过程中可能会出现的问题与解决方案
seata服务端和客户端配置(使用nacos进行注册发现,使用mysql进行数据持久化),以及过程中可能会出现的问题与解决方案 说明: 之所以只用nacos进行了注册与发现,因为seata使用naco ...
- 使用Apache CXF开发WebServices服务端、客户端
在前一篇的博客中,我使用Xfire1.x来开发了WebServies的服务端. 但是如果你访问Apache的官网,可以看到xfire已经被合并了. 最新的框架叫做CXF. Apache CXF = C ...
- 采用MQTT协议实现android消息推送(2)MQTT服务端与客户端软件对比、android客户端示列表
1.服务端软件对比 https://github.com/mqtt/mqtt.github.io/wiki/servers 名称(点名进官网) 特性 简介 收费 支持的客户端语言 IBM MQ 完整的 ...
- 【.NET+MQTT】.NET6 环境下实现MQTT通信,以及服务端、客户端的双边消息订阅与发布的代码演示
前言: MQTT广泛应用于工业物联网.智能家居.各类智能制造或各类自动化场景等.MQTT是一个基于客户端-服务器的消息发布/订阅传输协议,在很多受限的环境下,比如说机器与机器通信.机器与物联网通信等. ...
- Java 断点下载(下载续传)服务端及客户端(Android)代码
原文: Java 断点下载(下载续传)服务端及客户端(Android)代码 - Stars-One的杂货小窝 最近在研究断点下载(下载续传)的功能,此功能需要服务端和客户端进行对接编写,本篇也是记录一 ...
- asp.net获取服务端和客户端信息
asp.net获取服务端和客户端信息 获取服务器名:Page.Server.ManchineName获取用户信息:Page.User 获取客户端电脑名:Page.Request.UserHostNam ...
随机推荐
- leetcode:Median of Two Sorted Arrays分析和实现
这个问题的大意是提供两个有序的整数数组A与B,A与B并集的中间数.[1,3]与[2]的中间数为2,因为2能将A与B交集均分.而[1,3]与[2,4]的中间数为2.5,取2与3的平均值.故偶数数目的中间 ...
- vim 的小幅移动
1.操作符命令和位移 x --->删除一个字符,4x ---->删除4个字符. dw --->可以删除一个单词,d4w ---->删除4个单词. d$ ----> 删除 ...
- WebFlux01 webflux概念、异步servlet、WebFlux意义
1 概念 待更新...... 2 异步servlet 2.1 同步servlet servlet容器(如tomcat)里面,每处理一个请求会占用一个线程,同步servlet里面,业务代码处理多久,se ...
- Nginx+Tomcat集群+session共享
Nginx+Tomcat集群+session共享 1)安装Nginx 2)配置多个Tomcat,在server.xml中修改端口(端口不出现冲突即可) 3)在nginx.conf文件中配置负载均衡池, ...
- PostgreSQL的索引选型
PostgreSQL里面给全文检索或者模糊查询加索引提速的时候,一般会有两个选项,一个是GIST类型,一个是GIN类型,官网给出的参考如下: There are substantial perform ...
- Media Queries 媒体类型
引用方法:1.<link rel="stylesheet" type="text/css" href="style.css" medi ...
- jquery延时刷新
setTimeout(function(){ location.replace(location.href); },1000);
- Java 正则表达式的实际应用
正则表达式最详细-----> | |目录 1匹配验证-验证Email是否正确 2在字符串中查询字符或者字符串 3常用正则表达式 4正则表达式语法 1匹配验证-验证Email是否正确 public ...
- java多线程的基本介绍
Java多线程 1.进程与线程 进程是程序的一次动态执行过程,它需要经历从代码加载,代码执行到执行完毕的一个完整的过程,这个过程也是进程本身从产生,发展到最终消亡的过程.多进程操作系统能同时达运行多个 ...
- 「BZOJ 2733」「HNOI 2012」永无乡「启发式合并」
题意 你需要维护若干连通快,有两个操作 合并\(x,y\)所在的连通块 询问\(x\)所在连通块中权值从小到大排第\(k\)的结点编号 题解 可以启发式合并\(splay\),感觉比较好些的 一个连通 ...