django环境搭建已经在django中已经详细的说明过了,这里不在赘述,本节仅仅对django的数据库设置,缓存设置,以及log设置加以说明。
本项目所有代码均在码云:https://gitee.com/maniuu/First
在django环境搭建中数据库在setting文件中的设置非常重要,具体设置如下:
方法一:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql', # 数据库引擎
'NAME': 'name', # 数据库名
'USER': 'dj_user', # 用户名
'PASSWORD': 'password', # 密码
'HOST': '127.0.0.1', # 主机IP
'PORT': 3306 # 端口
}
}
方法二:将数据库配置信息存到一个文件,在settings文件中将其引入。(推荐)
新建数据库配置文件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'
配置日志器
用于记录系统运行过程中的各种日志信息。
在项目根目录中创建一个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'),
# 单个日志文件最大字节数
'maxBytes': 300*1024*1024,
# 日志文件个数
'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!')
创建应用:
在项目根目录下创建一个apps目录用于存放各子应用。
然后cd到apps目录创建各子应用
~$ 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
# 创建应用之后,把apps目录加入到sys.path中
sys.path.insert(0, BASE_DIR)
sys.path.insert(1, os.path.join(BASE_DIR, 'apps'))
接着分别在apps文件夹和项目根目录文件夹上右键,加入到Source Root中,优化导入路径(pycharm提示)。
项目文件右键菜单==>make directory as==>sources root
最后将应用添加到INSTALLED_APPS列表中
INSTALLED_APPS = [
# ...
'user',
'news',
'doc',
'course'
]
以上的这些设置基本都是固定的,没有什么变化可言,亦可在官网查询得到。
最后完成配置,可以继续开发或推送到码云进行版本保存。