SkyWalking是一款综合性的可观察性分析服务平台和性能智能管理系统,提供分布式系统追踪、服务网格遥测分析、指标汇聚以及数据可视化的一体化解决方案。它支持多种编程语言,包括Java、.Net Core、PHP、NodeJS、Golang、LUA和C,同时兼容Istio Envoy服务网格。以下是SkyWalking的主要功能:
服务分析:对服务实例进行详细分析,包括节点指标值。
直接原因分析:在运行时对代码进行分析,以定位问题根源。
系统架构图分析:提供服务的系统架构图,便于理解服务之间的依赖关系。
依赖关系分析:分析服务、服务实例和节点之间的相互依赖。
性能监控:检测慢速服务和节点,并进行性能优化。
分布式追踪:实现分布式系统的追踪,包括追踪的前后文传播。
数据库查询分析:浏览和监控数据库查询,包括慢查询语句(如SQL语句)。
警报系统:提供实时警报功能,以便及时发现潜在问题。
浏览器性能监控:监控浏览器的性能,确保用户获得良好的体验。
SkyWalking具有以下应用特点:
多语言支持:适用于Java、.Net Core、NodeJS、PHP和Python等多种编程语言。
去代理技术:无需修改应用程序代码,即可实现性能监控。
LUA代理支持:特别是Nginx、OpenResty的LUA代理。
服务网格可观察性:支持服务网格的可观察性,适用于切换阀遥测。
性能提升:推荐使用Envoy浏览器日志服务(ALS)以获得更强大的性能,该功能首次在KubeCon 2019上推出。
衡量系统支持:支持Prometheus、Spring Sleuth(游标卡尺)等衡量系统。
多种数据格式支持:支持Zipkin v1/v2和Jaeger gRPC格式,具有有限的拓扑结构和衡量分析功能(试验性)。
SkyWalking的使用非常简便,以下是一些基本步骤:
安装SkyWalking:从官方网站下载并安装SkyWalking。
配置SkyWalking:根据需要配置SkyWalking,包括数据源、代理等。
部署应用程序:将应用程序部署到生产环境中。
监控应用程序:通过SkyWalking监控应用程序的性能和状态。
分析问题:利用SkyWalking提供的分析工具,定位和解决问题。