Skip to content

flomesh-io/pipy

Folders and files

NameName
Last commit message
Last commit date
Mar 15, 2025
Jan 11, 2022
Aug 19, 2024
Oct 14, 2024
May 11, 2024
Dec 30, 2023
Jul 4, 2024
Feb 10, 2025
Apr 9, 2025
May 23, 2024
Dec 22, 2024
Jan 9, 2024
May 25, 2022
Apr 11, 2023
Dec 18, 2024
Feb 8, 2022
Feb 8, 2022
Feb 11, 2021
Feb 21, 2025
Dec 22, 2024
Feb 11, 2021
Feb 21, 2024
May 27, 2024
Mar 9, 2024
Mar 9, 2024
Mar 9, 2024
Feb 14, 2022
Feb 11, 2021
May 8, 2024
Feb 21, 2025
Mar 9, 2024
Oct 15, 2021
Aug 23, 2022
Oct 27, 2023
Oct 15, 2021
Sep 24, 2024
May 18, 2024
Feb 21, 2025
Dec 2, 2024
May 24, 2023

Repository files navigation

Pipy Logo

中文 | 日本語

Pipy

Pipy is a programmable proxy for the cloud, edge and IoT. It's written in C++, which makes it extremely lightweight and fast. It's also fully programmable by using PipyJS, a tailored version from the standard JavaScript language.

Why Pipy?

Versatile

Although Pipy is mostly used as a high-performance reverse proxy, the real power of Pipy relies on providing you a range of basic pluggable building blocks, aka. "filters", and not imposing any restrictions on how you combine them. It's entirely up to you. We've seen people using Pipy to convert protocols, record network traffic, sign/verify messages, trigger serverless functions, health-check servers, and more.

Fast

Pipy is written in C++. It leverages asynchronous network I/O. Allocated resources are pooled and reused. Data is transferred internally by pointers whenever possible. It's fast in every way.

Tiny

A build of Pipy with no built-in GUI frontend resources gives you an executable merely around 10MB with zero external dependencies. You'll experience the fastest download and startup times with Pipy.

Programmable

At the core, Pipy is a script engine running PipyJS, a tailored version from ECMA standard JavaScript. By speaking the planet's most widely used programming language, Pipy gives you unparalleled freedom over what you have in other products based on YAML configuration files and the like.

Open

Pipy is more open than open source. It doesn’t try to hide details in a black box. You'll always know what you are doing. It might sound a bit daunting but fear not, it doesn’t require a rocket scientist to understand how the different parts work together. In fact, you’ll only have more fun as you have complete control over everything.

Quick Start

Build

The following prerequisites are required to build Pipy:

  • Clang 5.0+
  • CMake 3.10+
  • Node.js v12+ (only if the builtin Admin UI is enabled)

Run the build script to start building:

./build.sh

The final product can be found at bin/pipy.

Run

Run bin/pipy with zero command line options, Pipy will start in repo-mode listening on the default port 6060.

$ bin/pipy

[INF] [admin] Starting admin service...
[INF] [listener] Listening on port 6060 at ::

Open the browser of your choice, point to http://localhost:6060. You will now see the Admin UI where you can start exploring the documentation and playing around with the tutorial codebases.

Documentation

Compatibility

Pipy is being constantly tested on these platforms:

  • RHEL/CentOS
  • Fedora
  • Ubuntu
  • Debian
  • macOS
  • FreeBSD
  • OpenBSD
  • OpenEuler
  • OpenWrt
  • Deepin
  • Kylin

Pipy runs on the following architectures:

  • X86/64
  • ARM64
  • LoongArch
  • Hygon

Copyright & License

Please refer to COPYRIGHT and LICENSE.

Contact