开发者社区 云原生 微服务 文章 正文

腾讯开源大规模 Node.js 微服务框架 Tars.js

2018年08月02日 5280
版权
版权声明:
本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《 阿里云开发者社区用户服务协议》和 《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写 侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
简介: Tars.js 在腾讯内部经过 5 年多的沉淀与迭代(Node.js@0.10版本即提供支持),广泛运用于腾讯QQ浏览器、腾讯桌面浏览器、腾讯地图、应用宝、腾讯手机管家、互联网+、腾讯医疗、腾讯觅影、保险、彩票等几十个重要业务中,日承担了上百亿流量。

随着互联网的发展,越来越多的业务不仅仅由单一节点(或是单一语言)就可承载,而是趋向多语言分布式协同开发(如接入层由 Node.js 完成,逻辑(数据)层由 C++/GO/Python 实现)并由此组成大型异构系统。

腾讯(现 SuperTeam)基于 Tars 体系研发出 Tars.js 以便用户在不改变异构系统整体架构的情况下快速搭建(迁移) Node.js 服务,并可非常方便的将原来的单一服务拆分为多个(逻辑)子服务。

__20180802154940


Tars.js 特性

Tars.js 包含下述特性:
くろまる 100% 由 JavaScript 编写,不包含任何 C/C++ 代码。
くろまる 多进程负载均衡与管理。
くろまる 代码异常监控与重启。
くろまる 服务日志搜集与处理。
くろまる HTTP(s) 服务监控与用量自动上报,并支持用户自定义维度上报(PP 监控)。
くろまる 符合 Tars(IDL) 规范的编解码模块。
くろまる 支持 Tars RPC 调用与染色(模调自动上报)。
くろまる 支持在线发送管理命令、拉取服务配置。
くろまる 独创 LongStackTraceTM 异常跟踪机制。
くろまる ......

设计理念

高自由度
くろまる 兼容所有(≥0.10)官方 Node.js 版本。
くろまる 对 Node.js 源码无侵入无修改。
くろまる 底层对上层完全透明,支持各种上层框架,无需变更。

也就是说:

您可以使用任何您熟悉的框架(如 Express.js / Koa.js 等,包括但不仅限于 Web 框架),也无需对框架进行任何修改(无需引入任何中间件)。 即可通过 Tars.js 运行,享受平台提供的各种监控与管理特性。

与此同时,Tars.js 所提供的模块,也可以根据您的需求引入(如未使用到则可不引入)。

高性能
Tars.js 为高性能与大并发量而设计,使用了大量的前端(V8)优化技巧(如 FlattenString/FastProperties 等)尽量降低所提供的能力对于业务性能的影响。

经过测试(Web Server),默认的旁路上报与监控对服务性能的影响≤ 5%,常用模块(RPC、日志等)性能位于业界前列。

差异化
くろまる Tars.js 根据不同的业务类型提供差异化运营方案:
くろまる 高流量业务:尽力降低框架对业务性能的影响。
くろまる 低流量业务:充分利用硬件资源提升开发体验。

团队介绍

SuperTeam 来自于腾讯 QQ 浏览器前端团队,由 @SuperZheng 创立于 2017 年。 团队成员均为全栈架构师,熟知 Web(3D) 、终端、后端与大数据计算,并由传统前端向互联网从业者方向发展。

Hello World

1、在 Tars 平台 -> 服务管理 -> 服务上线,上线一个新服务:

服务基本信息:
くろまる 服务名称:HelloWorld
くろまる 服务类型:NODEJS
くろまる 模板名称:tars.default

OBJ 部署信息:
くろまる OBJ名称:HttpObj
くろまる 是TARS:选择否(移除复选框)
くろまる 端口:自动生成端口

2、安装 @tars/deploy 打包工具。

npm i -g @tars/deploy

3、根据业务需求以及您的喜好选择框架(!Tars.js 不限制您使用的框架!),编写业务代码:

const http = require('http');
const hostname = process.env.IP || '127.0.0.1';
const port = process.env.PORT || 3000;
const server = http.createServer((req, res) => {
 res.statusCode = 200;
 res.setHeader('Content-Type', 'text/plain');
 res.end('Hello World
');
});
server.listen(port, hostname, () => {
 console.log(`Server running at http://${hostname}:${port}/`);
});

上述为 Node.js 官网 HTTP Server 例子,在 Tars.js 平台上运行只需要修改 IP 和端口即可。 这里在环境变量中获得到的 IP 和 PORT 即为您在第一步配置的 OBJ 部署信息中的 IP 与端口。

在项目根目录下执行打包工具,即可生成发布包 HelloWorld.tgz:

tars-deploy HelloWorld

5、在 Tars 平台上选择您刚刚创建的服务 -> 发布管理 -> 手动上传发布包,然后发布此版本即可。

6、通过您在第一步配置的 IP 与 端口即可访问您的服务。

Tars.js应用领域

Tars.js 在腾讯内部经过 5 年多的沉淀与迭代(Node.js@0.10版本即提供支持),广泛运用于腾讯QQ浏览器、腾讯桌面浏览器、腾讯地图、应用宝、腾讯手机管家、互联网+、腾讯医疗、腾讯觅影、保险、彩票等几十个重要业务中,日承担了上百亿流量。

原文发布时间为:2018年08月02日
本文作者:前端大学
本文来自云栖社区合作伙伴"前端大学",了解相关信息可以关注"前端大学"。

目录
热门文章
最新文章

AltStyle によって変換されたページ (->オリジナル) /