有时只需要知道数据库客户端在数据库中执行的操作。这些操作可能是:
创新互联坚实的技术研发基础赢得了行业内的良好口碑,公司成立十余年来,为上千多家企业提供过网站建设、软件开发、搜索引擎优化技术、互联网大数据整合营销服务,多年的技术服务成功经验、众多的客户使我们能懂得更多,做得更好。"让您的网站跑起来"是我们一直追求的目标!
数据库客户端是指直接与数据库对话的任何事务:它可能是在应用服务器中运行的中间层、报表编写器、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
网站名称:应用程序数据库监控的中间路线
文章分享:http://www.shufengxianlan.com/qtweb/news15/496215.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联