HSF称之为高速服务框架HSF(High-speed Service Framework),是在阿里巴巴广泛使用的分布式RPC服务框架。

HSF连通不同的业务系统,解耦系统间的实现依赖。HSF从分布式应用的层面,统一了服务的发布与调用方式,从而帮助用户更加方便、快速地开发分布式应用,以及提供或使用公共功能模块。HSF为用户屏蔽了分布式领域中的各种复杂技术细节,如远程通讯、序列化实现、性能损耗、同步与异步调用方式的实现等。

HSF服务框架包含以下主要组件

服务提供者

在服务框架中真正提供服务功

能实现的应用实例,为了保障服务提供的高可用性,一般均是集群部署。每一个HSF的应用均是以War包的形式存在,运行在阿里巴巴优化定制后的Tomcat容器中,在Tomcat容器层已经集成了HSF服务框架对服务提供者或服务调用者进行配置服务器发现、服务注册、订阅、失效转移等相关功能,所以不管是在服务提供者还是调用者开发时,只需要进行服务相关的配置操作,应用中无需引入任何HSF相关的Jar依赖包。

服务调用者

作为服务的消费者,大多数也是以WAR应用包的方式运行在Tomcat容器中,在阿里巴巴集团内部也有一部分是基于C/C++、PHP、Node.js等语言开发的服务调用者。

地址服务器

在HSF服务框架中肩负着给服务提供者和服务调用者提供部署环境中所有配置服务器和Diamond服务器的服务器列表信息,是由Nginx(是一个高性能的HTTP和反向代理服务

器)提供该服务能力。

配置服务器。

配置服务器主要负责记录环境内所有服务发布(服务提供者的IP地址和服务端口信息)和服务订阅(服务调用者的IP地址和服务端口信息)信息,并将服务相关信息推送到服

务节点上。为了追求服务发布和订阅的推送效率,所有的服务发布和订阅信息均是保存在内存中。

Diamond服务器

本质上,Diamond服务器是一个通用的统一配置管理服务(类似于Zookeeper),给应用提供统一的配置设置和推送服务,使用场景非常广泛,在阿里巴巴内部有很多产品在需要进行配置的保存和获取时都会使用Diamond服务器。

服务节点对配置服务器列表的获取。

服务调用者和服务提供者在随着Tomcat容器启动后,会以域名(比如“xxx.tbsite.net”)的方式获取到可用的地址服务器,通过向地址服务器分别发送获取服务器列表的方式,在容器启动完成后,就已经在该服务节点上获取到了配置服务器和Diamon服务器的IP列表信息。

服务的注册发布

作为服务提供者,当获取到配置服务器的服务器列表后,则向配置服务器发送当前应用中包含的服务提供者相关信息(这些信息均是从应用的配置文件中获取到的,比如服务的接口类全名、服务版本、所属服务组等信息),连同当前服务器的IP地址、服务端口等信息进行服务注册发布.

·服务的订阅

当作为服务调用者的应用启动时,同样在获取配置服务器列表后,就进行与配置服务器的交互,发送服务消费者相关信息(同样包含了服务的接口全名,服务版本、所属服务组)到配置服务器进行服务的订阅服务规则的推送(如果需要)。

如果没有上文提到对于服务安全管控、流量控制等需求的时候,对于Diamond服务器的使用并不是必需的,在有这样的需求场景时,可通过Diamond服务器提供的规则设置界面,对指定服务的服务提供者和调用者设置相关的规则,一旦保存规则后,则此规则配置将会在5秒内推送到与所设置服务相关的服务节点上。

服务交互

在应用进行业务请求处理过程中,出现了服务调用者对服务提供者的调用时,服务调用者会从已经保存在该应用节点上的服务提供者服务器列表中选择(阿里巴巴内部使用随机模式)其中一台进行服务请求的发送,服务交互期间完全是服务调用者和服务提供者间两台服务器间的操作,无需通过中间服务器的中转。

*********************************************************************************************

【如果文字看累了,可b站搜索“沙皮狗2021”,用听的方式领略知识的魅力】

传送门 :https://space.bilibili.com/407643589

【微信公众号】: 沙皮狗2021

*********************************************************************************************

阿里巴巴分布式服务框架HSF相关推荐

  1. 阿里巴巴分布式服务框架 Dubbo 团队成员梁飞专访

    专家访谈 目录(?)[-] 先来个自我介绍吧! Dubbo是什么?能做什么? Dubbo适用于哪些场景? Dubbo的设计思路是什么? Dubbo的需求和依赖情况? Dubbo的性能如何? 和淘宝HS ...

  2. (转)阿里巴巴分布式服务框架 Dubbo 团队成员梁飞专访

    Dubbo是阿里巴巴内部的SOA服务化治理方案的核心框架,每天为2000+ 个服务提供3,000,000,000+ 次访问量支持,并被广泛应用于阿里巴巴集团的各成员站点.Dubbo自2011年开源后, ...

  3. 团队成员梁飞专访:阿里巴巴分布式服务框架Dubbo

    Dubbo是阿里巴巴内部的SOA服务化治理方案的核心框架,每天为2000+ 个服务提供3,000,000,000+ 次访问量支持,并被广泛应用于阿里巴巴集团的各成员站点.Dubbo自2011年开源后, ...

  4. hsf 架构_分布式服务框架HSF

    最近在读阿里巴巴中台战略思想与架构这本书,so和大家分享一些我get到的东东. HSF是阿里巴巴内部的分布式服务框架,这个大家都很熟悉了,先上一张HSF的工作原理图: 这个图说明了HSF框架中每个组件 ...

  5. 分布式服务框架HSF学习

    HSF提供的是分布式服务开发框架,taobao内部使用较多,总体来说其提供的功能及一些实现基础: 1.标准Service方式的RPC   1).Service定义:基于OSGI的Service定义方式 ...

  6. 分布式服务框架HSF学习 Dubbo VS HSF

    HSF提供的是分布式服务开发框架,taobao内部使用较多,总体来说其提供的功能及一些实现基础: 1.标准Service方式的RPC   1).Service定义:基于OSGI的Service定义方式 ...

  7. java rpc框架 hsf_分布式服务框架HSF学习

    转载:http://googi.iteye.com/blog/1884754 HSF提供的是分布式服务开发框架,taobao内部使用较多,总体来说其提供的功能及一些实现基础: 1.标准Service方 ...

  8. 阿里巴巴分布式服务框架 Dubbo

    1.Dubbo是阿里巴巴内部的SOA服务化治理方案的核心框架,每天为2000+ 个服务提供3,000,000,000+ 次访问量支持,并被广泛应用于阿里巴巴集团的各成员站点.Dubbo自2011年开源 ...

  9. 分布式服务框架(一)

    转载自:https://www.cnblogs.com/jiyukai/p/9459983.html 分布式服务框架(一) 一.RPC RPC(Remote Process Call),即远程服务调用 ...

  10. Dubbo分布式服务框架简介

    概览 Dubbo是阿里巴巴SOA服务化治理方案的核心框架,每天为2,000+个服务提供3,000,000,000+次访问量支持,并被广泛应用于阿里巴巴集团的各成员站点:        自开源后,已有不 ...

最新文章

  1. 离奇的梦境,能够防范大脑过拟合
  2. JPA的Column注解总结
  3. 数据包头分析---网络字节序与主机字节序
  4. 现在的年轻人。。。到处都是套路。。。
  5. 前端每周清单半年盘点之 PWA 篇
  6. 网狐棋牌客户端连接服务器修改方法6,网狐游戏服务器 客户端连接
  7. MYSQL专题-MySQL事务实现原理
  8. 中班音乐计算机反思,中班歌曲《不再麻烦好妈妈》活动反思
  9. shell循环和分支
  10. oracle rac standby,oracle RAC数据库建立STANDBY(二)
  11. python入门——P49乱入:生成器
  12. [RL] 配置 gym 与 atari 游戏
  13. 第 6 章 工厂模式
  14. PKU 3667 HDOJ 3667 Hotel ACM 3667 IN HDU
  15. Mac 平台下功能强大的Shimo软件使用指南
  16. Mathematica仿真竞争性Lotka-Volterra方程(3种群)
  17. 一种简单的小型企业报表实现方式
  18. Mac系统输入英文时如何去掉自动提示
  19. Hibernate入门-03
  20. Oracle中if...then的使用

热门文章

  1. 编程语言的执行方式、静态语言和脚本语言
  2. 今年赚钱最多的,居然是个牧羊人
  3. Mouse Without Borders 使用经验
  4. 软件工程——清华大学《软件工程》课程学习与分享
  5. [转载]使用 Abbot 框架自动化测试 Eclipse 插件的用户界面,第 1 部分
  6. 西门子二代精简屏如何使用U盘下载触摸屏程序
  7. Webstorm如何下载插件
  8. 解读:【小爱同学】智能问答系统
  9. 消息队列实现原理(以kafka为例)
  10. Python最新官方教程中文版,火了!!