Skip to content

Latest commit

 

History

History
232 lines (169 loc) · 8.53 KB

README.md

File metadata and controls

232 lines (169 loc) · 8.53 KB

service-discovery-workshop

Presentation: https://bekkopen.github.io/service-discovery-workshop/

Before the workshop

If you want to prepare youself for the workshop, clone this repo and install Vagrant and Virtualbox.

Go to the cloned directory, and run vagrant up. Vagrant will now download the images you need, and you will be ready for the workshop.

USB-stick

We have some USB-sticks you can use so you dont have to download the VM image. After installing Vagrant and Virtualbox, run the following command in the directory of the USB stick:

vagrant box add smat/service-discovery-workshop mybox.box

systems overview

0. Initial setup

We are using five virtual machines in this workshop. See the diagram above. To start the servers run:

vagrant up

To start up Consul on the master node:

vagrant ssh master # Log in to the master node
nohup consul agent -server -bootstrap-expect 1 -data-dir /tmp/consul -config-dir /etc/consul.d/ -ui-dir /opt/consul-web/ -bind 172.20.100.2 -client 0.0.0.0 -node master &
exit # Exit the virtual machine

You should have a consul agent running on each node to use Consul. The commands below will log in and start the consul agent on each node, and connects them to the master:

### Setup service1
vagrant ssh service1
nohup consul agent -data-dir /tmp/consul -config-dir /etc/consul.d/ -bind 172.20.100.5 -node service1 &
sleep 2 # Wait for consul to start
consul join 172.20.100.2
consul members # list all members in the cluster
exit

# Setup service2
vagrant ssh service2
nohup consul agent -data-dir /tmp/consul -config-dir /etc/consul.d/ -bind 172.20.100.6 -node service2 &
sleep 2 # Wait for consul to start
consul join 172.20.100.2
consul members # list all members in the cluster
exit

# Setup webapp1
vagrant ssh webapp1
nohup consul agent -data-dir /tmp/consul -config-dir /etc/consul.d/ -bind 172.20.100.7 -node webapp1 &
sleep 2 # Wait for consul to start
consul join 172.20.100.2
consul members # list all members in the cluster
exit

# Setup webapp2
vagrant ssh webapp2
nohup consul agent -data-dir /tmp/consul -config-dir /etc/consul.d/ -bind 172.20.100.8 -node webapp2 &
sleep 2 # Wait for consul to start
consul join 172.20.100.2
consul members # list all members in the cluster
exit

Have a look at the Web UI on http://localhost:8500/ui

1. Register services

The first exercise is to register our webapplications serving API for our frontend. We will use Consul's service files. The /etc/consul.d directory is already present.

Register the webapp using the JSON file. The application is running on port 8080. The file must be created on the node the application is running on. After creating the file, run consul reload on the node, to make consul re-read the /etc/consul.d-directory.

Use vagrant ssh webapp1 and vagrant ssh webapp2 to connect to the two servers running the application.

You should also start the application by running backend.sh start inside the VM.

Use the Consul Web API to query and check if your services has been registered. The easiest way is to use curl from inside one of the application servers. If you called you service backend, the command should be: curl http://localhost:8500/v1/catalog/service/backend

We also also installed Consul UI for you. Open a browser on http://localhost:8500/ to see you registered service.

We have set up HAProxy to serve the application using a static config. We will be using the registered service later. For now you can go to http://localhost:8888/ to see that the application works.

2. Registering services through API

There are two ways of registering a service in Consul. In the first task we registered a service with a JSON file. The other way use to register a service is with the Consul API.

Try using the smallest JSON file you can use. We do not use a healthcheck at this time. Since we are using the agent-API, you dont even need to have an IP adress in the file, since it will use the agents IP if it is missing.

You should also start the application by running service.sh start inside the VM (for service1 and service2).

Use the Consul API to register the services running on service1 and service2. A tip is to log in to one of them and put the JSON into a file, and use curl to call the API. Example below: -d sends the data in filename.json as the HTTP body.

curl -X PUT -d @filename.json http://localhost:8500/v1/agent/service/register

Check that the services has been registered correctly.

3. Using consul-template

Our webapp-backend is going to talk to another service. To know the URL of this service, the webapp-backend reads config.properties, and put in service.url= with a comma-seperated list of URLs. The app reloads this file automatically.

To create this file we are going to use a tool called consul-template. The default configuration for consul-template is fine, so no need to create a configuration file. The program will watch for changes in the consul cluster, and write a new file based on template after each change. That way our application can read that file, and always have up-to-date URLs to call.

The template files are written as Go-template with some extensions

By adding - when printing variables in the template, you also remove whitespace. {{- .Address }} will remove the whitespace and newlines before the variable, and {{ .Address -}} will remove after. To create a comma seperated list, see the tip in the Stackoverflow answer

The service-command will list out all the IP-s and ports for a given service. Use this to iterate through the nodes. The range-command is useful to iterate over the values.

Use consul-template to create the config.properties file, and with the property service.url= with IP and and port in a comma separeted list. Example of a rendered file:

# config.properties
service.url=172.20.100.5:8080,172.20.100.6:8080

You have now connected the tag service to our application. Go to http://localhost:8888/ to see that that you can add tags to to-do's. You can also check in the bottom which service the application is using. Refreshing a couple of times should change this address.

4. Configuring HAProxy with consul-template

HAProxy is a load balancing software which is running on the master node. It is now configured to serve HTTP requests using static IP adresses to our webapp nodes.

Consule template have third argument to -template that allows you to specify a reload command. service haproxy reload will reload the HAProxy config. You will find the configuration file used in /etc/haproxy/haproxy.cfg on the master node. Use this file as the basis for your template.

Using consul template, reconfigure HAProxy to be updated for each change in consul.

5. Healthchecks

Now we are adding healthchecks to our webapp (running on webapp1 and webapp2)

First we need to deregister our service. With consul you are not able to modify a service entry after registration, so we need to deregister. Use the deregister-API to remove webapp1 and webapp2. Use the name of the service as the path parameter.

The next step is to add an HTTP-check using the agent register api.

After adding a healthcheck to both nodes, check the Consul UI that they work correctly.

Now try to log in to webapp1, and stop the application by running ./backend.sh stop. Check that the healthcheck is starting to fail in the Conul UI. Try refreshing the application also. If everything is set up correctly, the node should be removed from HAProxy, and you shouldn't see any errors.

Try also to log in on the master node, and verify that /etc/haproxy/haproxy.cfg now only have one server entry.

6. Finished

Congratulations, you have finished the workshop. Now you just have to clean up. Run this to stop and delete alle the virtual machines:

vagrant destroy