Golang在接入层长连接服务中的实践-黄欣
Golang 在接入层长连接服务中的实践 黄欣 基础平台-架构部 目录 • 背景 • 架构 • 心得 目录 • 架构 • 心得 背景—why 长连接? • 业务场景 – 大量实时计算 • 司机乘客撮合 • 实时计价 – 高频度的数据交互 • 坐标数据 • 计价数据 – App和服务端双向可达 • 上行(抢单) • 下行(派单) 背景—why golang? • 开发效率0 码力 | 31 页 | 1.67 MB | 1 年前3go-zero开源项目的成长史
0 码力 | 31 页 | 4.83 MB | 9 月前3张波-虎牙直播在微服务改造中的实践
Meetup #6 广州站 微服务改造事项 DNS-F在数据 库场景的落地 名字服务在负 载均衡场景的 落地 DNS-F在微服 务场景的落地 应用层探活 数据库故障 恢复时间长 服务故障牵 引慢,流量 接入生效时 间长 DNS生效慢 内部服务无 就近接入能 力 服务性能下 降流量不摘 除 实 例 切 换 能 力 秒 级 流 量 牵 引 能 力 D N S 就 近 接 入 能 力 华中IDC 华北IDC Nginx Nginx Nginx Web server 专线 背景 负载均衡变更需要更新配置发布后 才能生效,节点扩缩容,屏蔽操作 需要人工参与,流量接入接出时间 长 目标 流量接入接出时长低于30秒 负载均衡配置下发无状态改造 虎牙负载均衡部署的机器数百,配置下发的可靠性保障,一致性保障要求特别严格, 如果出现配置下发不及时,或下发配置失败,极大可能出现故障,同时负载均衡服 客户端主动监听配置更新,配置秒 级生效,新扩容服务主动拉取全量 配置,流量接入时长缩短3分钟+ 配置名字服务 配置IP方式 服务端下发文件更新配置,更新配 置生效时间长,由于需要预先知道 负责均衡集群的机器信息,扩缩容 需要等元信息同步以后才能接入流 量,扩容流量接入时间长 负载均衡节点对接名字服务 虎牙负载均衡部署的机器一台机器上可能存在数百的配置,每次节点生效需要重新 reload配置,且节点新增或删除需人工上系统操作配置,配置生效对服务会有中断0 码力 | 27 页 | 1.03 MB | 1 年前3Zabbix 3.4 中文手册
器 的 子 进 程 实 例 个 数\\Zabbix 2.2.0 后 支 持 该 参 数。 Timeout no 1-30 3 agent, SNMP 设 备 或 外 部 检 查 的 超 时 时 长 (单 位 秒)。 43 参数必 范围 默认值 描述 TLSCAFile no 包 含 用 于 对 等 证 书 验 证 的 顶 级 CA 证 书 的 文 件 的 完 整 路 径 名, 用 于 VMwareTimeout no 1-300 10 vmware 采 集 器 等 等 VMware 服 务 (vCen- ter or ESX 管 理 程 序) 响 应 的 最 大 时 长. Zabbix 2.2.9, 2.4.4 后 支 持 该 参 数。 Note: Zabbix 支持的配置文件是无BOM的 utf-8 编码. 注释只能在行的开头以”#” 开始. 2 Zabbix .conf. Zabbix 2.4.0 后都支持模式匹 配. 参看关于限制条件特例 。 JavaGateway no Zabbix Java 网关的 IP 地址 (或 主机名) 。 Java 轮询器启动时才需要该参 数。 Zabbix 2.0.0 后的所有版本支 持该参数。 JavaGatewayPort no 1024-32767 10052 Zabbix Java 网关监听端口。 Zabbix0 码力 | 1757 页 | 12.63 MB | 1 年前3Nacos架构&原理
规模:十万级服务/配置,百万级连接,具备强大扩展性。 15 > 简介 Nacos 生态 Nacos 几乎支持所有主流语言,其中 Java/Golang/Python 已经支持 Nacos 2.0 长链接协议,能 最大限度发挥 Nacos 性能。阿里微服务 DNS(Dubbo+Nacos+Spring-cloud-alibaba/Seata/ Sentinel)最佳实践,是 Java 微服务生态最佳解决方案;除此之外,Nacos 与存储、Server 间、Server 与 SDK 间高效通信问题。 容量管理:管理每个租户,分组下的容量,防止存储被写爆,影响服务可用性。 流量管理:按照租户,分组等多个维度对请求频率,长链接个数,报文大小,请求流控进行控制。 缓存机制:容灾目录,本地缓存,Server 缓存机制,是 Nacos 高可用的关键。 启动模式:按照单机模式,配置模式,服务模式,DNS 模式模式,启动不同的模块。 Nacos 架构 1. Nacos 提供可视化的控制台,可以对配置进行发布、更新、删除、灰度、版本管理等功能。 2. SDK 可以提供发布配置、更新配置、监听配置等功能。 3. SDK 通过 GRPC 长连接监听配置变更,Server 端对比 Client 端配置的 MD5 和本地 MD5 是否相等,不相等推送配置变更。 4. SDK 会保存配置的快照,当服务端出现问题的时候从本地获取。 配置资源模型0 码力 | 326 页 | 12.83 MB | 9 月前3Zabbix 4.0 中文手册
Zabbix 2.4.0. See special notes about limitations. JavaGateway 否 abbix Java 网关的 IP 地址 (或主机名) 。 Java 轮询器启动时才需 要该参数。 Zabbix 2.0.0 以后的所 有版本都支持该参数. JavaGateway no IP address (or hostname) of Zabbix Java instances of escalators. This parameter is supported since Zabbix 3.0.0. StartHTTPPollers 否 -1000 TTP 轮询进程的初始实 例数量。 在 Zabbix 1.8.5 版本 之前,最大能设置为 255。 StartHTTPPollers no 0-1000 1 Number of pre-forked instances HTTP pollers1. The upper limit used to be 255 before version 1.8.5. StartIPMIPollers 否 -1000 PMI 轮询进程的初始实 例数量。 在 Zabbix 1.8.5 版本 之前,最大能设置为 255。 StartIPMIPollers no 0-1000 0 Number of pre-forked instances0 码力 | 1992 页 | 17.90 MB | 1 年前3Zabbix 4.4 中文手册
Zabbix 2.4.0. See special notes about limitations. JavaGateway 否 abbix Java 网关的 IP 地址 (或主机名) 。 Java 轮询器启动时才需 要该参数。 Zabbix 2.0.0 以后的所 有版本都支持该参数. JavaGateway no IP address (or hostname) of Zabbix Java instances of escalators. This parameter is supported since Zabbix 3.0.0. StartHTTPPollers 否 -1000 TTP 轮询进程的初始实 例数量。 在 Zabbix 1.8.5 版本 之前,最大能设置为 255。 StartHTTPPollers no 0-1000 1 Number of pre-forked instances HTTP pollers1. The upper limit used to be 255 before version 1.8.5. StartIPMIPollers 否 -1000 PMI 轮询进程的初始实 例数量。 在 Zabbix 1.8.5 版本 之前,最大能设置为 255。 StartIPMIPollers no 0-1000 0 Number of pre-forked instances0 码力 | 1850 页 | 13.52 MB | 1 年前3Zabbix 4.2 中文手册
Zabbix 2.4.0. See special notes about limitations. JavaGateway 否 abbix Java 网关的 IP 地址 (或主机名) 。 Java 轮询器启动时才需 要该参数。 Zabbix 2.0.0 以后的所 有版本都支持该参数. JavaGateway no IP address (or hostname) of Zabbix Java instances of escalators. This parameter is supported since Zabbix 3.0.0. StartHTTPPollers 否 -1000 TTP 轮询进程的初始实 例数量。 在 Zabbix 1.8.5 版本 之前,最大能设置为 255。 StartHTTPPollers no 0-1000 1 Number of pre-forked instances HTTP pollers1. The upper limit used to be 255 before version 1.8.5. StartIPMIPollers 否 -1000 PMI 轮询进程的初始实 例数量。 在 Zabbix 1.8.5 版本 之前,最大能设置为 255。 StartIPMIPollers no 0-1000 0 Number of pre-forked instances0 码力 | 1869 页 | 13.68 MB | 1 年前3Zabbix 5.4 中文手册
Zabbix 2.4.0. See special notes about limitations. JavaGateway 否 abbix Java 网关的 IP 地址 (或主机名) 。 Java 轮询器启动时才需 要该参数。 Zabbix 2.0.0 以后的所 有版本都支持该参数. JavaGateway no IP address (or hostname) of Zabbix Java instances of escalators. This parameter is supported since Zabbix 3.0.0. StartHTTPPollers 否 -1000 TTP 轮询进程的初始实 例数量。 在 Zabbix 1.8.5 版本 之前,最大能设置为 255。 StartHTTPPollers no 0-1000 1 Number of pre-forked instances HTTP pollers1. The upper limit used to be 255 before version 1.8.5. StartIPMIPollers 否 -1000 PMI 轮询进程的初始实 例数量。 在 Zabbix 1.8.5 版本 之前,最大能设置为 255。 StartIPMIPollers no 0-1000 0 Number of pre-forked instances0 码力 | 2339 页 | 19.57 MB | 1 年前3Zabbix 7.0 中文手册
的通知机制,允许用户为几乎任何事件配置基于电子邮件的告警,以实现对服务器问题做出快速反应。Zabbix 基于存储的数据提供出色 的报告和数据可视化功能。这使得 Zabbix 成为容量规划的理想选择。 Zabbix 支持轮询和 trapping。所有 Zabbix 报告和统计数据以及配置参数都可以通过基于 Web 的前端访问。基于 Web 的前端确保可以 从任何位置评估您的网络状态和服务器的健康状况。如果配置得当,不管 get[OID] 监控项) 这些 poller 进程是异步的 - 它们可以在不等响应的情况下启动新的检查,并可以配置最多 1000 个并发检查。 异步 poller 的设计是为了提高效率,与同步轮询器相比,同步 poller 在同一时间只能执行一个检查,并且大部分时间都花费在等待响应 上。 server/proxy 配置文件中新增了 pollers 参数,你可以通过修改StartAgentPollers Zabbix 进程 请使用侧边导航栏来访问此章节中的内容。 1 Server 概述 Zabbix server 是整个 Zabbix 软件的核心程序。 Zabbix Server 负责执行数据的主动轮询和被动获取,计算触发器条件,向用户发送通知。它是 Zabbix Agent 和 Proxy 报告系统可用性 和完整性数据的核心组件。Server 自身可以通过简单服务远程检查网络服务(如 Web 服务器和邮件服务器)。0 码力 | 1951 页 | 33.43 MB | 1 年前3
共 592 条
- 1
- 2
- 3
- 4
- 5
- 6
- 60