- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章SpringCloud Ribbon 负载均衡的实现由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
前言 。
ribbon是一个客户端负载均衡器,它提供了对http和tcp客户端的行为的大量控制。我们在上篇(猛戳:springcloud系列——feign 服务调用)已经实现了多个服务之间的feign调用,服务消费者调用服务提供者,本文记录feign调用ribbon负载均衡的服务提供者 。
github地址:https://github.com/netflix/ribbon 。
官方文档:https://cloud.spring.io/spring-cloud-static/spring-cloud-netflix/2.1.0.rc2/single/spring-cloud-netflix.html 。
服务提供者 。
服务提供者有两个,实际上可以看做只有一个,因为这两个只有端口不同 。
maven引入ribbon 。
1
2
3
4
5
|
<!-- ribbon -->
<dependency>
<groupid>org.springframework.cloud</groupid>
<artifactid>spring-cloud-starter-netflix-ribbon</artifactid>
</dependency>
|
创建ribbonconfig文件,主类添加@ribbonclient(name = "ribbonconfig", configuration = ribbonconfig.class),我这里偷懒,直接在主类中创建内部类 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
@enableeurekaclient
@ribbonclient
(name =
"ribbonconfig"
, configuration = ribbonconfig.
class
)
@springbootapplication
public
class
springbootspringdatajpaapplication{
public
static
void
main(string[] args) {
springapplication.run(springbootspringdatajpaapplication.
class
, args);
}
}
@configuration
class
ribbonconfig {
@bean
public
irule ribbonrule(){
return
new
randomrule();
//分配策略:随机选择一个server
// return new bestavailablerule(); //分配策略:选择一个最小的并发请求的server,逐个考察server,如果server被tripped了,则忽略
// return new roundrobinrule(); //分配策略:轮询选择,轮询index,选择index对应位置的server
// return new weightedresponsetimerule(); //分配策略:根据响应时间分配一个weight(权重),响应时间越长,weight越小,被选中的可能性越低
// return new zoneavoidancerule(); //分配策略:复合判断server所在区域的性能和server的可用性选择server
// return new retryrule(); //分配策略:对选定的负载均衡策略机上重试机制,在一个配置时间段内当选择server不成功,则一直尝试使用subrule的方式选择一个可用的server
}
@bean
public
iping ribbonping() {
return
new
pingurl();
}
@bean
public
serverlistsubsetfilter serverlistfilter() {
serverlistsubsetfilter filter =
new
serverlistsubsetfilter();
return
filter;
}
}
|
下表显示了spring cloud netflix默认为ribbon提供的bean:
官网例子:
我们添加一个测试接口 。
1
2
3
4
5
6
7
8
9
10
|
@restcontroller
@requestmapping
(
"/user"
)
public
class
usercontroller {
@requestmapping
(
"/ribbon"
)
public
string ribbon() {
return
"springdatejpa -- 我的端口是:10088"
;
}
}
|
第二个服务提供者也是这样配置,注意:应用名要相同(spring.application.name=springdatejpa);端口不同; 。
服务消费者 。
服务消费者使用feign调用,无需做任何修改,feign已经使用ribbon。具体配置请戳:springcloud系列——feign 服务调用 。
1
2
3
4
5
6
|
@feignclient
(name =
"springdatejpa"
, path =
"/user/"
)
public
interface
myspringbootfeign {
@requestmapping
(
"/ribbon"
)
string ribbon();
}
|
1
2
3
4
5
6
7
|
/**
* feign调用
*/
@getmapping
(
"feign/ribbon"
)
string ribbon(){
return
myspringbootfeign.ribbon();
}
|
效果 。
启动所有项目,我们注册了三个服务,其中:
有两个服务名称相同、处理的业务相同、端口不同,这两台作为服务提供者(可看做是一个“小集群”); 。
另一个是服务消费者(feign调用); 。
消费者不断调用,ribbon会从注册中心的服务列表拉取实例集合进行负载均衡调用背后的服务提供者 。
后记 。
ribbon负载均衡已经可以实现,更多配置请看官方文档 。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我.
原文链接:https://www.cnblogs.com/huanzi-qch/p/10136254.html 。
最后此篇关于SpringCloud Ribbon 负载均衡的实现的文章就讲到这里了,如果你想了解更多关于SpringCloud Ribbon 负载均衡的实现的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
如何检查枚举是否等于可能情况之一。有没有比以下更好的解决方案: [.orderedAscending, .orderedSame].contains(Calendar.current.compare(
我正在尝试使用 openCV 和 C++ 来均衡 HSV 图像的直方图。我知道有些带有 openCV 的库可以为我执行此操作,但我想手动尝试以了解该方法。 我假设均衡将在 HSV 图像的 V chan
我有一个包含多个列的表格。这些列可以包含不同大小的内容,因此高度会有所不同。 我想做的是调整单个元素的高度,使它看起来像这样: . .table { display: flex; ba
:) 我有一个小问题: 我有一个 div,在里面有两个 div,一个挨着另一个。左边的一个在调整大小时改变其高度以保持其与宽度的关系,我希望右边的一个与左边的高度相同;我在文档末尾的 jQuery 中
我正在尝试在 YAML 中创建三列布局。我正在使用此框架的网格功能来定位列(导航、内容、侧边栏)。 我的问题:如何将所有三个 div 的高度设置为相同的大小。 YAML 应该提供 ym-equaliz
这个问题在这里已经有了答案: How do I keep two side-by-side div elements the same height? (24 个答案) 关闭 5 年前。 有没有一种
好像我的 JavaScript 没有听我的。我只是想将所有 anchor 的高度设置为等于这些 anchor 的最高高度。 HTML {{products.title}}
我想对同一主题的两个半脸彩色图像进行均衡,然后将它们合并。它们每个都有不同的色调饱和度和亮度值....使用 opencv 我如何标准化/均衡每个半图像? 我尝试执行 cvEqualizeHist(v,
当一个div高度很大时,我想等于两个div的高度 例子: B ACD Div 2 的高度大于 div 1 最佳答案 我可能有一个可能的解决方案: http://jsfiddle.net/adaz/w
我正在尝试做类似的事情(我已经删除了不必要的东西) Models.Parent.findAll({ where: { parent_id: {
我在 node 中使用 typescript,它在开发模式下运行良好,通过使用以下命令运行我的 index.ts 和 ts-node。 ts-node src/index.ts 但是当我将 types
我是一名优秀的程序员,十分优秀!