django環(huán)境搭建已經(jīng)在django中已經(jīng)詳細的說明過了,這里不在贅述幽告,本節(jié)僅僅對django的數(shù)據(jù)庫設置腌且,緩存設置殖属,以及l(fā)og設置加以說明软啼。
本項目所有代碼均在碼云:https://gitee.com/maniuu/First
在django環(huán)境搭建中數(shù)據(jù)庫在setting文件中的設置非常重要桑谍,具體設置如下:
方法一:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql', # 數(shù)據(jù)庫引擎
'NAME': 'name', # 數(shù)據(jù)庫名
'USER': 'dj_user', # 用戶名
'PASSWORD': 'password', # 密碼
'HOST': '127.0.0.1', # 主機IP
'PORT': 3306 # 端口
}
}
方法二:將數(shù)據(jù)庫配置信息存到一個文件,在settings文件中將其引入祸挪。(推薦)
新建數(shù)據(jù)庫配置文件db.cnf(名字隨意)
db.cnf文件:
[client]
database = name
user = dj_user
password = password
host = 127.0.0.1
port = 3306
default-character-set = utf8
在settings.py文件中引入db.cnf
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'OPTIONS':{
'read_default_file': 'utils/db/db.cnf'
}
}
}
配置redis緩存
# 在虛擬機中安裝django-redis
pip install django-redis
# settings.py文件中指定redis配置
CACHES = {
"default": {
"BACKEND": "django_redis.cache.RedisCache",
"LOCATION": "redis://127.0.0.1:6379/0",
"OPTIONS": {
"CLIENT_CLASS": "django_redis.client.DefaultClient",
}
},
'session': {
'BACKEND': 'django_redis.cache.RedisCache',
'LOCATION': 'redis://127.0.0.1:6379/1',
'OPTIONS': {
'CLIENT_CLASS': 'django_redis.client.DefaultClient',
}
},
}
# session存儲緩存設置
SESSION_ENGINE = 'django.contrib.sessions.backends.cache'
SESSION_CACHE_ALIAS = 'session'
配置日志器
用于記錄系統(tǒng)運行過程中的各種日志信息锣披。
在項目根目錄中創(chuàng)建一個logs文件夾,用于存放日志文件
# 日志
LOGGING = {
# 版本
'version': 1,
# 是否禁用已存在的日志器
'disable_existing_loggers': False,
'formatters': {
'verbose': {
'format': '{levelname} {asctime} {module} {lineno:d} {message}',
'style': '{',
},
'simple': {
'format': '{levelname} {module} {lineno:d} {message}',
'style': '{',
},
},
'filters': {
'require_debug_true': {
'()': 'django.utils.log.RequireDebugTrue',
},
},
'handlers': {
'console': {
'level': 'DEBUG',
'filters': ['require_debug_true'],
'class': 'logging.StreamHandler',
'formatter': 'simple'
},
'file': {
'level': 'INFO',
# 這個handler可以記錄一組日志文件
'class': 'logging.handlers.RotatingFileHandler',
'filename': os.path.join(BASE_DIR, 'logs/tz_django.log'),
# 單個日志文件最大字節(jié)數(shù)
'maxBytes': 300*1024*1024,
# 日志文件個數(shù)
'backupCount': 10,
'formatter': 'verbose'
},
},
'loggers': {
'django': {
'handlers': ['console', 'file'],
'level': 'INFO', # 日志器接收的最低級別
'propagate': True,
},
},
}
使用方法
# 使用方法
# import the logging library
import logging
# Get an instance of a logger
# 此處的django為,settings.py文件中雹仿,LOGGING配置下的loggers中定義的日志器名稱
logger = logging.getLogger('django')
def my_view(request, arg1, arg):
...
if ***:
# Log an error message
logger.error('Something went wrong!')
創(chuàng)建應用:
在項目根目錄下創(chuàng)建一個apps目錄用于存放各子應用榜跌。
然后cd到apps目錄創(chuàng)建各子應用
~$ cd ~/code/apps/
~/code/tztz/apps$ workon tzproject
(project) ~/code/apps$ python ../manage.py startapp news
(project) ~/code/apps$ python ../manage.py startapp course
(project) ~/code/apps$ python ../manage.py startapp doc
(project) ~/code/apps$ python ../manage.py startapp user
再到settings文件中,加入如下設置
import sys
# 創(chuàng)建應用之后盅粪,把apps目錄加入到sys.path中
sys.path.insert(0, BASE_DIR)
sys.path.insert(1, os.path.join(BASE_DIR, 'apps'))
接著分別在apps文件夾和項目根目錄文件夾上右鍵,加入到Source Root中悄蕾,優(yōu)化導入路徑(pycharm提示)票顾。
項目文件右鍵菜單==>make directory as==>sources root
最后將應用添加到INSTALLED_APPS列表中
INSTALLED_APPS = [
# ...
'user',
'news',
'doc',
'course'
]
以上的這些設置基本都是固定的,沒有什么變化可言帆调,亦可在官網(wǎng)查詢得到奠骄。
最后完成配置,可以繼續(xù)開發(fā)或推送到碼云進行版本保存番刊。