首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

在 Node.js 中使用 Async Hooks 处理 HTTP 请求上下文实现链路追踪

作者简介:五月君,Software Designer,公众号「Nodejs技术栈」作者。 Async Hooks 一个实际的使用场景是存储请求上下文,在异步调用之间共享数据。.....args) => { const traceId = asyncLocalStorage.getStore(); console.log(traceId, ...args); }...方式二:executionAsyncResource() 返回当前执行的异步资源 executionAsyncResource() 返回当前执行的异步资源,这对于实现连续的本地存储很有帮助,无需像 “方式一...Reference [1] nodejs.org/api/async_hooks.html: https://nodejs.org/api/async_hooks.html [2] Node.js 14...& AsyncLocalStorage: Share a context between asynchronous calls: https://blog.kuzzle.io/nodejs-14-asynclocalstorage-asynchronous-calls

1.9K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    穿针引线之 AsyncLocalStorage

    (); function logWithId(msg) { const id = asyncLocalStorage.getStore(); console.log(`${id !...= new AsyncLocalStorage(); function handler1() { const { req } = asyncLocalStorage.getStore();...中),那么executionAsyncResource返回的就是我们请求所对应的异步资源,上下文就是在run时设置的上下文({req, res}),但是如果是异步getStore那么怎么办呢?...因为这时候executionAsyncResource返回的不再是请求所对应的异步资源,也就拿不到他挂载的公共上下文。为了解决这个问题,Node.js对公共上下文进行了传递。...所以在asyncLocalStorage.getStore() 时即使不是我们在执行run时创建的资源对象,也可以获得具体asyncLocalStorage对象所设置的资源( handler2 中)。

    26120

    Koa源码学习

    AsyncLocalStorage 有两个主要的方法 run():用于在异步操作中保存数据。...接收一个回调函数作为参数,该回调函数会在异步操作执行期间被调用,并且在该回调函数中保存的数据会与异步操作所在的上下文关联起来 getStore():用于在异步操作中获取数据。...if (options.asyncLocalStorage) { const { AsyncLocalStorage } = require('async_hooks') this.ctxStorage...get currentContext () { if (this.ctxStorage) return this.ctxStorage.getStore() } } 如果初始化时配置了option.asyncLocalStorage...就注册一个放在第一位的koa中间件 在请求进入中间件时会执行ctxStorage.run 存入当前的context对象并马上在回调函数中执行next(即请求后续所有的操作) 在后续获取即可通过getStore

    26411

    nodejs+koa以流的形式返回数据

    需求背景: 项目中有多处下载数据的地方,有时候遇到几百万条数据,一口气返回的话,可能会导致内存不够用。 需求:是不是有一种方法,能让我循环每次取一点数据返回?...解决方案:目前想到两种—— 一种是node端使用 stream 方式返回,前端用window.kk的方式打开后端接口。...但本文标题是用node+koa以流的形式返回数据,所以本文先介绍第一种,另一种另起一篇文章。...null 时结束,如果返回undefined,会认为是返回空字符串 * @param getData size参数是用于参考单次返回多少数据,不是说要严格按照这个。...,如果是csv则够用了,如果要用Excel,需要查查有没有方法可以用 // 假如没有更多数据了,返回null })

    3.5K10
    领券