AWS Hosting in CHT 3.x

Hosting the CHT on Amazon EC2

Most production CHT instances are deployed on AWS EC2. Leveraging Elastic Compute Cloud (EC2) and Elastic Block Store (EBS), CHT instances can easily be scaled up with larger EC2 instances and have easy increased disk space, backup and restores with EBS.

This guide will walk you through the process of creating an EC2 instance, mounting an EBS volume and provisioning Docker containers.

Create and Configure EC2 Instance

  1. Create EC2 (use security best practices)

    Review the CHT hardware requirements and start with an appropriately sized instance. After creating the instance and downloading the .pem file, change permissions to 0600 for it:

    sudo chmod 0600 ~/Downloads/name_of_file.pem
    

    Create an Elastic IP (EIP) and associate the EIP to your EC2 instance.

    You should now be able to SSH into the EC2 instance using the EIP and the .pem file.

    Goal: SSH into instance

  2. Create or Restore EBS Volume

    • Create or Restore your EBS Volume, tagging appropriately, so it can be found later.
    • Attach volume to EC2 instance
    • Increase disk size (Optional)
    • If you are using a newly created EBS Volume, you will have to format the disk appropriately:
      1. SSH into instance
      2. Follow the instructions here: Using EBS Volumes
      3. Use sudo mkfs -t ext4 <location> in step 4
      4. Mount disk to /srv

    Goal: Mount EBS volume to /srv

  3. Provision Docker server

    Follow README & Run scripts in cht-infrastructure repository.

    Goal: CHT Application bootstraps and comes online

  4. DNS configuration

    • Point DNS A record to EIP given to Docker server in the prior step.
  5. Review SSL certificates

    • Location of certs is /srv/settings/medic-core/nginx/private/
    • Name the key file is default.key and the certificate file is default.crt
    • See SSL Certificates to install new certificates
  6. Configure CHT Sync See the CHT Sync configuration.

  7. Setup postgres to work with CHT Sync

    • Creating the database, setting up permissions, exploring the tables and what they store
  8. Debugging CHT Sync/postgres

    • Understanding the log and what the entries mean

Troubleshooting

  1. Restarting processes

    /boot/svc-<start/stop/restart> <service-name/medic-api/medic-sentinel/medic-core couchdb/medic-core nginx>
    
  2. Investigating logs inside Medic OS

    • To view logs, first run this to access a shell in the medic-os container: docker exec -it medic-os /bin/bash
    • View CouchDB logs: less /srv/storage/medic-core/couchdb/logs/startup.log
    • View medic-api logs: less /srv/storage/medic-api/logs/medic-api.log
    • View medic-sentinel logs: less /srv/storage/medic-sentinel/logs/medic-sentinel.log
  3. Investigating docker stderr/stdout logs

     sudo docker logs medic-os
     sudo docker logs haproxy
    
  4. Upgrading the container

    • Backup all data (EBS)

    • Log into container and stop all services

    • To prepare for the upgrade, delete all other files in /srv EXCEPT for /srv/storage/medic-core/

      The medic-core directory is where the CHT stores user data. Of key importance is ./couchdb/local.in and ./medic-core/couchdb/local.d/ where custom CouchDB configuration is stored.

    • Change the image tag to the final Medic OS image release version (cht-3.9.0-rc.2) in the docker compose file:

      services:
         medic-os:
            image: medicmobile/medic-os:cht-3.9.0-rc.2
      
    • Launch new containers with appropriate COUCHDB_ADMIN_PASSWORD & HA_PASSWORD environment variables

  5. Upgrading the webapp

  6. RDS help

Backups

  1. Configure backups

  2. Restoring from backup

    • Create volume from snapshot
    • Tag appropriately for backups
    • Mount volume to docker server

Process supervision

  • supvisorctl
  • /boot/supervisor-inspect

Increasing disk size

Monitor disk usage so alerts are sent before all disk spaces is used up. If free disk space falls below 40%, increase the disk space as follows:

  • Stop medic: sudo supervisorctl stop medic
  • Go to EBS in AWS and take a snapshot of the volume.
  • Modify the volume size (Increase it by 2x preferably). Wait until the modification succeeds.
  • Make the instance recognize the additional space
  • Turn medic back on: sudo supervisorctl start medic

Monitoring & Backup

  • AWS CloudWatch and monitoring tab. Enable detailed monitoring (This costs more money)
  • Set up Lifecycle Management for EBS snapshots
  • Steps to mounting a backup snapshot to the instance and restarting the application
  • Please see the second-half of “Increasing disk size” reference above
  • Setup a TLS cert & DNS registration

Hosting > 3.x > Production Hosting - Docker

Hosting the CHT on self run infrastructure