Skip to content

Latest commit

 

History

History
55 lines (43 loc) · 3.32 KB

README.md

File metadata and controls

55 lines (43 loc) · 3.32 KB

OPS is a collection of CoreOS and Docker files to simplify the deployment of multiple web services on Digital Ocean. The docker build processes can be used on any provider. Each component is divided into the following folders:

Quick Start

    $ git clone [email protected]:htmlgraphic/CoreOS.git && cd CoreOS
    $ make
    $ make token
    $ make node

Creating a cluster

Creating nodes for the CoreOS cluster is as simple as typing the make node.

  • Before running the make process, set the (Digital Ocean Key - Read & Write) DO_TOKEN environment variable and the SSH key ID (ssh_keys) in the script create_node_var.sh.

    Example: export DO_TOKEN=xyzabc123 add this to either your ~/.zshrc OR ~/.bashrc file to create when the terminal is launched.

  • New discovery URLs can be generated at https://discovery.etcd.io/new This process will be handled for you via the creation process if you have an existing cluster simply add the etcd token to .discovery-token.

  • Current variables set during box creation:

    • name - what is the droplet called? A valid domain name is possible as Digital Ocean will add a reverse DNS lookup
    • backup - boolean, Enable automated backups - more info
    • region - where should this droplet be created
    • size - 512mb, 1gb, 2gb - issue a CURL request to understand your size options - more info
    • private_networking - boolean
    • image - what version of CoreOS: coreos-stable coreos-beta coreos-alpha
    • user_data - this is where the cloud-config.yaml comes into play
    • ssh_keys - CoreOS only uses a key for login and the username is core. You will need to add one to your DO account - more info

Accessing the cluster

You may now verify that the cluster has clustered by SSHing into a node.

  • SSH into a node as the core user with the -A flag (to forward the SSH agent): ssh -A core@<node_public_ip>
  • On the node, run fleetctl list-machines to verify that the nodes have discovered each other.

It may also be preferred to install fleetctl on your local machine and connect remotely:

  • Run ssh-add to ensure your SSH key is added to the ssh agent
  • Run fleetctl --tunnel=<node_public_ip> list-machines
  • You may set the FLEETCTL_TUNNEL environment variable to skip setting the --tunnel flag

Deploying apps

It's important that the unit files (*.service) is accessible to the fleetctl command. If the files are on your local computer, use a tunneled fleetctl connection to load the unit files.

  • Upload the service file with fleetctl submit name.service
  • List unit files with fleetctl list-unit-files
  • Finally, start the units with fleetctl start name.service
  • List loaded units with fleetctl list-units