在我们的项目中,我们不使用Django ORM,所以我不能使用Django数据库验证。在启动服务器之前,我需要验证数据库连接。有没有人能帮助我用最佳实践来实现同样的目标??
我的想法是在使用execute_from_command_line(sys.argv)之前,在manage.py中引入几行代码或模块来验证DB连接性。我的方法是正确的,还是有更好的方法来实现同样的目标。
发布于 2015-10-01 18:03:26
您可以编写自己的管理命令,该命令将检查数据库连接,如果可以,则调用runserver命令:
from django.core.management.base import BaseCommand
from django.core.management import call_command
from django.db import connection
class Command(BaseCommand):
def handle(self, *args, **options):
cursor = connection.cursor()
cursor.execute("select 1")
call_command('runserver')发布于 2015-10-01 18:32:51
如果您想要替换runserver命令并在运行之前注入测试:
project/settings.py
INSTALLED_APPS = [
...
'project.app',
'django.contrib.staticfiles'
]顺序很重要,因为它指示哪个应用程序将重载另一个应用程序的管理命令。
project/app/management/commands/runserver.py
from django.core.management.commands.runserver import Command as BaseCommand
class Command(BaseCommand):
def __init__(self, *args, **kwargs):
try:
#test your connections
except SomeException as e:
#handle your error
super(BaseCommand, self).__init__(*args, **kwargs)这样,您的runserver命令总是在每次运行之前检查您的约束。如果不想运行该命令,还可以在except子句中重新修复错误。这导致初始化代码被运行两次,我不知道为什么。
如果您使用的是django-devserver,那么导入将变成:
from django_devserver.devserver.management.commands.runserver import Command as BaseCommandhttps://stackoverflow.com/questions/32884474
复制相似问题