Public | Automated Build

Last pushed: 2 years ago
Short Description
A fake endpoint for the xservedbyfinder coding challenge.
Full Description

x-served-by finder

This repository accompanies a blog post, please read it before continuing.

Node.js vs. Bash – Apr First Raspberry PI Challenge

The challenge: Reveal all the web-server nodes hidden behind a load-balancer by checking for the X-Served-By header.

Open invitation

You will find a few solutions in Node.js, Bash and Go. This is an open invitation for your contribution. Solve the problem the way that feels most natural to you, in whatever programming language you like then:

  • Fork the repository
  • Push up your changes into a new folder with a brief file
  • Ideally push a Dockerfile so that we can test the changes easily and include them in an automated build.
  • Raise a pull request (PR) and I will merge it.
  • Update the Examples so far section of the main file.
  • Update the file with your Github username and fork.

This is a chance to contribute to an open-source project without having to over-commit your time or worry about pushing a flashy feature to an established code-base.


For a practical tutorial and progressive set of labs from an official Docker Captain try my
Hands-on Docker Tutorial

Solutions so far:

List of Contributors

Tips for contributing

Use a fake server, instead of

Update: You may find that running the code against results in only two VMs being returned instead of the full set. I've also included a fake endpoint in the Github repo. You can test against this without going to the public Internet.

If you are using Docker then you can make use of a pre-built image directly from the Docker Hub xservedbyfinder-endpoint:

$ docker pull alexellis2/xservedbyfinder-endpoint
$ docker run -d -p 3000:3000 alexellis2/xservedbyfinder-endpoint

Without Docker:

  • Install Node.js (4.x) if you do not already have it.
  • Run the test server:
$ cd fakeendpoint/
$ node app.js
Listening on port 3000
  • Then update your URL to the IP address of your machine or http://localhost:3000
  • If you are using Docker then an environmental variable may be useful for passing different URLs.

You will now have a close simulation of the website on the day as mentioned in the blog post.

Node.js vs. Bash – Apr First Raspberry PI Challenge

Extra points

  • Passing or configuring the URL by environmental variable.

  • Adding a Dockerfile

You can extra kudos for adding a Dockerfile. This means anyone who wants to run your example can do so with zero fuss. I'd also like to include them in a CI build at a later date.

Several Dockerfiles are already included, please look through the examples if you need an example.

Docker Pull Command
Source Repository