У меня есть одно приложение django, размещенное на AWS - Web client <=> nginx <=> uwsgi <=> django
. Я решил превратить его в мультитенант с джанго-тенант. Также я использую Джанго-сельдерей-бит для планирования задач. Мое отдельное приложение нормально работает на AWS, и мой мультитенант тоже работает локально, на моей машине. У меня была проблема с распознаванием схем с сельдереем, но я решил ее здесь: Можно ли использовать django-celery-beat с django-tenant?. Однако ошибка, которую я получаю сейчас, находится в пределах моей VPN: django.db.utils.ProgrammingError: relation" app_modelcustomuser "does not exist
Появляется когда я пытаюсь бежать ./manage migrate_schemas
(Я делаю makemigration на своем локальном компьютере и фиксирую его, поэтому мне просто нужно перейти на БД в моем VPN) или любой другой перенос. Я пытался выполнить миграцию с помощью приложения, но получаю, когда это сделаю ./manage migrate admin
. Мой settings.py файл выглядит так:
SHARED_APPS = [
'django_tenants',
'django.contrib.admin',
'django.contrib.contenttypes',
'django.contrib.auth',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'clients',
]
TENANT_APPS = [
'django.contrib.admin',
'django.contrib.contenttypes',
'django.contrib.auth',
'django.contrib.sessions',
'django.contrib.messages',
# Libs
'stdimage',
'django_celery_beat',
'djcelery_email',
'tenant_schemas_celery',
# 'widget_tweaks',
'bootstrap4',
'bootstrapform',
mathfilters,
'django_filters',
'sorl.thumbnail',
# Apps
'presence',
'confirmed list',
'topper',
'app_users.apps.AppUsersConfig',
]
INSTALLED_APPS = list (set (SHARED_APPS + TENANT_APPS))
AUTH_USER_MODEL = 'app_users.ModelCustomUser'
PUBLIC_SCHEMA_URLCONF = 'myproject.urls_public'
# Django Tenant
TENANT_MODEL = "clients.Client" # app.Model
TENANT_DOMAIN_MODEL = "clients.Domain" # app.Model
DATABASE_ROUTERS = (
'django_tenants.routers.TenantSyncRouter',
)
мой models.py (приложение-приложение):
class ModelCustomUser (AbstractUser):
image = ImageField (
'Image',
upload_to = 'images',
default = 'images/new_logo.png',
)
мои формы.py:
class CustomUserCreationForm (UserCreationForm):
class Goal:
model = ModelCustomUser
# Changed when placing the Filters
fields = ('first_name', 'last_name', 'username', 'email', 'image')
class CustomUserChangeForm (UserChangeForm):
class Goal:
model = ModelCustomUser
fields = ('first_name', 'last_name', 'username', 'email', 'image')
Мой admin.py:
class AdminCustomUser (UserAdmin):
add_form = CustomUserCreationForm
form = CustomUserChangeForm
model = ModelCustomUser
# list_display = ['first_name', 'last_name', 'email', 'username', 'image']
list_display = ['first_name', 'last_name', 'email', 'username', 'image']
admin.site.register (ModelCustomUser, AdminCustomUser)
В моем клиентском приложении мой models.py:
class Client(TenantMixin):
name = models.CharField(max_length=100)
# default true, schema will be automatically created and synced when it is saved
auto_create_schema = True
def __str__(self):
return self.name
class Domain(DomainMixin):
pass
Давно пытался исправить эту проблему, но безуспешно. Если кто-то может мне помочь, я очень ценю это!