- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个使用 Spring 框架用 Java 编写的 Web 应用程序。我想存储用户 Activity ,例如页面访问、操作、交互等。我读到,通常这是通过为每个跟踪方面创建一个表来完成的。我想知道是否有更好的方法使用 Spring 框架来做到这一点,比如拦截所有请求并触发一些操作。您建议使用哪种技术来存储所有这些信息?我知道我正在使用 MySql 数据库,通过 JPA 与其交互。但是,由于我对这类事情真的很陌生,所以我不知道是否应该使用 NoSql 数据库还是继续使用现有的 MySql 数据库。这个奇迹来自这样的想法:这种数据流将比来自更传统操作(例如登录、创建、删除等)的正常数据流大得多。希望自己能解释清楚……如果不告诉我,我会尝试添加更多细节。
[编辑1]
网络应用程序是一种电子商务。到目前为止,它还没有那么多用户,但它会(以数千为单位)。
用户跟踪的目标只是对他们进行分析,以便为他们提供更好、更定制的服务。例如,如果看到用户正在查看某个特定类别的许多项目,我可以向他展示更多此类项目。
我不太关心性能,我的意思是,它不必那么快。
我知道我只有一个数据库,所有内容都存储在其中。我不知道用这种数据流为其充电是否会降低其性能。
应用程序在 AWS ElasticBeanstalk 上运行,数据库在 AWS RDS 上。
最佳答案
总的来说,这是一个非常广泛的主题。
我想到以下考虑因素:
每段时间有多少请求传递到微服务?如果用户数量较少(即数据库中的记录数量),那么可以使用 MySQL 方法,表不会很大。但请注意,有时无论如何都应该清洁
延迟重要吗?有时必须非常快速地处理请求,向数据库添加跃点来保存用户首选项可能会出现问题
您想如何使用此类信息?您是否打算使用仪表板(在这种情况下,Micrometer + Prometheus/InfluxDB 和 Grafana 可以是一个很好的解决方案)。您是否计划实际按照请求数量向用户收费,并能够将每月账单以 PDF 格式发送到他们的电子邮件或提供对此类信息的 Web 访问(例如 AWS 所做的)?
速率限制器怎么样?您是否打算拒绝某些频繁且来自同一用户的请求?
有多少实例会“添加”此类信息?如果您有数千个微服务现在必须写入 MySQL,该怎么办 - 它可能无法承受这样的负载(除了其设置的常规负载之外)?
解决方案的范围可能会有所不同。您可以在内存中对每个用户的请求进行批处理,并将消息发送到 Kafka 中,然后使用 kafka 流对其进行聚合。通过这种方法,您将最大限度地减少添加处理对现有解决方案的影响,并部署一些其他服务来处理如此大量的数据。
另一个选项:也许您可以创建一个异步填充的日志文件并将信息存储在那里。然后您可能想要添加一些“代理”/side-car 容器(例如logstash)并将数据流式传输到某些存储中。另一个可能与该领域相关的项目是 Apache Flume,它允许您构建管道。
对于计费,您可能会使用专门的系统,AFAIK spring 没有这样的东西,通常这些是您可以集成的现成产品。
对于速率限制,您可以考虑:Resilience4j 或使用 redis 解决它
关于java - 跟踪 Spring Web 应用程序上的用户 Activity ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59158731/
我对 Android 很陌生,如果问题重复,请避免并发送链接。有三个 Activity A、B 和 C。 Activity A 获取一个用户名,我想在 Activity C 中显示该用户名,但我想先运
我正在尝试制作记事本应用程序,因此每次打开新笔记时,布局都会相同。另外, Activity 的数量(新注释)不应定义得尽可能多 最佳答案 如果 Activity 始终相同,您可能应该创建一个适配器,允
我有 3 个 Activity 。 主窗口 5 个按钮 在按钮的主窗口中按下此窗口打开(将其称为父窗口) 在父窗口按钮上按下此窗口打开调用它作为结束子窗口。 现在从子窗口我从父窗口获取值如下:
我遇到了一个 Activity backstack 问题。假设我的后台有 5 个 Activity :比如 Activity A、 Activity B、 Activity C、 Activity D
我正在寻找必须具有以下附加特征的 JMS 提供程序: 采用多代理,所有代理都必须处于事件状态(无单点故障) 仅在两台机器上进行扩展就足以满足我们的需求 能够保证订购(如果 1 个生产者 + 1 个消费
假设,我有一个由 TabHost 组成的选项卡 Activity 。 TabHost 包含 2 个选项卡,每两个选项卡都有一个 Activity 组。每个 Activity 组包含一项 Activit
我正在开发一个应用程序,我需要根据某些操作导航到特定 Activity 。这是一张图片 我的第一个 Activity 是 ReadingActivity。基于某些操作,用户将被带到 NewProjec
我创建了一个与服务器异步通信的应用程序。当应用程序发出服务器请求时,将创建一个带有“正在加载”通知的新对话框( Activity )。主要 Activity 实现了处理服务器响应的方法,我想在主要 A
我想在我的所有应用程序 Activity 中显示相同的选项菜单。我创建了一个实现菜单的通用 Activity ,并且我所有的进一步 Activity 都扩展了它。 问题:当我需要扩展其他特定 Acti
我有四个 Activity ,即 java 文件 - Activity1.java、activity2.java、activity3.java、activity4.java 和 xml 文件 - Ac
我有两个 Activity 。我想将数据从第二个 Activity 发送到上一个 Activity 。第一个 Activity 有自定义 ListView 和 bean 类。当我点击第二个 Activ
根 Activity 是堆栈中当前的第一个 Activity 还是 list 中指定为启动 Activity 的 Activity ? 支持应用程序 P 在启动时启动 Activity A。然后 A
你好 我想知道您在绘制 Activity 图选择“Activity ”时考虑了哪些关键点? 您如何从要建模的问题中选择 Activity ? 谢谢 最佳答案 Activity 图用于对正在开发的系统和
如何从主 Activity 启动 Activity 并在子 Activity 返回主 Activity 中退出操作后返回主 Activity ? 我已将子 Activity 作为启动器 Intent
我的工作流程如下: 登录 Activity -> ActivityB -> ActivityC -> ActivityD 我想将数据从LoginActivity传递到ActivityD,但不直接传递到
我之前曾尝试获得此问题的答案,但找不到可以解决我的问题的答案。我正在制作保存圆盘高尔夫球分数的应用程序。我的 MainActivity 有 4 个按钮。新比赛、恢复比赛、类(class)和球员。 At
我有一个 tts 非 UI 类和 Activity 类。现在在 Activity 类中,我有一个按钮,用户可以从中选择男声或女声,具体取决于我想要将字符串传递给 tts 类的选择,然后一次tts 类根
问题有点复杂,首先, Activity A 和 Activity B 的 list 中都有 android:noHistory = true 。我有一个自定义 serialized 类,假设 MyCl
在我的应用程序中,我有两个 Activity (AuthenticationActivity 和 MainActivity),每个 Activity 都有一个导航图和大量 fragment 。我创建了
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: How can i use compose email activity in tabView? 我想在选项
我是一名优秀的程序员,十分优秀!