Phantom is a high performance proxy for accessing distributed services. It is an RPC system with support for different transports and protocols. Phantom is inspired by Twitter Finagle clients and builds on the capabilities of technologies like Netty, Unix Domain Sockets, Netflix Hystrix and Spring. Phantom proxies have been used to serve several hundred million API calls in production deployments at Flipkart.
Release | Date | Description |
---|---|---|
Version 3.8.0 | Dec 2021 | Upgrade log4j to 2.16.0 |
Version 3.7.0 | Dec 2021 | Upgrade log4j to 2.15.0 |
Version 3.6.0 | Nov 2021 | Filtering commands and threadpools in hystrix dashboard |
Version 3.5.0 | Sep 2020 | Spring 5 Upgrade & Corresponding XML updates |
Version 3.4.0 | May 2017 | Passing execution errors to fallback |
Version 3.3.0 | Feb 2017 | Upgrading to Jetty 9.4.1.v20170120 |
Version 3.2.0 | Jan 2017 | Hystrix 1.5.8, Customizable core and max thread pool sizes for Task |
Changelog can be viewed in CHANGELOG.md file (https://github.com/Flipkart/phantom/blob/master/CHANGELOG.md)
Phantom is the "ghost who walks" - an entity whose presence can be felt (in a good way) but its existence need not be acknowledged. The Service Proxies fit this analogy well and therefore earned the moniker "Phantom". Motivation for creating Phantom and design overview is described in this Proxies for resilience and fault tolerance in SOA blog post.
The Getting Started page has "5 minute" examples to help you start using Phantom proxies.
Phantom project modules that start with "sample" - for e.g. sample-http-proxy, sample-task-proxy are example proxy implementations. Documentation is continuously being added to the Wiki page of Phantom (https://github.com/Flipkart/phantom/wiki)
For discussion, help regarding usage, or receiving important announcements, subscribe to the Phantom users mailing list: http://groups.google.com/group/phantom-users
Phantom is licensed under : The Apache Software License, Version 2.0. Here is a copy of the license (http://www.apache.org/licenses/LICENSE-2.0.txt)