Skip to content

The Problem

Chris edited this page Feb 28, 2017 · 8 revisions

History

Manticore was a proof-of-concept that attempted to build and manage multiple copies of sdl_core simultaneously, and link multiple copies of sdl_hmi to them in order to be usable and served to a user. The user would visit a webpage served by NodeJS and hit an endpoint, which would eventually return HTTP addresses that point to the HMI.

Not much has changed in this general process, but with new demands such as being able to run pre-built sdl_core in a docker container, distributing these containers across multiple communicating machines, and supporting HTTPS and SSL connections, it was clear that the current setup of Manticore was not enough. It was time to move into distributed systems.

The Problem

Creating microservices are difficult to get right. Creating microservices that depend on other microservice information are even more difficult to get right. Fortunately, we live in the right time period where projects related to orchestration are showing up to make programmers' lives much easier. The task of making Manticore a distributed system will still be daunting, but it won't be needlessly daunting. Each technology that powers Manticore has been selected to solve an important and difficult problem. Here's the cast:

Nomad

Hashicorp's many products are meant to solve problems at the level of distributed systems and microservices. Nomad is a flexible scheduler that is able to scale across many machines and determine where programs should be placed out of the machines it can see. Other useful features include:

  • scheduling docker containers
  • the ability for a container scheduled by Nomad to communicate with the Nomad server cluster without storing any direct addresses to the servers
  • the ability to stream logs that are output from a scheduled container
  • a well-documented and useful HTTP API
  • job files which dictate what the expected state of all the programs described should be, leaving how to achieve that state up to Nomad
  • easy integration with Consul for service discovery

Consul

Nomad can schedule and run programs in one of many machines, and the service of that program could be exposed in one of tens of thousands of possible ports. In order to know how to actually find and access these machines, we need service discovery. Consul works with Nomad to allow finding running containers easily. Along with that, it has the following useful features:

  • a distributed key-value store where information can be stored and pulled from
  • the ability for a container scheduled by Nomad to communicate with the Consul server cluster without storing any direct addresses to the servers
  • a well-documented and useful HTTP API
  • the ability to watch for changes in the key-value store and changes in running services, checking the state of containers using health checks

Docker

Being able to run any program in an environment that you can ensure will be the same every time is a very comforting feature to have. Since the environment will not change, we can have sdl_core already compiled in a docker container so that when we need sdl_core to run it will start up almost instantly. Nomad is able to schedule and run docker containers. sdl_core and sdl_hmi are "dockerized", as well as the server that opens an API for clients to receive sdl_core and sdl_hmi instances. Additionally, we can pass extra information into these containers that allow the HMI to always know where sdl_core is for communication.

HAProxy

HAProxy is used as the internal load balancer that helps route traffic of clients to their HMI instances. HAProxy only allows connections to the HMI from users that have knowledge of a randomly generated URL given only to them by the Manticore web app. Additionally, HAProxy supports HTTP and websocket connections out of the box, and is very easy to programmatically change its configuration for whenever docker containers are created and destroyed. HAProxy opens up TCP ports so that users can connect their SDL app to sdl_core.

Consul Template

consul-template is a program that looks at changes in the Consul KV store and can use that information stored to generate template files. This program is especially useful for configuration load balancer config files, and it's what allows HAProxy to have automatic configuration.

AWS Elastic Load Balancer

AWS has many important uses for Manticore, but the ELB is useful for finding running instances with HAProxy to route external traffic to. The ELB also makes it easy to use SSL certificates to allow encrypted HTTP and websocket traffic, with SSL termination at the ELB.

NodeJS

NodeJS and the community-made modules that can be used with it are great for making servers and managing clients accessing an HTTP API. The Manticore web application is the component that controls all of the logic that the other programs cannot do on their own. This includes making calls to Consul and Nomad to start up containers, watching for service changes, managing user requests, implementing a waiting list, sending data to the KV store to be used by consul-template, and using the AWS SDK API to configure the ELB to open and close TCP ports.

It's time to see how all of these technologies can be combined to form into the behemoth that is Manticore. Read here for possible designs for Manticore

Clone this wiki locally