Skip to content

Latest commit

 

History

History
147 lines (122 loc) · 4.22 KB

CITUSDB_SETUP.md

File metadata and controls

147 lines (122 loc) · 4.22 KB

Setting up CitusDB for use in CommCare

CitusDB is a distributed SQL database built on top of PostgreSQL.

Running CitusDB

To run CitusDB in docker execute the following command:

$ ./scripts/docker citus up -d

This will spin up 3 containers:

  • citus_master (port 5600)
  • citus_worker1 (port 5601)
  • citus_worker2 (port 5602)

By default the postgres database will be configured on all nodes with the citus extension and with the worker nodes added to the master node.

For info on how that works see the Citus docs

Django settings

The following database settings should be added to localsettings.py:

DATABASES.update({
    'icds-ucr': {
        'ENGINE': 'django.db.backends.postgresql_psycopg2',
        'DISABLE_SERVER_SIDE_CURSORS': True,
        'NAME': 'commcare_ucr_citus',
        'USER': 'postgres',
        'PASSWORD': '',
        'HOST': 'localhost',
        'PORT': '5600',
        'TEST': {
            'SERIALIZE': False,
        },
        'ROLE': 'citus_master'
    },
    'citus-ucr-worker1': {
        'ENGINE': 'django.db.backends.postgresql_psycopg2',
        'DISABLE_SERVER_SIDE_CURSORS': True,
        'NAME': 'commcare_ucr_citus',
        'USER': 'postgres',
        'PASSWORD': '',
        'HOST': 'localhost',
        'PORT': '5601',
        'TEST': {
            'SERIALIZE': False,
            # this ensures the master gets created / destroyed before the workers
            'DEPENDENCIES': ['icds-ucr'],
        },
        'ROLE': 'citus_worker',
        'CITUS_NODE_NAME': 'citus_worker1:5432'
    },
    'citus-ucr-worker2': {
        'ENGINE': 'django.db.backends.postgresql_psycopg2',
        'DISABLE_SERVER_SIDE_CURSORS': True,
        'NAME': 'commcare_ucr_citus',
        'USER': 'postgres',
        'PASSWORD': '',
        'HOST': 'localhost',
        'PORT': '5602',
        'TEST': {
            'SERIALIZE': False,
            'DEPENDENCIES': ['icds-ucr'],
        },
        'ROLE': 'citus_worker',
        'CITUS_NODE_NAME': 'citus_worker2:5432'
    },
})

ROLE

This setting allows Django to know which DB is the master and which are workers. This allows it to run migrations during test setup which will add the citus extension and add the worker nodes to the master.

CITUS_NODE_NAME

By defaul when Django creates the test database on the master node it will add the worker nodes using the HOST and PORT. In some cases this doesn't work e.g. if you are running Django outside of Docker. In this case the master node will not be able to access the worker nodes with the same hostname that Django uses. Setting CITUS_NODE_NAME will override the host and port for master to worker communications.

Setting up the database

There are two ways to do the database setup. In both cases you will need to manually create the databases:

$ psql -h localhost -p 5600 -U postgres -c 'create database commcare_ucr_citus;'
$ psql -h localhost -p 5601 -U postgres -c 'create database commcare_ucr_citus;'
$ psql -h localhost -p 5602 -U postgres -c 'create database commcare_ucr_citus;'

Now we can configure the databases in either of the following ways:

  1. Django migrations

    Django will automatically setup test databases however it will not run the necessary migrations outside of the test setup. In order to have Django do the setup for you add the following to your locasettings.py file:

    LOCAL_APPS = LOCAL_APPS + (
        'testapps.citus_master',
        'testapps.citus_worker',
    )
    DATABASE_ROUTERS = ['testapps.citus_master.citus_router.CitusDBRouter']

    Run Django migrate:

    $ ./manage.py migrate_multi
    
  2. Manual setup

    master node

    Connect to your database on the master node:

    $ psql -h localhost -p 5600 -U postgres commcare_ucr_citus
    
    CREATE EXTENSION citus;
    SELECT * from master_add_node('citus_worker1', 5432);
    SELECT * from master_add_node('citus_worker2', 5432);
    

    worker nodes

    Connect to your database on each worker node:

    $ psql -h localhost -p 560[1,2] -U postgres commcare_ucr_citus
    
    CREATE EXTENSION citus;