您当前的位置:首页 > 电脑百科 > 程序开发 > 编程百科

gateway worker 分离部署

时间:2022-11-14 17:03:58  来源:今日头条  作者:it程序员

什么是Gateway Worker分离部署

GatewayWorker有三种进程,Gateway进程负责网络IO,BusinessWorker进程负责业务处理,Register进程负责协调Gateway与BusinessWorker之间建立TCP长连接通讯。我们可以把Gateway BusinessWorker Register分开部署在不同的服务器上,当业务进程BusinessWorker出现瓶颈时,单独增加BusinessWorker服务器提升系统负载能力。同理,如果Gateway进程出现瓶颈,则增加Gateway服务器。而Register服务一个集群只需要部署一台服务器,Register服务只有在进程启动的时候协调Gateway与BusinessWorker建立TCP连接,集群运行起来后通讯量极低,不会成为系统瓶颈。

部署示例

Applications/Todpole为例,假如需要部署三台服务器提供高可用服务。瓶颈在BusinessWorker进程,则可使用1台作为gateway服务器,另外两台做BusinessWorker服务器。(如果瓶颈在gateway进程(一般是带宽瓶颈),则可以2台gateway机器,1台BusinessWorker机器,部署方法类似)。Register服务可以部署在任意一台服务器上。

gateway worker 分离部署扩容步骤

1、由于一个集群只需要一台服务器运行Register服务,这里选择192.168.0.1,端口是1236(端口为start_register.php中监听的端口),其它服务器中start_register.php中的代码可以注释掉。

2、将进程切分,将Gateway进程部署在一台机器上(假设内网ip为192.168.0.1),这台服务器也运行着集群的Register服务,而BusinessWorker部署在另外两台机器上(内网ip为192.168.0.2/3)。

3、由于192.168.0.1这台机器只部署Gateway进程和Register进程,所以将该服务器上初始化BusinessWorker实例的地方注释或者删掉,避免运行BusinessWorker进程,例如

这里打开文件Applications/Todpole/start_businessworker.php,注释掉bussinessWorker初始化

...
// bussinessWorker
//$worker = new BusinessWorker();
//$worker->name = 'TodpoleBusinessWorker';
//$worker->count = 4;
...

4、配置Gateway服务器(192.168.0.1)上start_gateway.php中的lanIp=192.168.0.1与本机ip一致,配置registerAddress为192.168.0.1:1236,start_gateway.php文件最终类似下面配置

文件Applications/Todpole/start_gateway.php

<?php
use WorkermanWorker;
use GatewayWorkerGateway;

// gateway
$gateway = new Gateway("Websocket://0.0.0.0:8282");
$gateway->name = 'TodpoleGateway';
$gateway->count = 4;
// ==== 注意这里配置的是本机内网ip ====
$gateway->lanIp = '192.168.0.1';
// ==== 注意这里配置的是192.168.0.1:1236 ====
$gateway->registerAddress = '192.168.0.1:1236';
$gateway->startPort = 2000;
$gateway->pingInterval = 10;
$gateway->pingData = '{"type":"ping"}';

...

5、由于192.168.0.2/3 两台服务器只部署BusinessWorker进程,所以将这两台服务器上的Gateway进程初始化文件注释掉或者删掉。

这里打开Applications/Todpole/start_gateway.php,注释掉gateway初始化部分

<?php
use WorkermanWorker;
use GatewayWorkerGateway;

// gateway
//$gateway = new Gateway("Websocket://0.0.0.0:8282");
//$gateway->name = 'TodpoleGateway';
//$gateway->count = 4;
//$gateway->lanIp = '192.168.0.1';
//$gateway->registerAddress = '192.168.0.1:1236';
//$gateway->startPort = 2000;
//$gateway->pingInterval = 10;
//$gateway->pingData = '{"type":"ping"}';

6、打开192.168.0.2/3两台服务器的start_businessworker.php,配置registerAddress为 192.168.0.1:1236

7、逐台启动

至此,GatewayWorker分布式部署完毕。

一些问题及解答

为什么将Gateway与BusinesWorker分别部署在不同的服务器上?

首先说明的是不一定非要将Gateway BusinessWorker分开部署,但是推荐分开部署,原因如下:

1、由于Gateway只负责网络IO,只要服务器带宽够用,绝大多数情况下Gateway服务器不会成为瓶颈,所以在很长时间我们只需要一台或者少数几台Gateway服务器即可。由于我们不想BusinessWorker影响到Gateway,所以将Gateway和BusinessWorker分开部署

2、BusinessWorker主要负责业务逻辑。当请求量增大时,由于可能BusinessWorker业务比较复杂,负载可能会明显升高,这时我们只要单纯增加BusinessWorker服务器即可,Gateway服务器则一般不需要变动,也就是不用通知客户端Gateway的ip列表有所变动

3、当系统BusinessWorker负载较低,需要下线服务器时,我们只需要下线BusinessWorker服务器即可,无需变动GateWay服务器,也就不会导致客户端链接因为服务器下线而断开。

当BusinessWorker服务器集群负载较低时,需要下线一些机器怎么实施?

只需要停止BusinessWorker的服务,运行php start.php stop,然后下线即可。Gateway服务器会自动感知有BusinessWorker服务器下线,不会再将请求转发给下线的机器,整个下线过程中不影响服务质量。

当Gateway服务器集群负载较低时,需要下线一些机器怎么实施?

首先还是要说明下Gateway服务器一般情况下不会成为系统瓶颈,所以一般你很长时间内Gateway服务器数量是一个稳定的值,一般一台即可

下线Gateway服务器,首先停止服务,运行php start.php stop,此时会导致该服务器上已有的客户端链接断开,然后下线服务器即可。此时BusinessWorker会感知到有Gateway服务器下线,会自动断开与Gateway进程的联系。



Tags:gateway   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
Kubernetes API Gateway 1.0 上线,维护者提出了未来规划
作者 | Joab Jackson译者 | 王强策划 | Tina用户期待已久的 Kubernetes Gateway API 现已准备好投入生产环境,并附带一系列新的支持工具来帮助 K8s 管理员入门。Kubernetes G...【详细内容】
2023-11-14  Search: gateway  点击:(284)  评论:(0)  加入收藏
探索 Gateway API 在 Service Mesh 中的工作机制
前几天 Gateway API 宣布在 0.8.0 中支持服务网格[1],这意味着 GAMMA[2](Gateway API for Mesh Management and Administration)有了新进展,虽然目前还是实验阶段。去年 6 月 Ga...【详细内容】
2023-09-08  Search: gateway  点击:(287)  评论:(0)  加入收藏
一篇打通微服务架构,Nacos + Gateway + Redis + MySQL + Docker
基本组件Nginx、Gateway、Nacos、Sentinel、Ribbon、Feign、Seata、Redis、RabbitMQ、MySQL、docker、Vue。大家好,我是哪吒。今天分享一篇一站式微服务架构,读哪吒编程,品技术...【详细内容】
2023-02-27  Search: gateway  点击:(185)  评论:(0)  加入收藏
gateway worker 分离部署
什么是Gateway Worker分离部署GatewayWorker有三种进程,Gateway进程负责网络IO,BusinessWorker进程负责业务处理,Register进程负责协调Gateway与BusinessWorker之间建立TCP长连...【详细内容】
2022-11-14  Search: gateway  点击:(335)  评论:(0)  加入收藏
深入学习spring cloud gateway 限流熔断
目前,Spring Cloud Gateway是仅次于Spring Cloud Netflix的第二个最受欢迎的Spring Cloud项目(就GitHub上的星级而言)。它是作为Spring Cloud系列中Zuul代理的继任者而创建的。...【详细内容】
2021-04-21  Search: gateway  点击:(693)  评论:(0)  加入收藏
SpringCloud Gateway 身份认证
使用SpringCloud技术栈搭建微服务集群,可以选择的组件比较多,由于有些组件已经闭源或停更,这里主要选用spring-cloud-alibaba作为我们的技术栈。 服务注册与发现: nacos-discove...【详细内容】
2020-08-19  Search: gateway  点击:(619)  评论:(0)  加入收藏
Gateway - 网关应用
如果团队正在使用微服务架构搭建服务体系,或者正在考虑向微服务架构转型,那么应该熟悉网关,至少应该了解网关模式,网上有关于API gateway pattern模式的详细描述。微服务架构的A...【详细内容】
2020-03-22  Search: gateway  点击:(381)  评论:(0)  加入收藏
502 bad gateway nginx什么意思
一、502 bad gateway nginx什么意思?通俗的来讲,502 bad gateway代表您所访问的网站出了问题,因为502 Bad Gateway 服务器作为网关或者代理时,是为了完成访问下一个服务器,但该...【详细内容】
2019-10-14  Search: gateway  点击:(1380)  评论:(0)  加入收藏
▌简易百科推荐
Netflix 是如何管理 2.38 亿会员的
作者 | Surabhi Diwan译者 | 明知山策划 | TinaNetflix 高级软件工程师 Surabhi Diwan 在 2023 年旧金山 QCon 大会上发表了题为管理 Netflix 的 2.38 亿会员 的演讲。她在...【详细内容】
2024-04-08    InfoQ  Tags:Netflix   点击:(2)  评论:(0)  加入收藏
即将过时的 5 种软件开发技能!
作者 | Eran Yahav编译 | 言征出品 | 51CTO技术栈(微信号:blog51cto) 时至今日,AI编码工具已经进化到足够强大了吗?这未必好回答,但从2023 年 Stack Overflow 上的调查数据来看,44%...【详细内容】
2024-04-03    51CTO  Tags:软件开发   点击:(7)  评论:(0)  加入收藏
跳转链接代码怎么写?
在网页开发中,跳转链接是一项常见的功能。然而,对于非技术人员来说,编写跳转链接代码可能会显得有些困难。不用担心!我们可以借助外链平台来简化操作,即使没有编程经验,也能轻松实...【详细内容】
2024-03-27  蓝色天纪    Tags:跳转链接   点击:(13)  评论:(0)  加入收藏
中台亡了,问题到底出在哪里?
曾几何时,中台一度被当做“变革灵药”,嫁接在“前台作战单元”和“后台资源部门”之间,实现企业各业务线的“打通”和全域业务能力集成,提高开发和服务效率。但在中台如火如荼之...【详细内容】
2024-03-27  dbaplus社群    Tags:中台   点击:(9)  评论:(0)  加入收藏
员工写了个比删库更可怕的Bug!
想必大家都听说过删库跑路吧,我之前一直把它当一个段子来看。可万万没想到,就在昨天,我们公司的某位员工,竟然写了一个比删库更可怕的 Bug!给大家分享一下(不是公开处刑),希望朋友们...【详细内容】
2024-03-26  dbaplus社群    Tags:Bug   点击:(5)  评论:(0)  加入收藏
我们一起聊聊什么是正向代理和反向代理
从字面意思上看,代理就是代替处理的意思,一个对象有能力代替另一个对象处理某一件事。代理,这个词在我们的日常生活中也不陌生,比如在购物、旅游等场景中,我们经常会委托别人代替...【详细内容】
2024-03-26  萤火架构  微信公众号  Tags:正向代理   点击:(11)  评论:(0)  加入收藏
看一遍就理解:IO模型详解
前言大家好,我是程序员田螺。今天我们一起来学习IO模型。在本文开始前呢,先问问大家几个问题哈~什么是IO呢?什么是阻塞非阻塞IO?什么是同步异步IO?什么是IO多路复用?select/epoll...【详细内容】
2024-03-26  捡田螺的小男孩  微信公众号  Tags:IO模型   点击:(9)  评论:(0)  加入收藏
为什么都说 HashMap 是线程不安全的?
做Java开发的人,应该都用过 HashMap 这种集合。今天就和大家来聊聊,为什么 HashMap 是线程不安全的。1.HashMap 数据结构简单来说,HashMap 基于哈希表实现。它使用键的哈希码来...【详细内容】
2024-03-22  Java技术指北  微信公众号  Tags:HashMap   点击:(11)  评论:(0)  加入收藏
如何从头开始编写LoRA代码,这有一份教程
选自 lightning.ai作者:Sebastian Raschka机器之心编译编辑:陈萍作者表示:在各种有效的 LLM 微调方法中,LoRA 仍然是他的首选。LoRA(Low-Rank Adaptation)作为一种用于微调 LLM(大...【详细内容】
2024-03-21  机器之心Pro    Tags:LoRA   点击:(12)  评论:(0)  加入收藏
这样搭建日志中心,传统的ELK就扔了吧!
最近客户有个新需求,就是想查看网站的访问情况。由于网站没有做google的统计和百度的统计,所以访问情况,只能通过日志查看,通过脚本的形式给客户导出也不太实际,给客户写个简单的...【详细内容】
2024-03-20  dbaplus社群    Tags:日志   点击:(4)  评论:(0)  加入收藏
站内最新
站内热门
站内头条