我正在编写一个基于 Java 的 Web 服务器监控应用程序,它应该能够检测用户何时在特定时间范围内以特定顺序浏览给定的一组页面。为此,我正在使用Esper 库。我对查询的最佳表述有一些疑问。
我首先声明了一个“访问”对象,用于存储到达我的 Web 服务器的 HTTP 请求的所有信息。每当向服务器发出新请求时,都会实例化一个新的 Access 对象并将其作为事件发送到 EPL 处理核心。
假设我想跟踪浏览页面 A、页面 B 和页面 C 的所有用户。处理这种情况的最佳方法是什么?我是否需要执行多个连接,每个转换一个,如下例所示?
select * from Access(request='GET /A HTTP/1.1').win:time(30 sec) as a1,
Access(request='GET /B HTTP/1.1').win:time(30 sec) as a2,
Access(request='GET /C HTTP/1.1').win:time(30 sec) as a3
where a1.IP=a2.IP AND a2.IP=a3.IP