Skip to content

Instantly share code, notes, and snippets.

@vimishor
Last active December 31, 2015 05:59
Show Gist options
  • Star 12 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save vimishor/7944395 to your computer and use it in GitHub Desktop.
Save vimishor/7944395 to your computer and use it in GitHub Desktop.
Custom 503 page while deploy on openshift | License: MIT
<!DOCTYPE html>
<html>
<head>
<title>Deploy in progress. Please try again in few minutes</title>
<style type="text/css" />
body {color: #666; text-align: center; font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; sans-serif; margin:0; width: 800px; margin: auto; font-size: 14px; }
h1 { font-size: 56px; line-height: 100px; font-weight: normal; color: #456; }
h2 { font-size: 24px; color: #666; line-height: 1.5em; }
h3 { color: #456; font-size: 20px; font-weight: normal; line-height: 28px; }
hr { margin: 18px 0; border: 0; border-top: 1px solid #EEE; border-bottom: 1px solid white; }
</style>
</head>
<body>
<h1><center><img alt="" src="" /></center>Deploy in progress</h1>
<h3>Please try again in few minutes.</h3>
</body>
</html>

The default 503 page that is shown while a deployment is in progress on Openshift is not very "user friendly". I wanted to change that page for my DIY app and the solution I found is to start a temporary server that will serve the custom 503 page, while the deployment is in progress.

Python to the rescue !

To keep things simple, I will use python's base http server to serve a static html page. This python web server will be started after the nginx process is stopped and will be terminated at the end of the deployment, right before the nginx server will be started again.

Usage

  • In my stop action hook I will start python web server right after I stop nginx:
# stop nginx

echo "Starting maintenance web server."
nohup python ${OPENSHIFT_RUNTIME_DIR}/maintenance/maintenance.py > /tmp/nohup.out 2>&1&
echo $! > ${OPENSHIFT_RUN_DIR}/maintenance.pid
  • In my start action hook I will stop python web server right before I start nginx:
echo "Stopping maintenance web server."
kill -9 `cat ${OPENSHIFT_RUN_DIR}/maintenance.pid`

# start nginx

So basically when the deployment starts, nginx will be stopped and python's web server will be started and when the deployment is done, python's web server will be stopped and nginx will be started.

#!/usr/bin/env python
import os
import time
import BaseHTTPServer
HOST_NAME = os.getenv("OPENSHIFT_DIY_IP")
PORT_NUMBER = 8080
class MaintenanceHandler(BaseHTTPServer.BaseHTTPRequestHandler):
def do_GET(self):
self.curDir = os.path.dirname(os.path.realpath(__file__))
if self.path=="/":
self.path = "/503.html"
# If requested file does not exists, show 503 page
elif os.path.exists(self.curDir+self.path) == False:
self.path = "/503.html"
try:
# Check extensions and set the mime type accordingly
sendReply = False
if self.path.endswith(".html"):
mimetype = "text/html"
sendReply = True
if self.path.endswith(".png"):
mimetype = "image/png"
sendReply = True
if self.path.endswith(".jpg"):
mimetype = "image/jpg"
sendReply = True
if self.path.endswith(".gif"):
mimetype = "image/gif"
sendReply = True
if self.path.endswith(".js"):
mimetype = "application/javascript"
sendReply = True
if self.path.endswith(".css"):
mimetype = "text/css"
sendReply = True
if sendReply == True:
# Open the static file requested and send it
f = open(self.curDir+self.path)
self.send_response(200)
self.send_header('Content-type',mimetype)
self.end_headers()
self.wfile.write(f.read())
f.close()
return
except IOError:
self.send_error(404, 'File not found: %s' % self.path)
if __name__ == '__main__':
server_class = BaseHTTPServer.HTTPServer
httpd = server_class((HOST_NAME, PORT_NUMBER), MaintenanceHandler)
print time.asctime(), "Server Starts - %s:%s" % (HOST_NAME, PORT_NUMBER)
try:
httpd.serve_forever()
except KeyboardInterrupt:
pass
httpd.server_close()
print time.asctime(), "Server Stops - %s:%s" % (HOST_NAME, PORT_NUMBER)
@flyingfisch
Copy link

so do you just put this in your php directory?

@vimishor
Copy link
Author

I store it under ${OPENSHIFT_RUNTIME_DIR}/maintenance/maintenance.py in my diy cartridge

@connyay
Copy link

connyay commented Aug 28, 2014

Do you mind if I use this in an openshift cartridge I'm building?

@vimishor
Copy link
Author

@connyay You may consider the code under MIT license, so go ahead 😄

@mignev
Copy link

mignev commented May 7, 2015

Hello guys,
I wrote this cartridge based on this gist. https://github.com/mignev/openshift-cartridge-maintenance-page

Thanks @vimishor for your work!

@caruccio
Copy link

Found it via @mignev's cartridge and must say, it's a pretty cool idea!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment