data:image/s3,"s3://crabby-images/ae27d/ae27da0714109c579e60215c84b8edcc8f480380" alt=""
文章里面提到了2个问题,
- no state tracking
- do not support complex customized business logic
data:image/s3,"s3://crabby-images/335f2/335f2fa722a4ea20b92b7b0a76e035f0bc04f46c" alt=""
它们通过updateStateBykey(update_func)/mapWithState(update_func)
来自定义该update过程。即,
- Attach expire date/time when events are first seen & state is initialized
- drop the state if it expires
- apply business logic to new events/current state
data:image/s3,"s3://crabby-images/f78c6/f78c6d05ee92848b97d9544d67b0a0c26f73a10c" alt=""
data:image/s3,"s3://crabby-images/c376b/c376bd3221b5d04c033251032df4a39deee57776" alt=""
我借用了该ppt的思路,试着回答了stackoverflow上面的一个类似提问,但是我自己没有亲身实现出来,只是觉得可能这是一个思路。在每个state initialization的时候初始化一些状态(timeout,control flag等),然后判断这个stages的去留。
网友评论