应用程序数据库监控的中间路线

有时只需要知道数据库客户端在数据库中执行的操作。这些操作可能是:

  • 调试应用程序并尝试确定其数据库交互是否存在问题。
  • 分析无服务器功能的性能以确定某些查询是否耗时过长。
  • 测试应用程序并确保其数据库交互符合预期。
  • 审核系统以确保它不会在数据库中做任何有趣的事情。
  • 对应用程序进行逆向工程。

数据库客户端是指直接与数据库对话的任何事务:它可能是在应用服务器中运行的中间层、报表编写器、Excel中的电子表格、用PHP编写的Web应用程序、云中的lambda函数,等等。

不管是什么原因,了解客户的数据库交互对于理解客户的行为非常有帮助。

一般来说,有两种常见的方法:基于服务器的和基于客户端的。还有第三种不太常用的选项:监控数据库连接。这是中间路线:它既不关注数据库服务器,也不关注数据库客户端,而是关注它们之间的连接。

以下了解常见解决方案的优缺点,并看看这第三种方法带来了什么。

服务器端监控

大多数企业数据库都有内置的监控功能。如果用户对数据库具有管理员级别的访问权限,那么这种类型的监控可能是一个很好的解决方案,但如果有多个客户端访问数据库,它可能并不总是易于使用。

主要从数据库的角度观察世界的人员更喜欢服务器端监控,因为这种类型的监控使企业可以完全访问数据库服务器中发生的所有事情:CPU和内存、网络和磁盘使用情况、死锁等。

这种解决方案的主要缺点是:

  • 需要对数据库进行特权访问。
  • 对于云计算数据库,经常被云计算供应商提供的任何东西所困扰。
  • 可以看到来自所有客户端的所有请求,这可能会让人不知所措,并且可能成为一个安全问题。

客户端监控

专注于数据库客户端的解决方案要求用户在客户端中安装代理。这可以采用库或模块的形式,或者可能是拦截所有数据库调用的替代驱动程序库。

客户端监控是更关心数据库客户端观点的人员的首选,例如应用程序开发人员和测试人员。它允许用户专注于一个特定的客户端,并准确查看该客户端在做什么、它发送什么请求、它得到什么响应等等。大多数解决方案还不仅仅是监控数据库交互。

但是,这种类型的监控也有缺点:

  • 它要求用户对客户端进行一些更改,这可能很困难。
  • 如果用户不控制客户端(例如第三方应用程序、不再维护等),它甚至可能不是一个选项。
  • 如果监控解决方案不支持客户的语言或平台,这甚至不是一个选项。
  • 如果用户需要监控多个客户端,则可能会很不方便,因为需要在每个客户端中安装代理。

基于代理的监控:中间道路

还有第三种选择:使用数据库代理监视客户端和服务器之间的连接。

客户端并不是直接连接到数据库,而是连接到代理,代理转发客户端和服务器之间的所有请求和响应,并将这些活动报告给监控服务。

代理在有线协议级别工作:它的行为与数据库服务器完全相同,因此客户端无法知道它实际上并未直接与数据库服务器通信。

这种方法的主要优点是它不需要对数据库客户端或数据库服务器进行任何更改,因此可以在任何环境中以任何语言为任何客户端工作。唯一的要求是客户端应该连接到代理而不是数据库,这通常可以通过更改配置参数、数据源定义或有时是网络设置来完成。

这在处理不受用户控制的第三方应用程序或不再维护的旧应用程序时特别有用。在这些情况下,对应用程序进行任何更改通常是一个令人生畏的前景。与其相反,指导客户端连接到代理而不是数据库通常是微不足道的。

对于使用监控系统不支持的语言编写的客户端,基于代理的监控也是唯一实用的解决方案。

例如,New Relic公司拥有适用于C、Java、JavaScript、Go、Ruby、.NET、PHP和Python的应用程序性能监控库。如果用户的客户端使用不兼容的语言编写,将无法使用New Relic的代理。

应用程序开发人员和测试人员可以实施基于代理的监控,而无需数据库所有者的协作。一个代理可用于多个客户端,这在用户需要监控一套应用程序时很有帮助。

(1)代理方法的优点

  • 不需要更改数据库客户端或数据库服务器。
  • 适用于现场和云计算数据库。
  • 支持所有平台和语言,因为它在有线协议级别工作。
  • 可以同时应用于多个客户端。

(2)代理方法的缺点

  • 需要代理服务器。
  • 由于流量通过代理,响应时间略有增加。

哪种方法更加适合?

如果主要关心数据库,例如作为系统管理员(DBA),那么基于服务器的监控很可能是适合其的解决方案——这不足为奇。

如果用户是应用程序开发人员或测试人员,或者只需要知道数据库客户端在数据库中做什么,那么可以在基于客户端的监控和基于代理的监控之间进行选择。

如果用户在客户端中安装代理是合理的,那么这是一个很好的方法。将深入了解客户的行为,并且有许多产品可供选择(例如谷歌“APM数据库”)。

如果在用户的客户中安装代理是一个没有吸引力的前景,或者如果客户使用不受支持的平台或语言,那么基于代理的方法可能是用户的最佳选择,甚至可能是其唯一的选择。

原文标题:​​Application Database Monitoring: The Middle Way​​,作者:Max Tardiveau

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/238705.html<

(0)
运维的头像运维
上一篇2025-04-23 01:50
下一篇 2025-04-23 01:51

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注