Configurações do Django

Um arquivo de definições do Django contém todas as configurações da sua instalação do Django. Este documento explica como as configurações trabalham e quais definições estão disponíveis.

O básico

Um arquivo de definições é somente um módulo Python com variáveis de módulo.

Aqui alguns exemplos de definições:

ALLOWED_HOSTS = ["www.example.com"]
DEBUG = False
DEFAULT_FROM_EMAIL = "webmaster@example.com"

Nota

Se você definie o DEBUG para False, você também precisa definir a definição de ALLOWED_HOSTS.

Como o arquivo de definições é um módulo Python, o seguinte se aplica:

  • Ele não permite erros de sintaxe Python.

  • É possível assinalar definições dinamicamente usando sintaxe Python normalmente. Por exemplo:

    MY_SETTING = [str(i) for i in range(30)]
    
  • Pode importar valores de outros arquivos de definições.

Designando as definições

DJANGO_SETTINGS_MODULE

When you use Django, you have to tell it which settings you’re using. Do this by using an environment variable, DJANGO_SETTINGS_MODULE.

The value of DJANGO_SETTINGS_MODULE should be in Python path syntax, e.g. mysite.settings. Note that the settings module should be on the Python sys.path.

A ferramenta django-admin

Quando usar django-admin, você pode definir a variável de ambiente uam vez, ou passar explicitamente no módulo de definições cada vez que você rodar a ferramenta.

Example (Unix Bash shell):

export DJANGO_SETTINGS_MODULE=mysite.settings
django-admin runserver

Example (Windows shell):

set DJANGO_SETTINGS_MODULE=mysite.settings
django-admin runserver

Use the --settings command-line argument to specify the settings manually:

django-admin runserver --settings=mysite.settings

No servidor (mod_wsgi)

No seu ambiente do servidor de produção , você precisará dizer à sua aplicação WSGI qual arquivo de definições utilizar. Faça isso com os.environ:

import os

os.environ["DJANGO_SETTINGS_MODULE"] = "mysite.settings"

Leia a documentação do Django mod_wsgi para mais informações e outros elementos comuns para uma aplicação WSGI Django.

Definições padrão

A Django settings file doesn’t have to define any settings if it doesn’t need to. Each setting has a sensible default value. These defaults live in the module django/conf/global_settings.py.

Aqui está o algoritmo que o Django usa enquanto compila as definições:

  • Carrega as definições do global_settings.py.
  • Carrega as definições do arquivo de definições especificado, sobrescrevendo as definições globais quando necessário.

Note que o arquivo de definições não deve importar o global_settings, porque isso é redundante.

Vendo quais definições você alterou

The command python manage.py diffsettings displays differences between the current settings file and Django’s default settings.

Para mais detalhes, veja a documentação diffsettings.

Usando as definições em código Python

Nas suas apps Django, use as definições através da importação do objeto django.conf.settings. Exemplo:

from django.conf import settings

if settings.DEBUG:
    # Do something
    ...

Note que o django.conf.settings não é um módulo – é um objeto. Então não é possível importar definições individuais.

from django.conf.settings import DEBUG  # This won't work.

Também note que seu código não deve importar nem o global_settings nem seu próprio arquivo de definições. O django.conf.settings torna o conceito das definições padrão abstrato bem como as definições específicas do site; ele apresenta uma única interface. Ele também desacopla o código que usa as definições da localização das suas definições.

Alterando as definições em tempo de execução

Você não deve alterar as definições dentro de sua aplicação durante a execução. Por exemplo, não faça isso em uma “view”:

from django.conf import settings

settings.DEBUG = True  # Don't do this!

O único local onde você deve assinalar a definições é em um arquivo de definições.

Segurança

Because a settings file contains sensitive information, such as the database password, you should make every attempt to limit access to it. For example, change its file permissions so that only you and your web server’s user can read it. This is especially important in a shared-hosting environment.

Configurações disponíveis.

Para uma lista completa de configurações disponíveis, veja a referência de configurações.

Criando suas próprias configurações

There’s nothing stopping you from creating your own settings, for your own Django apps, but follow these guidelines:

  • Nomes de definições devem estar em maiúsculo.
  • Não reinvente uma configuração já existente.

Para definições que são sequências, mesmo o Django usa listas, mas isso é apenas uma convenção.

Using settings without setting DJANGO_SETTINGS_MODULE

In some cases, you might want to bypass the DJANGO_SETTINGS_MODULE environment variable. For example, if you’re using the template system by itself, you likely don’t want to have to set up an environment variable pointing to a settings module.

Nestes casos, você pode configurar manualmente as definições. Faça isso através da chamada:

django.conf.settings.configure(default_settings, **settings)

Exemplo

from django.conf import settings

settings.configure(DEBUG=True)

Passe ao configure() quantos argumentos nomeados você quiser, com cada argumento representando uma configuração e seu valor. Cada nome de argumento deve ser todo em maiúsculo, com o mesmo nome da configuração descrita acima. Se uma definição em particular não for passada para o configure() e e for necessária em algum ponto a diante, o Django irá usar o valor padrão para aquela configuração.

Configurando o Django desta maneira é sobretudo necessário – e, realmente, recomendado quando você está usando uma parte do framework dentro de uma aplicação maior.

Consequentemente, quando configurado através do settings.configure(), o Django não irá fazer qualquer modificação nas variáveis de ambiente do processo (veja a documentação do TIME_ZONE para o porque disso não ocorrer normalmente). Ele assume que você já está com todo o controle do seu ambiente nestes casos.

Definições padrão personalizadas

Se você quer que os valores padrão venham de algum outro lugar que não o django.conf.global_settings, você pode passar em um módulo ou classe que forneça as definições padrão como o argumento default_settings (ou como o primeiro argumento opcional) na chamada do configure().

Neste exemplo, definições padrão são pegas do myapp_defaults, e a definição de DEBUG é definida como True, apesar de seu valor em myapp_defaults:

from django.conf import settings
from myapp import myapp_defaults

settings.configure(default_settings=myapp_defaults, DEBUG=True)

O exemplo seguinte, o qual usa myapp_defaults como um argumento posicional, é equivalente:

settings.configure(myapp_defaults, DEBUG=True)

Normally, you will not need to override the defaults in this fashion. The Django defaults are sufficiently tame that you can safely use them. Be aware that if you do pass in a new default module, it entirely replaces the Django defaults, so you must specify a value for every possible setting that might be used in the code you are importing. Check in django.conf.settings.global_settings for the full list.

Either configure() or DJANGO_SETTINGS_MODULE is required

If you’re not setting the DJANGO_SETTINGS_MODULE environment variable, you must call configure() at some point before using any code that reads settings.

If you don’t set DJANGO_SETTINGS_MODULE and don’t call configure(), Django will raise an ImportError exception the first time a setting is accessed.

If you set DJANGO_SETTINGS_MODULE, access settings values somehow, then call configure(), Django will raise a RuntimeError indicating that settings have already been configured. There is a property for this purpose:

django.conf.settings.configured

Por exemplo:

from django.conf import settings

if not settings.configured:
    settings.configure(myapp_defaults, DEBUG=True)

E mais, é um erro chamar o configure() mais de uma vez, ou chamar o configure() depois que qualquer definição tenha sido acessada.

It boils down to this: Use exactly one of either configure() or DJANGO_SETTINGS_MODULE. Not both, and not neither.

É mandatório chamar o django.setup() para o usar o Django de modo “standalone”

Se você está usando componentes do Django de modo “standalone” – por exemplo, escreveu um script Python o qual carrega alguns templates Django e os renderiza, ou usa o ORM para ler alguns dados – existe mais um passo que é necessário além de configurar as definições.

Depois de definir ou o DJANGO_SETTINGS_MODULE ou chamado configure(), precisará chamar django.setup() para carregar suas definições e popular o registro da aplicação Django. Por exemplo:

import django
from django.conf import settings
from myapp import myapp_defaults

settings.configure(default_settings=myapp_defaults, DEBUG=True)
django.setup()

# Now this script or any imported module can use any part of Django it needs.
from myapp import models

Note that calling django.setup() is only necessary if your code is truly standalone. When invoked by your web server, or through django-admin, Django will handle this for you.

django.setup() deve ser chamado uma única vez.

Portanto, evite colocar lógica de aplicação reutilizável em scripts “standalone” de modo que tenha que importar o script em algum lugar da aplicação. Se você não puder evitar isso, coloque a chamada do django.setup() dentro de um bloco if:

if __name__ == "__main__":
    import django

    django.setup()

Ver também

A referência sobre configurações
Contém uma lista completa das configurações do “core” e das aplicações do “contrib”.
Back to Top