SpringCloud----Rest和Feign方式调用及负载均衡

服务提供者内容,serverId:member-server

@RestController
public class MemberController {

	@Value("${server.port}")
	private String serverPort;
	
	@RequestMapping("/getMember")
	public String getMember() {
		return "this is member, now the server port is:" + serverPort;
	}
}	

【1】消费者使用rest方式调用:

启动类:
package com.order;

@SpringBootApplication
@EnableEurekaClient
public class SpringCloudOrderApplication {

	//注入到bean,并开启负载均衡
	@Bean
	@LoadBalanced
	public RestTemplate restTemplate() {
		return new RestTemplate();
	}
	
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		SpringApplication.run(SpringCloudOrderApplication.class, args);
	}

}

@RestController
public class OrderController {

	@Autowired
	private RestTemplate restTemplate;
	
	@RequestMapping("/getOrder")
	public String getOrder() {
		String url = "http://member-server/getMember";
		String result = restTemplate.getForObject(url, String.class);
		return result;
	}
	
}

【2】Feign调用方式

引入依赖:

      <!-- SpringCloud整合feign客户端依赖 -->
	  <dependency>
		<groupId>org.springframework.cloud</groupId>
		<artifactId>spring-cloud-starter-openfeign</artifactId>
	  </dependency>

最好在application.yml里面配置一下客户端超时时间

###设置feign客户端超时时间
ribbon:
  ###指的是建立连接所用的时间,适用于网络状况正常的情况下,两端连接所用的时间。
  ReadTimeout: 5000
  ###指的是建立连接后从服务器读取到可用资源所用的时间。 
  ConnectTimeout: 5000

新建接口:MemberApiFeign

@FeignClient(name="member-server")
public interface MemberApiFeign {

	@RequestMapping("/getMember")
	public String getMember();
	
}

调用服务器方法:

package com.order.controller;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;

import com.order.api.MemberApi;

@RestController
public class OrderController {

	@Autowired
	private MemberApiFeign memberApiFeign;
	
	@RequestMapping("/getOrder")
	public String getOrder() {
		return memberApiFeign.getMember();
	}
	
}

区别:

(1)Rest方式是要手动开启负载均衡的,并且要注入到Bean才可使用(不要用new的方式)。Feign方式是要引入依赖,默认自动就开启了负载均衡的。

(2)Rest方式每次调用服务端方法时都要写地址,很恶心。但是Feign方式就不一样了。只需要设置@FeignClient就可以自动映射服务端的方法。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值