Skip to content

PSH(爬山虎) 用于采集云服务运行时软硬件性能数据。

License

LGPL-3.0, GPL-3.0 licenses found

Licenses found

LGPL-3.0
COPYING.LESSER
GPL-3.0
COPYING
Notifications You must be signed in to change notification settings

OptimatistOpenSource/psh

Repository files navigation

Performance Savior Home (PSH)

image License: LGPL v3 License: GPL v3 image image

Performance Savior Home (PSH) collects software and hardware performance data when the cloud service is running.

PSH's layout has WASM sitting at the top tier, while the foundation is made up of operators responsible for scooping up performance stats, utilizing tech like eBPF and the perf_event_open interface. This setup brings both a secure environment and user-friendliness to the table, making it a breeze to work with while keeping things locked down tight.

It protects both the performance acquisition and computation algorithms of performance engineers and the sensitive data of companies applying PSH.

Overview

Performance Savior Home (PSH) is a cutting-edge performance monitoring and analytics solution designed for cloud services. It securely harvests software and hardware performance metrics while your cloud applications are in operation, safeguarding both the intricate performance tuning algorithms of engineers and the sensitive corporate data of its adopters.

PSH achieves this through a dual-layered architecture leveraging WebAssembly (WASM) at the top and an array of robust operators at its foundation.

PSH encapsulates low-level performance monitoring capabilities within WASM, streamlining the development of performance collection tools with simplicity and grace. Built with Rust, PSH inherently boasts memory safety, further enhancing its robustness and reliability in high-stakes environments.

PSH's vision is to reduce the duplication of construction within the enterprise and to collect performance data in a reliable, low-overhead, and elegant way.

Key Features

  • Secure Sandboxing: Leverages WASM to create a secure sandbox for performance data acquisition and processing algorithms, ensuring isolation and preventing unauthorized access. Permission control ensures that sensitive data is not collected, while WASM's performance data processing algorithms are easier to protect.
  • Low-Level Insights: PSH harnesses eBPF and perf_event_open to gather detailed, real-time performance metrics from both software and hardware levels, encompassing a wide spectrum of metrics across various system layers. The result is a 360-degree view of your application's performance footprint.
  • Cross-Platform Compatibility: PSH is designed from the ground up with performance data acquisition and analysis for the ARM platform in mind, and is compatible with both x86_64 and RISC-V architectures.
  • Highly Scalable Architecture: PSH is designed for effortless scalability, allowing users to easily extend both the algorithms executed within the WASM environment and the range of performance events captured by operators. This flexibility ensures that as technology stacks evolve or new monitoring requirements arise, PSH can be adapted swiftly to meet those needs, future-proofing your performance monitoring strategy.
  • Minimal Performance Overhead: Preliminary testing indicates that PSH's data collection incurs a negligible operational overhead, with current measurements suggesting an impact of merely around 3%. This ensures that while comprehensive monitoring is in place, the system's primary functions remain unaffected, preserving optimal performance and responsiveness.

Config

The default config is located in /etc/psh/config.toml.

See config template

Contribution Guide

We welcome contributions! Please refer to the following guide for details on how to get involved.

Before submitting a pull request (PR) to PSH, it's crucial to perform a self-check to ensure the quality and adherence to coding standards. Follow these steps for an effective self-check:

  • Run Clippy: Execute cargo clippy, a lint tool for Rust designed to catch common mistakes and enhance the overall quality of your Rust code.

  • Format Code: Utilize cargo fmt to format your Rust code, ensuring consistency in code formatting across the project.

  • Security Audit: Employ cargo audit to enhance the security of your Rust code. This command reviews your dependencies for any security vulnerabilities reported to the RustSec Advisory Database. If you haven't installed cargo-audit yet, you can do so by running cargo install cargo-audit.

Failing to adhere to these self-check steps might result in your PR not being reviewed promptly. Without completing these checks, the chances of finding a reviewer willing to assess your PR may be reduced. Therefore, it is essential to diligently follow the outlined steps to increase the likelihood of a successful and timely review for your pull request.

Acknowledgments

The development of the Performance Savior Home (PSH) project can be attributed to the collaborative efforts and shared vision of Optimatsit Technology Co., Ltd and Zhejiang University's SPAIL – System Performance Analytics Intelligence Lab.

License

Performance Savior Home is distributed under the terms of the LGPL3.0/GPL3.0 License.

About

PSH(爬山虎) 用于采集云服务运行时软硬件性能数据。

Resources

License

LGPL-3.0, GPL-3.0 licenses found

Licenses found

LGPL-3.0
COPYING.LESSER
GPL-3.0
COPYING

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages