Na przykładzie Fedory (na CentOS jest tak samo) oraz MariaDB. Nazwę użytkownika w bazie danych najlepiej mieć taką samą, jak w /etc/passwd.
# sudo dnf install mariadb mariadb-server mariadb-devel python3-devel # sudo systemctl start mariadb # sudo mysql_secure_installation # mysql -u root -p > create user 'lukasz'@'localhost' identified by 'tajnehaslo'; > grant all privileges on *.* to 'lukasz'@'localhost' with grant option; > create user 'project'@'localhost' identified by 'tajnehaslo2'; > create database project; > grant all privileges on project.* to 'project'@'localhost'; > grant all privileges on test_project.* to 'project'@'localhost'; > exit;
# mkdir -p project/app # cd project # python3 -m venv . # source bin/activate # pip install --upgrade pip # pip install django mysqlclient # cd app # django-admin startproject project
Poprawić konfigurację dla bazy danych.
#DATABASES = { # 'default': { # 'ENGINE': 'django.db.backends.sqlite3', # 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), # } #} DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'project', 'USER': 'project', 'PASSWORD': 'tajnehaslo2', 'HOST': 'localhost', # Or an IP Address that your DB is hosted on 'PORT': '3306', } }
# python manage.py runserver
Przy założeniu, że mamy dwie bazy danych w klasycznym układzie:
który został opisany na tej stronie.
W katalogu z plikiem manage.py utworzyć plik dbroute.py o treści:
import random from django.conf import settings class ReplicationRouter: def db_for_read(self, model, **hints): """ Randomly pick a database to read from """ return random.choice([key for key in settings.DATABASES]) def db_for_write(self, model, **hints): """ Always send write queries to the master database. """ return 'default'; def allow_relation(self, obj1, obj2, **hints): """ This isn't really applicable for this use-case. """ return True def allow_migrate(self, db, app_label, model_name=None, **hints): """ Only allow migration operations on the master database, just in case. """ if db == 'default': return True return None
W pliku settings.py należy dodać linijkę
DATABASE_ROUTERS = ['dbroute.ReplicationRouter']
oraz zmienić domyślny słownik DATABSES z Sqlite3 na Marię:
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'nazwabazydanych', 'USER': 'uzytkownik', 'PASSWORD': 'haslo', 'HOST': 'maria1.ping.local', 'PORT': '3306' }, 'replica': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'nazwabazydanych', 'USER': 'uzytkownik', 'PASSWORD': 'haslo', 'HOST': 'maria2.ping.local', 'PORT': '3306' }, }