
有一个函数 send_log() 负责向后端发送前端日志,由于这个 send_log() 会被其他不同的函数调用,这个调用行为又想限制在一定的频率范围之内(避免频繁请求后端服务器,造成无谓的压力)。
有什么方式,可以限制这个 send_log() 被调用的频率吗(比如每分钟最多 1 次这样)。
function send_log() { // send data to server } 1 murmur 2020-05-05 19:11:18 +08:00 搜索 throttle |
2 murmur 2020-05-05 19:12:13 +08:00 其实这个最好是建议 debounce,把日志收起来,日志可以考虑编个码 gz 一下啥的,随便扔日志是个好做法么,或者给日志分 debug info error 这样的级别 |
3 lithbitren 2020-05-05 19:38:34 +08:00 初始一个 bool 变量为 true,只有变量为 true 才能调用目标函数,每次调用完函数后,bool 变量变成 false,执行 settimeout 让其变成 true 。 |
4 Orenoid 2020-05-05 19:40:08 +08:00 装饰器+闭包应该就能实现吧 |
5 xg4 2020-05-05 19:40:18 +08:00 throttle 或者 debounce 会丢失一部分日志 可以先把日志放在本地,每分钟发送一次数据,发送成功之后清空数据 |
7 hanxiaomeng 2020-05-05 19:48:32 +08:00 sleep(60) |
8 JackWolf001 2020-05-05 19:50:01 +08:00 节流吧 |
9 foam 2020-05-05 19:50:20 +08:00 via Android 业务层区分日志重要程度,不希望丢的实时发,可以丢的累积发。 |
10 zhennann 2020-05-05 21:58:49 +08:00 如果是考虑分布式,可用 bottleneck |
11 cst4you 2020-05-05 22:30:45 +08:00 log 可以先存起来, 然后到了次数一次发送 |
12 christin 2020-05-06 00:47:28 +08:00 via iPhone if ( flag>n) break; flag++ |
13 tairan2006 2020-05-06 00:54:42 +08:00 via Android 5 楼正解…或者别限制了,后端塞 kafka 里 |
14 windychen0 2020-05-06 10:04:52 +08:00 let flag = true; function send_log() { if(flag ){ flag = false; // send data to server // function callback(){setTimeout(()=>{flag = true},1000 * 60)} }else{ return false } } |
15 zjm947373 2020-05-06 10:17:46 +08:00 |
16 theohateonion 2020-05-06 14:44:46 +08:00 function send_log() { return throttle(old_send_log, 6000) } 不考虑丢 log 的话就这样就行了 |
17 libook 2020-05-09 18:08:41 +08:00 函数不直接发送数据,而是把数据存入本地的队列,另一个 setInterval 每隔一段时间把队列里的数据发到服务器,同时清空队列。 其实我觉得后端直接塞消息队列里是可靠性更好的方式。 |