我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Node.js服务性能翻倍的方法是什么

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Node.js服务性能翻倍的方法是什么

这篇文章主要介绍“Node.js服务性能翻倍的方法是什么”,在日常操作中,相信很多人在Node.js服务性能翻倍的方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Node.js服务性能翻倍的方法是什么”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

前言

用过 Node.js 开发过的同学肯定都上手过 koa,因为他简单优雅的写法,再加上丰富的社区生态,而且现存的许多 Node.js 框架都是基于  koa 进行二次封装的。但是说到性能,就不得不提到一个知名框架:fastify ,听名字就知道它的特性就是快,官方给出的Benchmarks甚至比  Node.js 原生的 http.Server 还要快。

Node.js服务性能翻倍的方法是什么

Benchmarks

性能提升的关键

我们先看看 fastify 是如何启动一个服务的。

  1. # 安装 fastify 

  2. npm i -S fastify@3.9.1 


// 创建服务实例 const fastify = require('fastify')()  app.get('/', {   schema: {     response: {       // key 为响应状态码       '200': {         type: 'object',         properties: {           hello: { type: 'string' }         }       }     }   } }, async () => {   return { hello: 'world' } })  // 启动服务 ;(async () => {   try {     const port = 3001 // 监听端口     await app.listen(port)     console.info(`server listening on ${port}`)   } catch (err) {     console.error(err)     process.exit(1)   } })()

从上面代码可以看出,fastify 对请求的响应体定义了一个 schema,fastify 除了可以定义响应体的 schema,还支持对如下数据定义  schema:

  1. 鸿蒙官方战略合作共建——HarmonyOS技术社区

  2. body:当为 POST 或 PUT 方法时,校验请求主体;

  3. query:校验 url 的 查询参数;

  4. params:校验 url 参数;

  5. response:过滤并生成用于响应体的 schema。

app.post('/user/:id', {   schema: {     params: {       type: 'object',       properties: {        id: { type: 'number' }       }     },     response: {       // 2xx 表示 200~299 的状态都适用此 schema       '2xx': {         type: 'object',         properties: {           id: { type: 'number' },           name: { type: 'string' }         }       }     }   } }, async (req) => {   const id = req.params.id   const userInfo = await User.findById(id)   // Content-Type 默认为 application/json   return userInfo })

让 fastify 性能提升的的秘诀在于,其返回 application/json 类型数据的时候,并没有使用原生的  JSON.stringify,而是自己内部重新实现了一套 JSON 序列化的方法,这个 schema 就是 JSON 序列化性能翻倍的关键。

如何对 JSON 序列化

在探索 fastify 如何对 JSON 数据序列化之前,我们先看看 JSON.stringify  需要经过多么繁琐的步骤,这里我们参考 Douglas Crockford (JSON 格式的创建者)开源的 JSON-js 中实现的 stringify  方法。

“JSON-js:https://github.com/douglascrockford/JSON-js/blob/master/json2.js

// 只展示 JSON.stringify 核心代码,其他代码有所省略 if (typeof JSON !== "object") {   JSON = {}; } JSON.stringify = function (value) {   return str("", {"": value}) } function str(key, holder) {   var value = holder[key];   switch(typeof value) {     case "string":       return quote(value);     case "number":       return (isFinite(value)) ? String(value) : "null";     case "boolean":     case "null":       return String(value);     case "object":       if (!value) {         return "null";       }       partial = [];       if (Object.prototype.toString.apply(value) === "[object Array]") {         // 处理数组         length = value.length;         for (i = 0; i < length; i += 1) {           // 每个元素都需要单独处理           partial[i] = str(i, value) || "null";         }         // 将 partial 转成 ”[...]“         v = partial.length === 0           ? "[]"           : "[" + partial.join(",") + "]";         return v;       } else {         // 处理对象         for (k in value) {           if (Object.prototype.hasOwnProperty.call(value, k)) {             v = str(k, value);             if (v) {               partial.push(quote(k) + ":" + v);             }           }         }         // 将 partial 转成 "{...}"         v = partial.length === 0           ? "{}"          : "{" + partial.join(",") + "}";         return v;       }   } }

从上面的代码可以看出,进行 JSON 对象序列化时,需要遍历所有的数组与对象,逐一进行类型的判断,并对所有的 key 加上  "",而且这里还不包括一些特殊字符的 encode 操作。但是,如果有了 schema 之后,这些情况会变得简单很多。fastify 官方将 JSON  的序列化单独成了一个仓库:fast-json-stringify,后期还引入了 ajv  来进行校验,这里为了更容易看懂代码,选择看比较早期的版本:0.1.0,逻辑比较简单,便于理解。

“fast-json-stringify@0.1.0:https://github.com/fastify/fast-json-stringify/blob/v0.1.0/index.js

function $Null (i) {   return 'null' }  function $Number (i) {   var num = Number(i)   if (isNaN(num)) {     return 'null'   } else {     return String(num)   } }  function $String (i) {   return '"' + i + '"' }  function buildObject (schema, code, name) {   // 序列化对象 ... }  function buildArray (schema, code, name) {   // 序列化数组 ... }  function build (schema) {   var code = `     'use strict'      ${$String.toString()}     ${$Number.toString()}     ${$Null.toString()}   `   var main    code = buildObject(schema, code, '$main')    code += `     ;     return $main   `    return (new Function(code))() }  module.exports = build

fast-json-stringify 对外暴露一个 build 方法,该方法接受一个 schema,返回一个函数($main),用于将 schema  对应的对象进行序列化,具体使用方式如下:

const build = require('fast-json-stringify')  const stringify = build({   type: 'object',   properties: {     id: { type: 'number' },     name: { type: 'string' }   } }) console.log(stringify)  const objString = stringify({   id: 1, name: 'shenfq' }) console.log(objString) // {"id":1,"name":"shenfq"}

经过 build 构造后,返回的序列化方法如下:

function $String (i) {   return '"' + i + '"' } function $Number (i) {   var num = Number(i)   if (isNaN(num)) {     return 'null'   } else {     return String(num)   } } function $Null (i) {   return 'null' } // 序列化方法 function $main (obj) {   var json = '{'    json += '"id":'    json += $Number(obj.id)   json += ','   json += '"name":'    json += $String(obj.name)    json += '}'   return json }

可以看到,有 schema 做支撑,序列化的逻辑瞬间变得无比简单,最后得到的 JSON 字符串只保留需要的属性,简洁高效。我们回过头再看看  buildObject 是如何生成 $main 内的代码的:

function buildObject (schema, code, name) {   // 构造一个函数   code += `     function ${name} (obj) {       var json = '{'   `   var laterCode = ''   // 遍历 schema 的属性   const { properties } = schema   Object.keys(properties).forEach((key, i, a) => {     // key 需要加上双引号     code += `       json += '${$String(key)}:'     `     // 通过 nested 转化 value     const value = properties[key]     const result = nested(laterCode, name, `.${key}`, value)      code += result.code     laterCode = result.laterCode      if (i < a.length - 1) {       code += 'json += \',\''     }   })    code += `       json += '}'       return json     }   `    code += laterCode    return code }  function nested (laterCode, name, key, schema) {   var code = ''   var funcName   // 判断 value 的类型,不同类型进行不同的处理   const type = schema.type   switch (type) {     case 'null':       code += `       json += $Null()       `       break     case 'string':       code += `       json += $String(obj${key})       `       break     case 'number':     case 'integer':       code += `       json += $Number(obj${key})       `       break     case 'object':       // 如果 value 为一个对象,需要一个新的方法进行构造       funcName = (name + key).replace(/[-.\[\]]/g, '')       laterCode = buildObject(schema, laterCode, funcName)       code += `         json += ${funcName}(obj${key})       `       break     case 'array':       funcName = (name + key).replace(/[-.\[\]]/g, '')       laterCode = buildArray(schema, laterCode, funcName)       code += `         json += ${funcName}(obj${key})       `       break     default:       throw new Error(`${type} unsupported`)   }    return {     code,     laterCode   } }

其实就是对 type 为 "object" 的 properties 进行一次遍历,然后针对 value  不同的类型进行二次处理,如果碰到新的对象,会构造一个新的函数进行处理。

  1. // 如果包含子对象 

  2. const stringify = build({ 

  3.   type: 'object', 

  4.   properties: { 

  5.     id: { type: 'number' }, 

  6.     info: { 

  7.       type: 'object', 

  8.       properties: { 

  9.         age: { type: 'number' }, 

  10.         name: { type: 'string' }, 

  11.       } 

  12.     } 

  13.   } 

  14. }) 

  15.  

  16. console.log(stringify.toString()) 


function $main (obj) {   var json = '{'    json += '"id":'    json += $Number(obj.id)   json += ','   json += '"info":'    json += $maininfo(obj.info)    json += '}'   return json }  // 子对象会通过另一个函数处理 function $maininfo (obj) {   var json = '{'    json += '"age":'    json += $Number(obj.age)   json += ','   json += '"name":'    json += $String(obj.name)    json += '}'   return json }

到此,关于“Node.js服务性能翻倍的方法是什么”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Node.js服务性能翻倍的方法是什么

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

云服务器运算性能检测方法是什么

CPU测试:可以使用SuperPi、Prime95、Cinebench等工具来模拟真实用户的操作,测试云服务器的处理能力。内存测试:可以使用SuperPi和GoldWrk等内存测试工具来测试云服务器的内存使用情况,比较不同进程之间的内存占用情况,找出内存瓶颈。多线程测试:可以使用TwilioThreadingCLI和PyTorchCore来模拟多线程操作,测试云服务器的并发性能。分布式测试:可以使用HadoopFive-Team和SparkStreamingFoundation来...
2023-10-27

mongodb查询性能的方法是什么

评估MongoDB查询性能的方法包括以下几种:使用explain()方法:可以通过explain()方法来分析查询的执行计划,包括查询使用的索引、查询优化器的选择、扫描文档的数量等信息,以帮助优化查询性能。使用索引:索引是提高查询性能的重要
mongodb查询性能的方法是什么
2024-04-09

jvm性能调优的方法是什么

JVM性能调优的方法包括以下几个方面:1. 内存调优:通过调整JVM的堆内存大小(-Xmx和-Xms参数)来优化内存使用效率,避免过多的垃圾回收。同时,可以使用垃圾回收器的不同配置(如CMS、G1等)来适应不同的应用场景。2. 垃圾回收调优
2023-10-10

MongoDB的性能优化方法是什么

MongoDB的性能优化方法包括:索引优化:使用合适的索引可以加快查询速度。确保为经常查询的字段创建索引,并使用复合索引来优化复杂查询。查询优化:避免查询中使用全表扫描和大量排序操作,尽量减少查询返回的字段数量。资源优化:合理配置服务器资源
MongoDB的性能优化方法是什么
2024-05-07

亚马逊服务器性能测试方法是什么

压力测试:模拟高负载的情况下,亚马逊服务器能够承受的压力。测试方法可以通过限制服务器的访问时间、监测服务器的CPU和内存使用情况、设置定时器等方式来模拟高负载情况。响应时间测试:模拟服务器响应客户端请求的速度,以此评估服务器的性能和稳定性。测试方法可以通过监测服务器的响应时间、处理并发请求的能力、调整服务器配置等方式来评估服务器的响应时间。负载测试:模拟高并发量情况下,亚马逊服务器能够承受的负载量...
2023-10-27

云服务器运算性能测试方法是什么

负载测试:模拟多用户同时访问云服务器的情况,记录每个用户的请求数量和延迟时间等指标,以评估云服务器的承载能力和响应速度。性能测试:测试云服务器在单个请求下的处理能力,包括读、写、缓存等方面的性能表现,比如读取大文件、写入小文件等。资源利用率测试:测试云服务器在某个资源(如CPU、内存等)不足的情况下的性能表现,比如读取大量数据或执行长时间运行的任务时的资源占用情况。并发测试:测试云服务器在多个并发用...
2023-10-27

Nginx性能优化的方法是什么

今天小编给大家分享一下Nginx性能优化的方法是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。Nginx 性能优化1、N
2023-07-06

Oracle性能调优的方法是什么

Oracle性能调优的方法包括但不限于以下几种:使用索引:通过在表中创建适当的索引,可以加快查询的速度。可以使用索引来加速WHERE子句中的过滤和排序操作。优化SQL查询语句:对SQL查询语句进行优化,避免使用过多的JOIN操作和子查询,尽
Oracle性能调优的方法是什么
2024-04-19

Docker容器化应用Node.js服务的方法是什么

本文小编为大家详细介绍“Docker容器化应用Node.js服务的方法是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“Docker容器化应用Node.js服务的方法是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习
2022-11-30

Vue性能优化方法是什么

本篇内容主要讲解“Vue性能优化方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue性能优化方法是什么”吧!一、代码层面的优化1.1、v-if 和 v-show 区分使用场景v-if
2023-07-04

JAVA性能设计方法是什么

本篇内容介绍了“JAVA性能设计方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!  概要  许多通常的 Java 性能问题都起源于在
2023-06-03

轻量应用服务器性能测试方法是什么

轻量应用服务器性能测试方法通常是针对具有高负载或高并发访问的系统,如Web应用和数据库系统等。这些系统的性能通常受以下几个因素影响:处理器和内存:轻量应用服务器常常需要处理大量的请求和数据。处理器和内存大小的增加会使系统处理更多的指令,从而影响系统的性能。在这种情况下,可以通过更频繁地运行相同的指令来测试性能。CPU和内存:处理器和内存是轻量应用服务器的关键组成部分。处理器和内存的数量越多
2023-10-26

springboot tomcat性能调优的方法是什么

调优Spring Boot Tomcat的性能可以有以下几种方法:1. 增加Tomcat的线程池大小:通过修改Tomcat的配置文件,可以增加Tomcat的线程池大小,从而提高并发处理能力。2. 调整Tomcat的连接超时时间:通过调整To
2023-10-11

Nginx+Linux性能调优的方法是什么

本篇内容介绍了“Nginx+Linux性能调优的方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Nginx以高性能负载均衡、缓存和w
2023-06-16

Java NIO性能测试的方法是什么

这篇文章主要介绍“Java NIO性能测试的方法是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Java NIO性能测试的方法是什么”文章能帮助大家解决问题。时间(ms)文件大小(byte)Bu
2023-06-17

Tomcat中性能优化的方法是什么

调整JVM参数:通过调整JVM参数来优化Tomcat的性能,可以提高Tomcat的运行效率。例如增加堆内存大小、调整垃圾回收策略等。使用连接池:将数据库连接池和Tomcat连接池进行整合,可以减少数据库连接的创建和销毁次数,提高数据库操作的
Tomcat中性能优化的方法是什么
2024-04-03

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录