Skip to content

Latest commit

 

History

History
189 lines (99 loc) · 6.02 KB

README.md

File metadata and controls

189 lines (99 loc) · 6.02 KB

HTTP Load Balancer On Top Of WSO2 Gateway

This is a Google Summer of Code (GSoC 2016) Project. It is under development.

Abstract: http://summerofcode.withgoogle.com/projects/#6175096838291456

Proposal: http://docs.google.com/document/d/1Agl-Y_UKM5eMon8IDZa02aDGj0Yh_vZ7kFC2b1IzFI4/edit?usp=sharing

Status Updates : https://docs.google.com/document/d/1kEk706KkwjK3gFpjx56vNwAKzVQpa-G52MHIC_I7-0Y/edit?usp=sharing

Architecture


High Level Architecture

![alt tag] (docs/High Level Architecture.PNG)


Engine Architecture

![alt tag](docs/Engine Architecture.png)


Message Flow

![LogicalMessageFlow](docs/Message Flow.png)

Performance Benchmarks

In this performance test, five instances of simple service created using Netty framework were used. Each instance is a fast backend (0s delay) with response of size 1KB.

One Million (1,000,000) requests were sent at different concurrency levels (500 to 12,000) to Netty backend, Nginx and GW-LB using apache bench via this [automated script] (performance-benchmark/excecute-tests.sh).

Benchmarks were conducted in Round-Robin algorithm mode with no persistence policies. More details can be found here.


Throughput Test

Tests were done twice. Average of 'Average throughput' for each concurrency level is calculated and plotted.

First graph shows throughput comparison between Open Source Nginx and GW-LB. Second graph shows throughput comparison with Netty backend.

![Throughput] (performance-benchmark/graphs/throughput_without_netty.png)

![ThroughputWithNetty] (performance-benchmark/graphs/throughput_with_netty.png)


Latency Test

Tests were done twice. Average of 'Mean Latency' for each concurrency level is calculated and plotted.

![MeanLatency] (performance-benchmark/graphs/mean_latency.png)


Memory Test

Java Flight Recorder (JFR) is enabled while starting LB server and recording is stopped after load test ends. The obtained JFR recording has memory usage details.

This graph shows Committed, Reserved and Used Heap values.

Enabling JFR in WSO2-Carbon Server

cd CARBON_HOME/bin

Open carbon.sh in any text editor

Then add the following lines in between "-Dfile.encoding=UTF8 " and "org.wso2.carbon.bootstrap.Bootstrap $*"

-XX:+UnlockCommercialFeatures \
-XX:+FlightRecorder \
-XX:FlightRecorderOptions=defaultrecording=true,disk=true,maxage=0,repository=./tmp,dumponexit=true,dumponexitpath=./ \

![UsedMemory] (performance-benchmark/graphs/memory_using_jfr.png)

Building Product

  • JDK 1.8 is required.

  • Clone and do mvn install on https://github.com/wso2/carbon-gateway-framework.git as this product is dependent on it.

  • Then do mvn install on this product.

  • Now Clone and do mvn install on https://github.com/Venkat2811/carbon-gateway-framework-with-LB.git as it has support for LB.

  • Again do mvn install on this product.

  • Once build is successful, extract product zip file at <CARBON_HOME>\product\target\

  • Add configuration (.iflow) file in <EXTRACTED_PRODUCT>\deployment\integration-flows

    NOTE: As of now, Carbon Gateway Framework supports only one configuration file.

  • Then goto <EXTRACTED_PRODUCT>\bin and start carbon.bat or carbon.sh accordingly.

Sample Configuration

@startuml

participant StocksInbound : InboundEndpoint(protocol("http"),port("8290"),context("/stocks"))

participant StocksPipeline : Pipeline("Stocks_Flow")

participant Endpoint1 : OutboundEndpoint(protocol("http"),host("http://localhost:8080/stockquote/all"))

participant Endpoint2 : OutboundEndpoint(protocol("http"),host("http://localhost:8082/stockquote/all"))

participant Endpoint3 : OutboundEndpoint(protocol("http"),host("http://localhost:8084/stockquote/all"))

participant Endpoint4 : OutboundEndpoint(protocol("http"),host("http://localhost:8086/stockquote/all"))

participant Endpoint5 : OutboundEndpoint(protocol("http"),host("http://localhost:8088/stockquote/all"))

StocksInbound -> StocksPipeline : "client request"

LoadBalancer(algorithm(name(ROUND_ROBIN)),persistence(type(NO_PERSISTENCE)),healthCheck(type(PASSIVE),requestTimeout(5s),unHealthyRetries(2times),healthyRetries(3times),healthyCheckInterval(1m)))

StocksPipeline -> StocksInbound : "Final Response"

@enduml

Directory Structure

  • carbon-gw-lb: Contains source code for LB.

  • docs: Contains diagrams and javadoc.

  • performance-benchmark: Contains graphs, sample configuration used for benchmarking, sample back-end services, test bed related details and scripts used for benchmarking.

  • product: Contains carbon server related config. Once product is built successfully, zip file will be available here.

More Samples

You can find more samples in /product/carbon-home/samples/.

Traffic Flows

Carbon Gateway Framework provides abstraction on HTTP/HTTPs traffic. By configuring Inbound and Outbound endpoints with appropriate protocol, the following three modes of operation can be achieved.

Simple HTTP

Traffic between Client -> LB -> Back-End and Back-End -> LB -> Client are un-encrypted.

SSL Offload

  • Traffic from Client -> LB and LB -> Client are encrypted.
  • Traffic from LB -> Back-End and Back-End -> LB are un-encrypted.

In this mode, when request reaches WSO2-Netty Listener, it gets decrypted and LB mediates requests to appropriate Outbound Endpoints.

When response from back-end reaches LB, it forwards it to appropriate client. When response reaches WSO2-Netty Listener it is encrypted and is forwarded to client.

SSL Re-Encryption

Traffic between Client -> LB -> Back-End and Back-End -> LB -> Client are encrypted.

In this mode, when request reaches WSO2-Netty Listener, it gets decrypted and LB mediates requests to appropriate Outbound Endpoints. When requests reach WSO2-Netty sender it gets encrypted again and is sent to backend.

It works similarly when response arrives.