Reputation: 4693
Okay, I've read a small article on wiki which explained AJP a bit. Basically this protocol is used for communication between Apache and Application server. But why may one need it in the first place? Why not use just plain http?
Upvotes: 65
Views: 77010
Reputation: 7686
AJP (Apache Jserv Protocol) is basically a binary protocol that allows to reverse proxying requests from a FE Web Server to a BE Application Server, effectively propagating all the needed information to make the Req-Res flow continuing successfully. Often, AJP is used to load balance using sticky-session policies: thanks to the transferred header data, the FE Web Server can load balance over the BE counterparts making use of specific modules (like, mod_jk).
AJP is used mainly because:
Definitely, I'd say that it's a proven solution with almost 20 years of maturity on the shoulders: it's successfully used in production environments.
Upvotes: 31
Reputation: 3819
More specifically, and not really covered in that ehow article, there's some non-trivial overhead to parsing http headers on requests and creating them on responses. If you are fronting your app server with a web proxy server, AJP allows you to skip that extra parsing and just pass efficient binary representations of the headers between the proxy server and the app server. There are other benefits with things like simple connection pools and tight integration if you use apache/mod_jk to tomcat.
Client <- http/s-> Proxy <- http/s -> App
vs
Client <- http/s-> Proxy <- AJP -> App
Upvotes: 54
Reputation: 4693
Seems the answer I was looking for is perfomance
http://www.ehow.com/facts_7181755_ajp-protocol_.html
Upvotes: 10