以下是一个使用Spring Boot和Feign实现客户端和服务端通信的简单例子。
一,首先,建立服务端,服务端注册到服务中心,创建一个服务端应用:
//注意application.properties配置文件中定义应用的
//服务名为 my-service 即spring.application.name=my-service,
//提供客户端在服务注册中心中寻找该名称服务名@SpringBootApplication
public class MyServiceApplication {public static void main(String[] args) {SpringApplication.run(MyServiceApplication.class, args);}// 简易的服务端接口定义,一般定义在另外文件@RestControllerpublic class MyController {@GetMapping("/hello")public String hello() {return "Hello from Service!";}}
}
二,其次,建立客户端应用,客户端也注册到服务中心,创建一个Feign客户端:
1,客户端应用添加相关依赖到pom.xml:
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
2,在Spring Boot应用中启用Feign功能:
@EnableFeignClients // 客户端应用启动类启动feign服务
@SpringBootApplication
public class MyClientApplication {public static void main(String[] args) {SpringApplication.run(MyClientApplication.class, args);}
}
3,创建Feign客户端接口:
// path 属性定义统一前缀,根据需要设置,可以为空
@FeignClient("my-service",contextId="uniqueCxtKey1", path="")
public interface MyServiceClient {@GetMapping("/hello")String hello();// more api define expand...
}
4,使用Feign客户端:
@RestController
public class MyController {@Autowiredprivate MyServiceClient myServiceClient;@GetMapping("/greeting")public String greeting() {return myServiceClient.hello();}
}
5,配置请求超时:
客户端请求服务端走服务间的网络请求,客户端需要配置合理超时x毫秒配置,确保调用高可用;
feign:client:config:default:connectTimeout: 5000readTimeout: 5000
在这个例子中,创建了一个简单的服务端应用,并定义了一个/hello端点。然后,我们创建了一个客户端用和Feign接口,用于向服务端发送请求。在客户端的控制器中,我们注入了Feign客户端,并使用它来获取服务端的响应。
确保你的服务端应用是可访问的,并且在配置文件中设置了正确的服务名称(例如,在application.properties中使用spring.application.name=my-service),这样Feign客户端可以通过服务名称正确地发现和访问服务端。