Skip to main content

Simple database sharding (horizontal partitioning) library for Django applications.

Project description

Django Horizon Documentation Status Updates Python 3


Simple database sharding (horizontal partitioning) library for Django applications.



  • Shard (horizontal partitioning) by some ForeignKey field like user account.


To install Django Horizon, run this command in your terminal:

$ pip install django-horizon

This is the preferred method to install Django Horizon, as it will always install the most recent stable release.

If you don’t have pip installed, this Python installation guide can guide you through the process.



Add database router configuration in your

Horizontal database groups and a metadata store
    'GROUPS': {
        'group1': {  # The name of database horizontal partitioning group
            'DATABASES': {
                1: {
                    'write': 'member1-primary',
                    'read': ['member1-replica-1', 'member1-replica-2'],  # Pick randomly by router
                2: {
                    'write': 'member2-primary',
                    'read': ['member2-replica'],
                3: {
                    'write': 'a3',  # Used by 'read' too
            'PICKABLES': [2, 3],  # Group member keys to pick new database
    'METADATA_MODEL': 'app.HorizontalMetadata',  # Metadata store for horizontal partition key and there database
Database router

Example models

Horizontal partitioning by user

Metadata store
from horizon.models import AbstractHorizontalMetadata

class HorizontalMetadata(AbstractHorizontalMetadata):

In the example, metadata store save followings.

  • group: Group name for horizontal partitioning.

  • key: Determines the distribution of the table’s records among the horizontal partitioning group.

  • index: Choosed database index in horizontal partitioning groups.

Sharded model
from django.conf import settings

from horizon.manager import HorizontalManager  # For Django<1.10
from horizon.models import AbstractHorizontalModel

class SomeLargeModel(AbstractHorizontalModel):
    user = models.ForeignKey(
        db_constraint=False,  # May be using anothor database

    objects = HorizontalManager()  # For Django<1.10

    class Meta(object):
        horizontal_group = 'group1'  # Group name
        horizontal_key = 'user'  # Field name to use group key

In many cases use UUIDField field for id. The AbstractHorizontalModel uses UUIDField as a them id field in default.

Using a model
from django.contrib.auth import get_user_model

user_model = get_user_model()
user = user_model.objects.get(pk=1)

# Get by foreign instance

# Get by foreign id
Model limitations
  • django.db.utils.IntegrityError occured when not specify horizontal key field to filter

  • Cannot lookup by foreign key field, cause there are other (like default) database



1.1.0 (2018-03-30)_

  • Drop support for Django 1.9, 1.10

1.0.0 (2018-02-02)

  • Add support for Django 2.0

  • Drop support for Django 1.8

0.0.1 (2017-05-22)

  • First release on PyPI.

Project details

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django-horizon-1.1.1.tar.gz (239.4 kB view hashes)

Uploaded Source

Built Distribution

django_horizon-1.1.1-py2.py3-none-any.whl (9.6 kB view hashes)

Uploaded Python 2 Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page