Welcome! Log In Create A New Profile

Advanced

Tomcat cluster behind nginx: avoiding delays while restarting tomcat

John Morris
May 27, 2009 03:59AM
We run a tomcat cluster behind nginx with the upstream module. Nginx
fits our requirements well for load balancing and failover, except for
in one case.

When starting or restarting tomcat, our web application takes a couple
of minutes to initialize, during which time the tomcat connector is
listening on TCP 8080, but the application isn't ready to process requests.

The nginx documentation instructs that a host (in planned down time)
should be marked as 'down' during this time, and this is a partial
solution to our problem.

Since we're still small, our developers do the application deployment
themselves. The deploy process is quite informal and is performed
manually right now.

Because our developers are primarily Windows users who spend most of
their time in Eclipse, and because they don't have a full understanding
of the systems, they tend to make mistakes when editing config files in
UNIX and when restarting/reloading servers. Because of this, I would
like to find the best solution for automating the deploy process,
beginning with this small part.

If the tomcat connector could be told not to start listening on its TCP
port until the app is finished initializing, then I would be tempted to
let the upstream module's failover mechanism take care of everything
(comments on the wiseness or stupidity of succumbing to this temptation
are welcome). However, I haven't seen any way to accomplish this.

I also don't see any mechanism in the upstream module to help with this,
and the upstream module doesn't seem to consider a tomcat that is
accepting TCP connections but that isn't answering requests to be failed.

This leads me to think that the best way to automate web app deployment
is to either:

- Write a script to edit nginx.conf, mark the tomcat node as 'down', and
reload nginx;

- Or, write a script to run on the tomcat server using iptables to
REJECT connections to TCP 8080 until the app is finished initializing.

Either of these could be built into an automated deployment process that
would save manual labor and the associated human error.

I would appreciate hearing how others have solved this problem, whether
the above ideas are reasonable, and whether there is a standard solution
I haven't heard of. If it seems useful, I'll be happy to post details
about our solution once it is implemented and tested.

John
Subject Author Posted

Tomcat cluster behind nginx: avoiding delays while restarting tomcat

John Morris May 27, 2009 03:59AM

Re: Tomcat cluster behind nginx: avoiding delays while restarting tomcat

anomalizer June 10, 2009 01:42PM



Sorry, only registered users may post in this forum.

Click here to login

Online Users

Guests: 202
Record Number of Users: 8 on April 13, 2023
Record Number of Guests: 421 on December 02, 2018
Powered by nginx      Powered by FreeBSD      PHP Powered      Powered by MariaDB      ipv6 ready