node 写简单接口发现一件诡异的事,求解答

2023-09-18 10:43:17 +08:00
 unt


用 node 写了一个接口,这个接口里会调用很多现成的 api 接口,然后将这些接口返回的数据重新组合规整一并返回。

测试过程中发现 A 接口返回的数据居然和直接调用 A 接口不一样。。

A 接口写在 app.get 里返回:
{data:[{bit:'35'}],code:0}

直接调用 A 接口返回:
{data:[{bit:'0'}],code:0}


这究竟是为什么。。。
3218 次点击
所在节点    Node.js
24 条回复
cherryas
2023-09-18 10:46:14 +08:00
建议不用想歪了,显然是发出的请求不一样。(仅代表我个人观点)
dream4ever
2023-09-18 10:53:51 +08:00
一切的诡异最后都会有真实的原因在背后,就你这个情况而言,后端数据有没有可能是其他人修改了?或者是哪里的代码写错了?计算机不会出现灵异事件,绝大部分都是人的原因。
caiqichang
2023-09-18 11:01:23 +08:00
抓包对比一下请求头
NessajCN
2023-09-18 11:02:30 +08:00
没看懂啥叫「直接调用 A 接口」
建议你把两种方式的具体操作方法或代码 po 上来
juzisang
2023-09-18 11:14:43 +08:00
nodejs 不至于这么点东西都能搞错,建议好好排查下其它问题...
dreasky
2023-09-18 11:18:04 +08:00
你的 res 能不要写和外面一样的吗
aikilan
2023-09-18 11:23:08 +08:00
这种情况跟 NODE 没啥关系,直接看看两次请求的 body 有啥区别,如果是内部的接口聚合,不如直接找对于的开发问问有什么需要注意的,或者直接让对方给你断点也许啊
pota
2023-09-18 11:26:49 +08:00
先确定请求头和请求内容一致吧。肯定是有不一样的地方
winnerczwx
2023-09-18 11:37:45 +08:00
最诡异的地方不应该是你两次请求参数不同得到了不同的返回值, 而你却觉得这很诡异还发了一贴...?
Belmode
2023-09-18 11:38:55 +08:00
这个接口里,两个 fetch 方法都是异步的,当这个路由的 Handler 方法返回,fetch A 或者 fetch B 总有一个先调用了 resovle ,第二个还没有调用完成,express 直接把 response 直接响应了。

显然,你这个路由 handler 里最先处理的是 第二个 fetch 方法,获取的 B 数据
Belmode
2023-09-18 11:40:11 +08:00
解决办法,用 Promise.all 包裹,或者把两个 fetch 用 then 串联起来。
TabGre
2023-09-18 11:41:43 +08:00
总想搞个大新闻
jaylee4869
2023-09-18 11:51:13 +08:00
基于你的写法我感觉你对 Node.js 不是很熟悉。
常量最好用 const 申明,现在 commonjs 已经逐渐推出历史舞台,所以还是尽快迁到 ESM ,另外请使用 async/await 来处理 Promise 吧,起码可以直观看出代码的执行顺序……
shuimugan
2023-09-18 12:56:16 +08:00
基础不牢看什么都是魔法,上抓包数据
royalknight
2023-09-18 13:27:52 +08:00
应该是接口的问题,发出来让大伙压力测试下
unt
2023-09-18 14:59:41 +08:00
@royalknight #15 我初步查下来是接口并发有问题。没心气神了,不管了,自己不测试的后端是真菜啊
M003
2023-09-18 15:50:56 +08:00
如果参数一样. 你先确认出来 打印出来是 A,还是 B 的. 建议你在 log 中写死 'A'/'B'
====
你 A,B 是并发请求; 并不是单步请求,处理完 A,再请求 B.

要不就并发 用 `Promise.all` 要不用 await 单步查看一下,每一步返回什么信息.
unt
2023-09-18 16:14:30 +08:00
@M003 #17 这些肯定都知道的呀,所以才说诡异。。这两个请求压根就没请求参数,所以上面说请求参数的我全都忽略了。 是压力并发问题,这接口不是查数据库,所以比较特殊
amlee
2023-09-18 16:22:17 +08:00
哈哈,node 里面的东西默认都是异步非阻塞,随便搞个啥东西并发就出来了。

估计你们后端水,后端自己调一下接口,没问题就放那了,压根没考虑并发的事
M003
2023-09-18 16:26:50 +08:00
@unt 排除参数问题, 可能是执行顺序问题. 你可以在最后 console.log 中,打印出接口地址. 你的代码是并行执行了 A 和 B, 如果 B 先执行完,会先打印出来, 现在要看看是 B 先执行完,还是 A 先执行完.

====

如果 B 先执行完,先返回数据,并打印出来. 也不是问题. 因为就是这么设计的. 你可以用 async/await 来处理执行顺序.

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/974746

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX