中企动力 > 头条 > api接口服务

网站性能检测评分

注:本网站页面html检测工具扫描网站中存在的基本问题,仅供参考。

api接口服务

搜职网开放API接口 营销视频课程

img

Mu

关注
搜职网(www.globehr.com)近期又有新的举措,将对用户开放API接口,接口页面是http://www.globehr.com/searchcode.html 。API接口的开放有利于任何想提供职务搜索的个人或者是招聘机构

 

API就是ApplicationProgrammingInterface(应用程序接口)的英文缩写,API接口函数是见者有份的,即凡是在Windows工作环境下运行的应用程序,都有权利调用它们。

以前的开放API甚至源代码,主要是在桌面应用上,现在越来越多的Web通过开放API获得了很多有趣、有用的想法,并借助外部的力量,让用户获得了更好的体验。更多大公司也加入到开放API的潮流中,GoogleYahoo!AmazonGoogle桌面搜索今年3月才开放API,很快就产生了大量的创造,大大扩充了可搜索的文件格式。

开放是一种自信,也是一种更高级的商业策略。网站不能靠限制用户离开来留住用户,越开放越让用户放心。苹果就曾经因为不开放,而失去了PC时代,而微软,恰好是把握住了开放的这个节奏和时机。

搜职网此次开放API接口,仍旧是本着用户体验第一的出发点。很多中小网站和个人主页,就将由此将搜职网上对其有价值的信息嵌入自己的网页,并且随时根据搜职网的更新而在自己的网页上实现同步更新。这样不但可以使用户更加快捷的获取自己感兴趣的信息,对于其网站内容而言,也成为醒目的一部分。

不过,国内绝大多数网站似乎还远远没有走到开放API这一步,封闭意识仍然是主流。而搜职网从开始RSS服务,SNS服务,到如今的开放API接口,无一不是在为提高用户体验而努力。

 


Tseer:Tars名字服务功能的轻量化实现 互联网视频课程

img

Ward

关注
作者:钟科

Tseer产品介绍

一.TSeer简介

TSeer是一套服务注册发现容错的方案,是对Tars名字服务功能的轻量化。在腾讯浏览器、应用宝、管家、手机书城、腾讯文学、广点通等众多业务中广泛采用,目前日均承载百亿级的请求量

TSeer轻巧灵便,对业务的侵入性低,非tars服务亦可无缝接入。在服务发现的核心功能之上,Tseer还支持多种负载均衡算法,提供可靠的故障容错策略,可有效解决业务跨地区跨机房调用等难题,极大提升服务的可用性和调用质量,是微服务框架中优秀的名字服务解决方案

TSeer拥有web管理界面和API接入两种方式可供用户根据需求自由选择,通过代理节点和代理服务器机制为需要频繁发布变更的业务提供透明的服务发现功能,学习成本很低,操作也很方便,对于业务维护人员十分友好。

二.研发背景

在传统的单体式应用中,变更发布相对较少,系统中的网络位置也很少变化,偶尔的变更也可以通过手动更改配置的方式来应对。但是在当前海量服务的大环境下,这种架构已经无法高效稳定的支撑高速增长的业务。越来越庞大的分布式服务集群和微服务框架已经逐渐成为主流。

但是新型架构为业务提供更好支撑的同时,频繁的发布更新与动态伸缩也导致了网络位置的频繁变化,在这种情况下业务维护人员手动更改配置这种大规模重复性工作不仅增大了出错的风险,其低效也会限制业务的高速发展。往往配置还没改完,新的变更就需要发布了。所以就必须要一个自动化的服务发现工具来解决这些问题。

然而这些也并不是问题的全部。在保证访问成功的前提下,响应时间作为服务质量中最重要的指标,是影响业务发展最关键的一环。多业务集之间复杂的调用关系再加上跨地区跨网络调用等其他因素,响应时间达不到预期是持续困扰整个业务发展周期的棘手问题。与此同时,无论是采用物理机还是虚拟机,节点挂掉导致的不可用时有发生,如何有效容错也是亟待解决的问题。

基于这些问题,我们开发了TSeer。

三.TSeer架构

整个Tseer的结构分为四部分:TseerServer、业务客户端(主调)、业务服务端(被调)、web管理。

·TseerServer

TseerServer是整个Tseer的枢纽与核心模块。当新节点上线时,需要先通过WEB管理平台在Tseer服务集群注册,将其网络位置信息记录在Tseer系统中。当需要对节点进行下线或者其他修改时,也需要在WEB管理平台就行相关操作。被调节点也会定时上报心跳给TseerServer,server端会屏蔽心跳超时的节点使其无法被调用。

·业务客户端

业务客户端是需要调用其他服务的节点,称之为主调,是服务发现功能的使用者。Tseer为业务客户端提供了:安装Agent与API调用两种方式来从TseerServer获得需要调用的服务(被调)的地址来完成调用。

·业务服务端

业务服务端是需要被调用的节点,称之为被调,是服务的提供者。当新节点上线时,被调需要在TseerServer注册。不论同一个被调服务集群有多少个节点,注册时该服务集群都需要注册一个统一的名字。主调在调用逻辑中只需要写明需要调用的服务的名字,Tseer会根据被调名字来返回被调地址。当被调需要扩容时,只需要把新节点加在该服务对应的名字下面即可。业务人员无需管理被调集群下繁多的服务节点信息,十分方便。

·Web管理

业务信息及节点路由信息的增删改查都是通过web管理界面操作,简便快捷直观。甚至agent安装包都可以通过web平台更新发布。详细使用方式可参考github上TSeer项目的使用文档。

四.Tseer功能的特点

1.负载均衡

当同一业务集群中某些节点被频繁调用而另一些节点没有承担合理的负载时,不仅业务的服务质量和响应时间会大幅下降,同时也会造成资源的浪费。

Tseer系统中,当主调发起调用时,会针对被调名字下所有可用节点为调用提供四种负载均衡方式来保障各个节点的合理负载,分别是

·轮询

·随机

·静态权重

·一致性哈希

用户还可以使用调用分组的方式来自定义负载均衡实现,调用分组会在下文中提到。

2.故障容错

为了解决节点故障导致的业务不可用与服务质量降低,Tseer还提供了可靠的故障容错机制。

当主调进行一次调用之后,会将调用结果上报。如果调用失败Tseer会暂时将该节点屏蔽来避免故障节点被反复调用,Tseer会定时探测被屏蔽的节点,当发现故障节点恢复服务时,会重新将其激活。

对于任意被调节点,满足下列条件之一则屏蔽该节点:

1.在一个检测周期(60秒)内调用失败次数达到2次,且调用错误数占总调用次数的50%以上

2.在5秒内连续调用失败5次以上

对于被屏蔽的节点TseerAgent/Api将每隔30秒对已屏蔽的节点进行重试。

同时当Tseer故障时,主调也能根据缓存信息继续调用。

3.调用优化

Tseer为调用逻辑提供IDC分组、Set分组、All三种方式来解决跨地区调用等问题。

·All

为主调提供所有可用被调节点地址

·IDC分组

IDC分组可以近似的看作就近接入。

该方法按照两个层次进行划分。第一个是物理小组,是最小的组调度单位,即按照节点所在的机房或者区域分配统一的组名。第二个是物理小组组成的逻辑组,可以理解为按照更大的区域来划分的统一的组名。

针对IDC的逻辑分组,Tseer还定义了调用优先级策略。即部分逻辑组不可用时,会按照优先级策略返回可用被调节点地址列表。

·Set分组

IDC分组主要是在区域概念上去划分分组,实现就近访问策略,在后台服务架构中,业务规模达到一定数量时,如果要对某几个服务节点实现根据容量、灰度,分区域管理的隔离控制,IDC分组是无法满足的,而Set分组则是对IDC分组的再细化。

Set分组的命名规则为:Set名.Set地区.Set组。其中Set组是最小区分单元的名称,支持通配符*,表示Set地区下的所有分组。比如0,1,2,3,4或者a,b,c,d。

Set分组的调用逻辑如下:

1.主调(客户端)和被调(服务端)都启用了Set分组,并且Set名要一致才认为是启用同SET内

2.启用Set分组的主调和被调只能访问同Set内的节点

3.主调启用Set分组,被调没有启用Set分组,则默认会走按IDC分组查询的逻辑(前提是启用了IDC分组)

4.两种接入方式

根据服务客户端是否在其物理机中部署TseerAgent,Tseer的使用方式可以分为Agent和TseerAPI两种方式:

·Agent方式

名字路由

Agent方式下,TseerAgent会定期缓存被调方的信息。并根据调用方指定的负载均衡策略将被调节点信息返给调用方。如果调用方希望通过服务特性来实现负载均衡,Tseer也支持按照调用方指定的分组策略将被调的组信息返给调用方。

数据上报

每次调用完成后,调用方需要调用TseerApi提供的上报接口上报调用信息,调用信息将由TseerApi即使上报至TseerAgent。TseerAgent将根据调用信息剔除失效被调节点。

容错使用Agent方式时,如果TseerAgent失效,TseerApi将会从内存中返回已访问过的节点给主调,如果TseerApi缓存失效,此时TseerApi将会从本地磁盘中的缓存文件恢复缓存信息提供给主调。需要注意的是此时TseerApi提供给主调服务的信息为有损信息,TseerApi不保证节点一定健康。

·TseerApi方式

名字路由

Agent方式与TseerApi方式的区别在于是否需要在主调的宿主机中部署TseerAgent。TseerApi会直接访问Tseerserver。并且被调方信息缓存、负载均衡以及失效节点剔除都在TseerApi中完成。

TseerApi会定时拉取Tseerserver的后端信息并屏蔽不可用的被调节点。

容错

Tseerserver故障时,TseerApi会将内存中缓存的信息返回给主调。当内存缓存不可用时,TseerApi将会用本地磁盘中的缓存恢复内存缓存。

AgentApi方式与TseerApi方式对比

结语

TSeer是一套服务注册发现容错的方案,是对Tars名字服务功能的轻量化,轻巧灵便,对业务的侵入性低。在服务发现的核心功能之上,Tseer还支持多种负载均衡算法,提供可靠的故障容错策略,可有效解决业务跨地区跨机房调用等难题,极大提升服务的可用性和调用质量,是微服务框架中优秀的名字服务解决方案。

DDI网络:DDI核心服务的“秘密”,你知道么? 互联网视频课程

img

加非妃

关注
DDI提供网络基础服务的DNS域名解析、网络IP地址分配和智能化管理服务,(DDI)也是DNS、DHCP、IPAM的简写。作为DDI网络核心服务,ZDNSDDI全面满足以下需求:

一、具备双机HA高可靠部署,任何一台故障,另一台继续提供DNS解析和IP地址分配服务,确保(DDI)网络基础服务的可用,ZDNS(DDI)服务保障让人心安。

二、在IPv4、IPv6支持上可以兼顾,这是因为IPv6快速普及,网络基础服务也要升级,从IPv4、IPv6双栈,IPv6自动化演进到IPv6的全面自动化支撑缺一不可。

三、具备专业的DNS权威解析系统:满足多活、灾备数据中心的解析调度和业务系统横向调度能力;提供全功能API接口无缝对接第三方运维管理平台,并对解析服务数据进行实时和历史报表分析;全面支持IPv6、DNSSEC等下一代互联网技术,便于升级拓展。

四、网络地址管理可视化、自动化:ZDNS提供了国内首款专业化地址管理产品,将IP管理各个环节纳入一套系统进行一体化集中管理,首次真正实现了IP运维和管理的自动化。

五、紧密结合业务特征,提供丰富的关键运行指标报表:提供丰富的历史和趋势分析、全面监控基础设施运行状态、简化网络设备和应用系统管理、增强网络和系统安全性健壮性。

六、ZDNSCMS(CloudManagementSystem)云管理系统平台拥有强大的管理控制能力和工业级消息总线技术,可实现安全控制、权限分级;同时,ZDNS域名、IP基础服务自动化供给能够增强虚拟化、私有云部署管理,提升智能化和连续性,从而实现私有云价值最大化。

DDI核心网络服务(DDI,DHCP/DNS/IP地址管理)提供智能DNS解析、智能DHCP地址分配和IP地址管理,打造高速、安全、稳定、易管理的DDI网络基础服务。

HTTPDNS:HTTPDNS解析服务中那些“破事”你知道么? 行业视频课程

img

白亦

关注
HTTPDNS是移动场景下的域名解析全链路解决方案,HTTPDNS解决解析延迟、(HTTPDNS)还解决域名劫持、(HTTPDNS)调度精确性、(HTTPDNS)域名解析生效慢等一系列问题。传统的DNS解析是客户端通过运营商LocalDNS获取域名解析结果,因为LocalDNS存在缓存等原因,这种方式所引起的域名劫持、域名解析错误、流量调度不准确等问题,让系统运维人员非常头痛。

ZDNSHTTPDNS优势

一、安全,高效,避免存中毒、访问劫持:使用HTTP协议访问ZDNSCloud获得域名解析结果,绕过运营商的LocalDNS,避免域名劫持,让每一次访问都畅通无阻。

二、更精细的源端控制:由于运营商策略的多样性,其LocalDNS的解析结果可能不是最近、最优的节点,HTTPDNS能够直接得到客户端的出口网关IP,从而能够更准确地判断客户端的地区和运营商,获得最精准的解析结果,(HTTPDNS)让客户端就近接入业务节点;结合ZDNSCloud自定义视图功能,实现基于云的全球精准流量负载;HTTPDNS能更完善的网络性能管理:端对端实时监控IDC、CDN资源,ZDNSCloud实现多个数据中心、CDN流量负载和服务优选,保证APP访问最优的网络资源,也能实现内容永远在线可访问。简洁的API接口,满足不同的使用场景:HTTPDNS对外提供简洁的API接口,(HTTPDNS)典型场景是移动端APP直接调用该接口解析域名,也支持在服务端调用的场景。

img

在线咨询

建站在线咨询

img

微信咨询

扫一扫添加
动力姐姐微信

img
img

TOP