π¦ ramaβ’ (γ©γ) is a modular service framework for the π¦ Rust language to move and transform your network packets.
This framework is designed for developers who need fine-grained, programmable control over how packets are handled across the network stack. Whether you're intercepting traffic for security analysis, emulating clients with custom user agents, hijacking connections for advanced testing, or building high-performance proxies, Rama provides a clean and composable Rust-native foundation.
With support for modular packet pipelines, deep protocol introspection, and advanced socket manipulationβincluding features like transparent proxying and HAProxy protocol supportβRama makes it easy to prototype, deploy, and scale complex network behavior with safety and speed.
It's not just a toolkitβit's a mindset shift for how to design and operate dynamic, programmable network services
Important
The reasons behind the creation of Rama can be read in the "Why Rama" chapter.
Rama is async-first using Tokio as its only Async Runtime.
Please refer to the examples found in the /examples
dir
to get inspired on how you can use it for your purposes.
Warning
This framework might not be for everyone. Particularly if you're building a typical simple web server or just need an HTTP client for making standard requests, you might be better served by other crates. While we at Plabayo use Rama for most of our web needs (clients, servers, and proxies), it is not the most straightforward framework to use and doesn't yet have the large community backing that other crates enjoy.
- Consider using Axum if you're building a typical HTTP web server.
It comes with many community crates to help with virtually anything you can think of. However, using
Axum means giving up full control over your web stack, which could become limiting when you need something
that isn't typical or standards-enforced.
- π Or read more about web servers using Rama at https://ramaproxy.org/book/web_servers
- Consider using Reqwest if you only need to make typical
HTTP requests without fine-grained control over the requests sent or responses received,
and where TLS is merely a detail indicated by the
https
protocol (where 's' stands for secure).- π Or read more about HTTP clients using Rama at https://ramaproxy.org/book/http_clients
If you're building proxies and feel that Rama isn't the right approach for you, you might want to check out the alternatives mentioned at the bottom of this README.
Rama emphasizes empowerment and modularity. It helps you build proxies, servers, and clients without getting in your way or limiting your mission where Rama might fall short. A web stack built with Rama can always be customized to your needs, even if a particular part or layer is specific to your purpose.
It's worth noting that Rama is built upon the shoulders of giants. Please refer to the acknowledgements for more information.
When necessary, we've forked other crates due to incompatibilities in needs or scope. While this creates additional work for us, we willingly do so when it aligns with our mission of empowering Rama users, including ourselves. You can find more information about these forks in the FORK.md document. We strive to preserve the code layout of forked modules to maintain synchronization with upstream and push patches upstream where possible.
Note
If your organization relies on Rama (γ©γ) for its operations, we invite you to consider becoming a sponsor π. By supporting our project, you'll help ensure its continued development and success. To learn more about sponsorship opportunities, please refer to the "Sponsors" section below or contact us directly at [email protected].
Rama comes with π batteries included, giving you the full freedom to build the middleware and services you want, without having to repeat the "common":
category | support list |
---|---|
β transports | β tcp βΈ± β udp βΈ± β Unix (UDS) βΈ± β middleware |
β http | β auto βΈ± β http/1.1 βΈ± β h2 βΈ± ποΈ h3 (2) βΈ± β middleware |
β web server | β fs βΈ± β router βΈ± β dyn router βΈ± β static router βΈ± β handler extractors βΈ± β k8s healthcheck |
β http client | β easy client βΈ± β high level API βΈ± β BoringSSL Connect βΈ± β Rustls Connect βΈ± β HTTP Proxy Connect βΈ± β Socks5 Proxy Connect βΈ± β Chromium Http (3) |
β tls | β Rustls βΈ± β BoringSSL βΈ± β NSS (3) |
β dns | β DNS Resolver |
β proxy protocols | β PROXY protocol βΈ± β http proxy βΈ± β https proxy βΈ± β socks5(h) proxy |
β web protocols | β SSE βΈ± β WS βΈ± β Web Transport (3) βΈ± β gRPC (3) |
β async-method trait services | β Service βΈ± β Layer βΈ± β extensions βΈ± β dyn dispatch βΈ± β middleware |
β telemetry | β tracing βΈ± β opentelemetry βΈ± β http metrics βΈ± β transport metrics |
β Diagnostics | β curl export βΈ± β HAR |
β upstream proxies | β MemoryProxyDB βΈ± β Username Config βΈ± β Proxy Filters |
β User Agent (UA) | β Http Emulation βΈ± β Tls Emulation βΈ± β UA Parsing |
β Fingerprinting | β Ja3 βΈ± β Ja4 βΈ± β Ja4H βΈ± ποΈ Akamai passive h2 (1) βΈ± β Peetprint (tls) |
β utilities | β error handling βΈ± β graceful shutdown βΈ± β Connection Pooling βΈ± β Tower Adapter βΈ± ποΈ IP2Loc (1) |
ποΈ Graphical Interface | ποΈ traffic logger (3) βΈ± ποΈ TUI implementation (3) βΈ± β traffic intercept (3) βΈ± β traffic replay (3) |
β binary | β prebuilt binaries βΈ± ποΈ proxy config (3) βΈ± β http client βΈ± β WASM Plugins (3) |
ποΈ data scraping | ποΈ Html Processor (3) βΈ± β Json Processor (3) |
β browser | β JS Engine (3) βΈ± β Web API Emulation (3) |
ποΈ Footnotes
- (1) Part of
v0.3.0
milestone (ETA: 2025 Q4)- (2) Part of
v0.4.0
milestone (ETA: 2025 Q4)- (3) No immediate plans, but on our radar. Please open an issue to request this feature if you have an immediate need for it. Please add sufficient motivation/reasoning and consider becoming a sponsor to help accelerate its priority.
The primary focus of Rama is to aid you in your development of proxies:
- π¦ Reverse proxies;
- π TLS Termination proxies;
- π HTTP(S) proxies;
- 𧦠SOCKS5 proxies;
- π SNI proxies;
- π MITM proxies;
- π΅οΈββοΈ Distortion proxies.
- π§ HaProxy (PROXY protocol).
Tip
Check out the "Intro to Proxies" chapters in the Rama book to learn more about the different kind of proxies. It might help in case you are new to developing proxies.
The Distortion proxies support
comes with User Agent (UA) emulation capabilities. The emulations are made possible by patterns
and data extracted using rama-fp
. The service is publicly exposed at
https://fp.ramaproxy.org, made possible by our sponsor host https://fly.io/.
π https://echo.ramaproxy.org/ is another service publicly exposed. In contrast to the Fingerprinting Service it is aimed at developers and allows you to send any http request you wish in order to get an insight on the Tls Info and Http Request Info the server receives from you when making that request.
curl -XPOST 'https://echo.ramaproxy.org/foo?bar=baz' \ -H 'x-magic: 42' --data 'whatever forever'Feel free to make use of while crafting distorted http requests, but please do so with moderation. In case you have ideas on how to improve the service, please let us know by opening an issue.
Using the
rama
binary you can also run both theecho
andfp
service yourself, locally or as an external facing web service.Please run your own echo service instead of using
echo.ramaproxy.org
in case you are planning to send a lot of traffic to the echo service.
BrowserStack sponsors Rama by providing automated cross-platform browser testing on real devices, which uses the public fingerprinting service to aid in automated fingerprint collection on both the Http and Tls layers. By design we do not consider Tcp and Udp fingerprinting.
Next to proxies, Rama can also be used to develop Web Services and Http Clients.
- Learn more by reading the Rama book at https://ramaproxy.org/book;
- or checkout the framework Rust docs at https://docs.rs/rama;
- edge docs (for main branch) can be found at https://ramaproxy.org/docs/rama.
π Rama's full documentation, references and background material can be found in the form of the "rama book" at https://ramaproxy.org/book.
π¬ Come join us at Discord on the #rama
public channel. To ask questions, discuss ideas and ask how rama may be useful for you.
Note
Rama also has a public channel on the official Discord of the tokio project. Feel free to join us there instead or as well: https://discord.com/channels/500028886025895936/1349098858831024209
The rama
binary allows you to use a lot of what rama
has to offer without
having to code yourself. It comes with a working http client for CLI, which emulates
User-Agents and has other utilities. And it also comes with IP/Echo services.
It also allows you to run a rama
proxy, configured to your needs.
Learn more about the rama
binary and how to install it at https://ramaproxy.org/book/deploy/rama-cli.
Important
Learn more about the rama CLI code signing- and privacy policy at https://ramaproxy.org/book/deploy/rama-cli.html#code-signing. Applicable to MacOS and Windows platforms only.
π¦ Rama (γ©γ) is to be considered experimental software for the foreseeable future. In the meanwhile it is already used
in production by ourselves and others alike. This is great as it gives us new perspectives and data to further improve
and grow the framework. It does mean however that there are still several non-backward compatible releases that will follow 0.2
.
In the meanwhile the async ecosystem of Rust is also maturing, and edition 2024 is also to be expected as a 2024 end of year gift. It goes also without saying that we do not willy-nilly change designs or break on purpose. The core design is by now also well defined. But truth has to be said, there is still plenty to be improved and worked out. Production use and feedback from you and other users helps a lot with that. As such, if you use Rama do let us know feedback over Discord, email or a GitHub issue.
π If you are a company or enterprise that makes use of Rama, or even an individual user that makes use of Rama for commercial purposes. Please consider becoming a business/enterprise subscriber. It helps make the development cycle to remain sustainable, and is beneficial to you as well. As part of your benefits we are also available to assist you with migrations between breaking releases. For enterprise users we can even make time to develop those PR's in your integration codebases ourselves on your behalf. A win for everybody. πͺ
For now there are only the rama crates found in this repository, also referred to as "official" rama crates.
We welcome however community contributions not only in the form of contributions to this repository, but also have people write their own crates as extensions to the rama ecosystem. E.g. perhaps you wish to support an alternative http/tls backend.
In case you have ideas for new features or stacks please let us know first. Perhaps there is room for these within an official rama crate. In case it is considered out of scope you are free to make your own community rama crate. Please prefix all rama community crates with "rama-x", this way the crates are easy to find, and are sufficiently different from "official" rama crates".
Once you have such a crate published do let us know it, such that we can list them here.
The rama
crate can be used as the one and only dependency.
However, as you can also read in the "DIY" chapter of the book
at https://ramaproxy.org/book/diy.html#empowering, you are able
to pick and choose not only what specific parts of rama
you wish to use,
but also in fact what specific (sub) crates.
Here is a list of all rama
crates:
rama
: one crate to rule them allrama-error
: error utilities for rama and its usersrama-macros
: contains the procedural macros used byrama
rama-utils
: utilities crate for ramarama-ws
: WebSocket (WS) support for ramarama-core
: core crate containing the service, layer and context used by all otherrama
code, as well as some other core utilitiesrama-crypto
: rama crypto primitives and dependenciesrama-net
: rama network types and utilitiesrama-dns
: DNS support for ramarama-unix
: Unix (domain) socket support for ramarama-tcp
: TCP support for ramarama-udp
: UDP support for ramarama-tls-acme
: ACME support for ramarama-tls-boring
: Boring tls support for ramarama-tls-rustls
: Rustls support for ramarama-proxy
: proxy types and utilities for ramarama-socks5
: SOCKS5 support for ramarama-haproxy
: rama HaProxy supportrama-ua
: User-Agent (UA) support forrama
rama-http-types
: http types and utilitiesrama-http-headers
: types http headersrama-http
: rama http services, layers and utilitiesrama-http-backend
: default http backend forrama
rama-http-core
: http protocol implementation drivingrama-http-backend
rama-tower
: provide tower compatibility forrama
rama
crates that live in https://github.com/plabayo/rama-boring (forks of cloudflare/boring
):
rama-boring
: BoringSSL bindings for Ramarama-boring-sys
: FFI bindings to BoringSSL for Ramarama-boring-tokio
: an implementation of SSL streams for Tokio backed by BoringSSL in function of Rama
repositories in function of rama that aren't crates:
- https://github.com/plabayo/rama-boringssl: Fork of mirror of BoringSSL in function of rama-boring
- https://github.com/plabayo/homebrew-rama: Homebrew formula for the rama Cli tool
- /examples/tls_rustls_termination.rs: Spawns a mini handmade http server, as well as a TLS termination proxy, forwarding the plain text stream to the first. Tls is handled by rustls
- /examples/tls_boring_termination.rs: Spawns a mini handmade http server, as well as a TLS termination proxy, forwarding the plain text stream to the first. Tls is handled by boring
- /examples/mtls_tunnel_and_service.rs: Example of how to do mTls (manual Tls, where the client also needs a certificate) using rama, as well as how one might use this concept to provide a tunnel service build with these concepts;
- /examples/http_connect_proxy.rs: Spawns a minimal http proxy which accepts http/1.1 and h2 connections alike, and proxies them to the target host.
Developing proxies are the primary focus of Rama (γ©γ). It can however also be used to develop web services to serve web pages, Http API's and static content. This comes with many of the same benefits that you get when developing proxies using Rama:
- Use Async Method Traits;
- Reuse modular Tower-like middleware using extensions;
- Have the ability to be in full control of your web stack from Transport Layer (Tcp, Udp), through Tls and Http;
- If all you care about is the Http layer then that is fine to.
- Be able to trust that your incoming Application Http data has not been modified (e.g. Http header casing and order is preserved);
- Easily develop your service at a Request layer and High level functions alike, choices are yours and can be combined.
Examples of the kind of web services you might build with rama in function of your proxy service:
- a k8s health service (/examples/http_k8s_health.rs);
- a metric exposure service;
- a minimal api service (e.g. to expose device profiles or certificates);
- a graphical interface / control panel;
Tip
π Learn more about developing web services in the Rama book: https://ramaproxy.org/book/web_servers.html.
Datastar helps you build reactive web applications with the simplicity of server-side rendering and the power of a full-stack SPA framework.
Rama has built-in support for π Datastar. You can see it in action in Examples:
- /examples/http_sse_datastar_hello.rs: SSE Example, showcasing a very simple datastar example, which is supported by rama both on the client as well as the server side.
Rama rust docs:
- SSE support: https://ramaproxy.org/docs/rama/http/sse/datastar/index.html
- Extractor support (
ReadSignals
): https://ramaproxy.org/docs/rama/http/service/web/extract/datastar/index.html - Embedded JS Script: https://ramaproxy.org/docs/rama/http/service/web/response/struct.DatastarScript.html
Shuttle is a Rust-native cloud development platform that lets you deploy your app while also taking care of all of your infrastructure. Rama is one of a series of frameworks that is officially supported by Shuttle as part of their official SDK crates.
Learn more about what shuttle is and how to deploy services built with Rama on our Shuttle docs.
Here are some low level web service examples without fancy features:
- /examples/http_listener_hello.rs: is the most basic example on how to provide
a root service with no needs for endpoints or anything else (e.g. good enough for some use cases related
to health services or metrics exposures);
- /examples/http_health_check.rs is an even more minimal example of a health check service returning a 200 OK for any incoming request.
- /examples/http_service_hello.rs: is an example similar to the previous example but shows how you can also operate on the underlying transport (TCP) layer, prior to passing it to your http service;
There's also a premade webservice that can be used as the health service for your proxy k8s workloads:
- /examples/http_k8s_health.rs: built-in web service that can be used as a k8s health service for proxies deploying as a k8s deployment;
The following are examples that use the high level concepts of Request/State extractors and IntoResponse converters,
that you'll recognise from axum
, just as available for rama
services:
- /examples/http_key_value_store.rs:
a web service example showcasing how one might do a key value store web service using
Rama
; - /examples/http_web_service_dir_and_api.rs: a web service example showcasing how one can make a web service to serve a website which includes an XHR API;
- /examples/http_web_router.rs: a web service example showcasing demonstrating how to create a web router, which is excellent for the typical path-centric routing, and an approach you'll recognise from most other web frameworks out there.
For a production-like example of a web service you can also read the rama cli fp
cmd source code.
This is the webservice behind the Rama fingerprinting service, which is used by the maintainers of π¦ Rama (γ©γ) to generate
the UA emulation data for the Http and TLS layers. It is not meant to fingerprint humans or users. Instead it is meant to help
automated processes look like a human.
Tip
This example showcases how you can make use of the match_service
macro to create a Box
-free service router. Another example of this approach can be seen in the
http_service_match.rs example.
In The rama book you can read and learn that a big pillar of Rama's architecture is built on top of the Service concept. A Service
takes a Request
, and uses it to serve either a Response
or Error
. Such a Service
can produce the response "directly" (also called βοΈ Leaf services) or instead pass the request to an inner Service
which it wraps around (so called π Middlewares).
It's a powerful concept, originally introduced to Rust by the Tower ecosystem and allows you build complex stacks specialised to your needs in a modular and easy manner. Even cooler is that this works for both clients and servers alike.
Rama provides an EasyHttpWebClient
which sends your Http Request
over the network and returns the Response
if it receives and read one or an Error
otherwise. Combined with the many Layers (middleware) that Rama
provides and perhaps also some developed by you it is possible to create a powerful Http client suited to your needs.
As a π cherry on the cake you can import the HttpClientExt
trait in your Rust module to be able to use your Http Client Service
stack using a high level API to build and send requests with ease.
Tip
π‘ The full "high level" example can be found at /examples/http_high_level_client.rs.
use rama::http::service::client::HttpClientExt;
let client = (
TraceLayer::new_for_http(),
DecompressionLayer::new(),
AddAuthorizationLayer::basic("john", "123")
.as_sensitive(true)
.if_not_present(),
RetryLayer::new(
ManagedPolicy::default().with_backoff(ExponentialBackoff::default()),
),
).into_layer(EasyHttpWebClient::default());
#[derive(Debug, Deserialize)]
struct Info {
name: String,
example: String,
magic: u64,
}
let info: Info = client
.get("http://example.com/info")
.header("x-magic", "42")
.typed_header(Accept::json())
.send(Context::default())
.await
.unwrap()
.try_into_json()
.await
.unwrap();
rama
's default http implementation is forked from hyper
and adds very little
overhead. So rama
's performance is comparable to hyper
and frameworks that built on top of that.
Here's a list of external benchmarks:
- http server benchmark @ https://web-frameworks-benchmark.netlify.app/result
- http server + client benchmark @ https://sharkbench.dev/web
Please open an issue or Pull Request (PR) in case you are aware of any other benchmarks of interest in regards to http(s) servers, http(s) clients or proxies such as Man-In-The-Middle (MITM) proxies.
The rama crates avoid unsafe_code
, but do make use of it for some low level primitives (e.g. http core)
or indirectly because of bindgens to C (e.g. boring).
We also make use of cargo vet
to audit our supply chain.
Rama (γ©γ) is developed mostly on MacOS M-Series and Windows 11 x64 machines. Most organisations running rama in production do so on a variety of Linux systems. These are tier 1 platforms.
platform | tested | test platform |
---|---|---|
MacOS | β | MacOS 15 Apple Silicon: developer machine + GitHub Action |
Linux | β | AMD x64 developer machine with Ubuntu 25 + GitHub Action (Ubuntu 24.04) |
Windows | β | Windows 11 AMD x64 developer machine + GitHub Action (Windows latest (x64)) |
Please open a ticket in case you have compatibility issues for your setup/platform. Our goal is not to support all possible platforms in the world, but we do want to support as many as we reasonably can. Such platforms will only happen and continue to happen with community/ecosystem support.
Rama's MSRV is 1.88
.
Using GitHub Actions we also test if rama
on that version still works on
the stable and beta versions of rust as well.
Please refer to https://github.com/plabayo/rama/milestones to know what's on the roadmap. Is there something not on the roadmap for the next version that you would really like? Please create a feature request to request it and become a sponsor if you can.
Rama (0.2
) was featured in a π» Rustacean episode on the 19th of May 2024, and available to listen at https://rustacean-station.org/episode/glen-de-cauwsemaecker/. In this episode Glen explains the history of Rama, why it exists, how it can be used and more.
On the 19th of August 2025 we released the first episode of Netstack.FM, a new podcast about networking, Rust and everything in between. In the first episode we went over the origins of Glen, Rama and why the podcast was created.
Rama is also frequently featured in newsletters such as https://this-week-in-rust.org/.
This project is dual-licensed under both the MIT license and Apache 2.0 License.
π Thanks for your help improving the project! We are so happy to have
you! We have a contributing guide to help you get involved in the
rama
project.
Contributions often come from people who already know what they want, be it a fix for a bug they encountered, or a feature that they are missing. Please do always make a ticket if one doesn't exist already.
It's possible however that you do not yet know what specifically to contribute, and yet want to help out. For that we thank you. You can take a look at the open issues, and in particular:
good first issue
: issues that are good for those new to therama
codebase;easy
: issues that are seen as easy;mentor available
: issues for which we offer mentorship;low prio
: low prio issues that have no immediate pressure to be finished quick, great in case you want to help out but can only do with limited time to spare;
In general, any issue not assigned already is free to be picked up by anyone else. Please do communicate in the ticket if you are planning to pick it up, as to avoid multiple people trying to solve the same one.
Note
Some issues have a needs input
label.
These mean that the issue is not yet ready for development. First of all prior to starting working on an issue you should always look for
alignment with the rama maintainers. However these
needs input
issues require also prior R&D work:
- add and discuss missing knowledge or other things not clear;
- figure out pros and cons of the solutions (as well as what if we choose to not resolve the issue);
- discuss and brainstorm on possible implementations, desire features, consequences, benefits, ...
Only once this R&D is complete and alignment is confirmed, shall the feature be started to be implemented.
Should you want to contribute to this project but you do not yet know how to program in Rust, you could start learning Rust with as goal to contribute as soon as possible to rama
by using "the Rust 101 Learning Guide" as your study companion. Glen can also be hired as a mentor or teacher to give you paid 1-on-1 lessons and other similar consultancy services. You can find his contact details at https://www.glendc.com/.
Unless you explicitly state otherwise, any contribution intentionally submitted
for inclusion in rama
by you, shall be licensed as both MIT and Apache 2.0,
without any additional terms or conditions.
Special thanks goes to all involved in developing, maintaining and supporting the Rust programming language, the Tokio ecosystem and all other crates that we depend upon. This also includes Hyper and its ecosystem as without those projects Rama would not be. The core http module of rama is a specialised fork of hyper
and use the underlying h2
and h3
crates as dependencies.
Extra credits also go to Axum, from which ideas and code were copied as it's a project very much in line with the kind of software we want Rama to be, but for a different purpose. Our hats also go off to Tower, its inventors and all the people and creatures that help make it be every day. The service concept is derived from Tower and many of our layers are a Tower fork, adapted where required or desired.
An extra big shoutout goes also to the online communities surrounding and part of these ecosystems. They are a great place to hangout and always friendly and helpful. Thanks.
Rama is completely free, open-source software which needs lots of effort and time to develop and maintain.
You can become a regular financial contributor to Rama by paying for a monthly subscription at Github Sponsors. One time contributions are possible as well.
Sponsors help us continue to maintain and improve rama
, as well as other
Free and Open Source (FOSS) technology. It also helps us to create
educational content such as https://github.com/plabayo/learn-rust-101,
and other open source libraries such as https://github.com/plabayo/tokio-graceful and https://venndb.rs.
Next to the many unpaid developer hours we put in a project such as rama
,
we also have plenty of costs, such as services ranging from hosting to Docker,
but also tooling for developers and automated processing. All these costs money.
Sponsors receive perks and depending on your regular contribution it also allows you to rely on us for support and consulting.
Finally, you can also support us by shopping Plabayo <3 γ©γ
merchandise ποΈ at https://plabayo.threadless.com/.
We would like to extend our thanks to the following sponsors for funding Rama (γ©γ) development. If you are interested in becoming a sponsor, you can do so by becoming a sponsor. One time payments are accepted at GitHub as well as at "Buy me a Coffee". One-time and monthly financial contributions are also possible via Paypal, should you feel more at ease with that at "Paypal Donations".
Donations can also be paid in the following cryptocurrency:
- Bitcoin:
bc1qk3383nfzcag9lymwv83m7empa6qu2vspqjkpw4
- Ethereum:
0xc0C5aCdB0E6c560132c93Df721E1Cd220f6fD4aa
If you wish to financially support us through other means you can best start a conversation with us by sending an email to [email protected].
Rama (γ©γ) is bundled with Http/Tls emulation data, gathered for all major platforms and browsers using real devices by BrowserStack. It does this automatically every day by using our public Fingerprinting service which is hosted together with a database on fly.io.
We are grateful to both sponsors for sponsering us these cloud resources.
- SignPath.io: provides authoritive code signing for the windows rama CLI;
π€ Enterprise support, software customisations, integrations, professional support, consultancy and training are available upon request by sending an email to [email protected]. Or get an enterprise subscription via Gihub Sponsors.
These type of contracts are another way for you to be able to support the project and at the same time get serviced for your own needs and purposes.
Rama is licensed as both MIT and Apache 2.0, as such you are free to use and modify the source code for any purposes, including commercial goals. That said, we would appreciate it if you would consider becoming a sponsor of the project if you do end up using it for commcercial reasons.
While there are a handful of proxies written in Rust, there are only two other Rust frameworks specifically made for proxy purposes. All other proxy codebases are single purpose code bases, some even just for learning purposes. Or are actually generic http/web libraries/frameworks that facilitate proxy features as an extra.
Cloudflare has been working on a proxy service framework, named pingora
, since a couple of years already,
and on the 28th of February of 2024 they also open sourced it.
Rama is not for everyone, but we sure hope it is right for you.
If not, consider giving pingora
a try, it might very well be the next best thing for you.
Secondly, ByteDance has an open source proxy framework written in Rust to develop forward
and reverse proxies alike, named g3proxy
.
Available at https://ramaproxy.org/book/faq.html.
π Want to know why we built Rama? Check out the NetstackFM podcast.