简单的 springboot + eureka + feign 应用
这3者组合会导致默认返回数据格式由json变成了xml
看了一些教程资料,记录一下基础的入门,还有很多强大的功能需要继续去学习
创建3个项目,server(作为注册中心)、producer(生产者,即提供服务的)、consumer(消费者);
3个项目的创建过程基本一致:
最后 finish,完成项目创建。
1.server项目
单纯的作为一个注册中心,这里没作其他用途(也可以作为生产者或消费者),只需要在启动类上加上 @EnableEurekaServer 注解,表明这是一个eureka的注册服务中心
这样 一个简单的服务注册中间就好了,访问:127.0.0.1:8081 就可以看到如下页面;
2.producer生产者
这个项目里面跟平常的项目一样,只需要在启动类上加上 @EnableEurekaClient 注解,并在配置文件中添加eureka的配置
这样我们简单的生产者系统就好了。
3. consumer消费者
消费者系统其实也基本相同。
feign的使用:启动类要加上@EnableFeignClients 的注解
编写一个接口interface(ps:类名写错了不要紧!),加上@FeignClient(name = "erueka-producer") 注解,name属性是 上面生产者的系统应用名称,调用的时候就会通过注册的地址访问对应系统的内容,即使是分布式应用(也就是有多个同名的生产者),它也会自动使用其自带的负载均衡,会挨个轮着访问每个生产者系统。
我们只需要在控制层中引入feign的接口就可以直接使用。
注意:
可以看到我们的控制层是加上了@RestController 注解,按理说返回的数据应该是json格式的,但是实际上这样我们访问的时候返回的是 xml 格式的数据。(就不贴图了) ,它默认返回的是xml格式。
因为在它默认的配置中,返回xml数据是优先于json的。
指定返回是数据格式:
1.可以通过在请求路径上设置来指定返回 json或xml格式数据,
如:http:xxx/a.json?token=xxxx 、 http:xxx/a.xml?token=xxxxx
2.在方法上的@RequestMapping 注解中指定,如:
这样 /a 这个接口就会返回json格式,但是其他接口仍然是返回xml格式,
3.在类上的@RequestMapping 注解上指定,如:
这样整个类的接口都会返回json格式。
4.在导入jar时,排除掉下图中的这个依赖包:(ps:这个方法可能会导致启动的时候报错:NoClassDefFoundError)
这样就返回的是json格式数据了。
最近又看到一个新的方法
5.用拦截器设置默认的ContentType