227 lines
		
	
	
		
			6.7 KiB
		
	
	
	
		
			Python
		
	
	
	
			
		
		
	
	
			227 lines
		
	
	
		
			6.7 KiB
		
	
	
	
		
			Python
		
	
	
	
| """
 | ||
| Django settings for mysite project.
 | ||
| 
 | ||
| Generated by 'django-admin startproject' using Django 1.11.3.
 | ||
| 
 | ||
| For more information on this file, see
 | ||
| https://docs.djangoproject.com/en/1.11/topics/settings/
 | ||
| 
 | ||
| For the full list of settings and their values, see
 | ||
| https://docs.djangoproject.com/en/1.11/ref/settings/
 | ||
| """
 | ||
| 
 | ||
| import os,time
 | ||
| import psycopg2.extensions
 | ||
| 
 | ||
| # Build paths inside the project like this: os.path.join(BASE_DIR, ...)
 | ||
| BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
 | ||
| 
 | ||
| 
 | ||
| # Quick-start development settings - unsuitable for production
 | ||
| # See https://docs.djangoproject.com/en/1.11/howto/deployment/checklist/
 | ||
| 
 | ||
| # SECURITY WARNING: keep the secret key used in production secret!
 | ||
| SECRET_KEY = '^2_d@h7#j5zx4=g+!=r&tdmm&)akpd_hf!7@-85#qs(+*(#o!i'
 | ||
| 
 | ||
| # SECURITY WARNING: don't run with debug turned on in production!
 | ||
| DEBUG = True
 | ||
| 
 | ||
| ALLOWED_HOSTS = ['10.7.100.160','10.7.100.250','192.168.0.100','127.0.0.1','114.115.210.98','safeyun.ctcshe.com','ctcshe.com','localhost','192.168.0.102','10.7.100.209']
 | ||
| 
 | ||
| # Application definition
 | ||
| 
 | ||
| INSTALLED_APPS = [
 | ||
|     'django.contrib.admin',
 | ||
|     'django.contrib.auth',
 | ||
|     'django.contrib.contenttypes',
 | ||
|     'django.contrib.sessions',
 | ||
|     'django.contrib.messages',
 | ||
|     'django.contrib.staticfiles',
 | ||
|     'safesite',
 | ||
|     'groups',
 | ||
|     'captcha',
 | ||
| ]
 | ||
| 
 | ||
| MIDDLEWARE = [
 | ||
|     'django.middleware.security.SecurityMiddleware',
 | ||
|     'django.contrib.sessions.middleware.SessionMiddleware',
 | ||
|     'django.middleware.common.CommonMiddleware',
 | ||
|     #'django.middleware.csrf.CsrfViewMiddleware',
 | ||
|     'django.contrib.auth.middleware.AuthenticationMiddleware',
 | ||
|     'django.contrib.messages.middleware.MessageMiddleware',
 | ||
|     'django.middleware.clickjacking.XFrameOptionsMiddleware',
 | ||
| ]
 | ||
| 
 | ||
| ROOT_URLCONF = 'mysite.urls'
 | ||
| 
 | ||
| TEMPLATES = [
 | ||
|     {
 | ||
|         'BACKEND': 'django.template.backends.django.DjangoTemplates',
 | ||
|         'DIRS': [BASE_DIR+"/templates",],
 | ||
|         'APP_DIRS': True,
 | ||
|         'OPTIONS': {
 | ||
|             'context_processors': [
 | ||
|                 'django.template.context_processors.debug',
 | ||
|                 'django.template.context_processors.request',
 | ||
|                 'django.contrib.auth.context_processors.auth',
 | ||
|                 'django.contrib.messages.context_processors.messages',
 | ||
|             ],
 | ||
|         },
 | ||
|     },
 | ||
| ]
 | ||
| 
 | ||
| WSGI_APPLICATION = 'mysite.wsgi.application'
 | ||
| 
 | ||
| 
 | ||
| # Database
 | ||
| # https://docs.djangoproject.com/en/1.11/ref/settings/#databases
 | ||
| 
 | ||
| DATABASES = {
 | ||
|    # 'default': {
 | ||
|         # 'ENGINE': 'django.db.backends.sqlite3',
 | ||
|         # 'NAME': os.path.join(BASE_DIR, 'safe.db'),
 | ||
|     # },
 | ||
|     'default': {
 | ||
|         'ENGINE': 'django.db.backends.postgresql',
 | ||
|         'NAME': 'safedb',
 | ||
|         'USER':'postgres',
 | ||
|         'PASSWORD':'0000',
 | ||
|         'HOST':'114.115.210.98',
 | ||
|         'PORT':'5432',
 | ||
|         'CONN_MAX_AGE': 600,
 | ||
|     },
 | ||
|     'OPTIONS': {
 | ||
|         'isolation_level': psycopg2.extensions.ISOLATION_LEVEL_SERIALIZABLE,
 | ||
|     },
 | ||
| }
 | ||
| 
 | ||
| 
 | ||
| # Password validation
 | ||
| # https://docs.djangoproject.com/en/1.11/ref/settings/#auth-password-validators
 | ||
| 
 | ||
| AUTH_PASSWORD_VALIDATORS = [
 | ||
|     {
 | ||
|         'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
 | ||
|     },
 | ||
|     {
 | ||
|         'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
 | ||
|     },
 | ||
|     {
 | ||
|         'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
 | ||
|     },
 | ||
|     {
 | ||
|         'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
 | ||
|     },
 | ||
| ]
 | ||
| 
 | ||
| 
 | ||
| # Internationalization
 | ||
| # https://docs.djangoproject.com/en/1.11/topics/i18n/
 | ||
| 
 | ||
| LANGUAGE_CODE = 'zh-hans'
 | ||
| 
 | ||
| TIME_ZONE = 'Asia/Shanghai'
 | ||
| 
 | ||
| USE_I18N = True
 | ||
| 
 | ||
| USE_L10N = True
 | ||
| 
 | ||
| USE_TZ = False
 | ||
| 
 | ||
| 
 | ||
| # Static files (CSS, JavaScript, Images)
 | ||
| # https://docs.djangoproject.com/en/1.11/howto/static-files/
 | ||
| 
 | ||
| STATIC_URL = '/static/'
 | ||
| STATIC_ROOT = os.path.join(BASE_DIR, 'static')
 | ||
| MEDIA_ROOT = os.path.join(BASE_DIR, 'media')
 | ||
| MEDIA_URL = '/media/'
 | ||
| 
 | ||
| ###配置Broker
 | ||
| CELERY_BROKER_URL = 'redis://127.0.0.1:6379/0'
 | ||
| CELERY_BROKER_TRANSPORT = 'redis'
 | ||
| CELERYD_MAX_TASKS_PER_CHILD = 10
 | ||
| CELERY_TIMEZONE='Asia/Shanghai' 
 | ||
| CELERY_ENABLE_UTC=True
 | ||
| 
 | ||
| ##配置session
 | ||
| SESSION_EXPIRE_AT_BROWSER_CLOSE =  True
 | ||
| SESSION_COOKIE_AGE = 1800
 | ||
| SESSION_SAVE_EVERY_REQUEST = True
 | ||
| 
 | ||
| #日志配置
 | ||
| # 创建日志的路径
 | ||
| LOG_PATH = os.path.join(BASE_DIR, 'log')
 | ||
| # 如果地址不存在,则自动创建log文件夹
 | ||
| if not os.path.join(LOG_PATH):
 | ||
|     os.mkdir(LOG_PATH)
 | ||
| LOGGING = {
 | ||
|     'version': 1,
 | ||
|     'disable_existing_loggers': True,
 | ||
|     'formatters': {
 | ||
|         # 日志格式
 | ||
|         'standard': {
 | ||
|             'format': '[%(asctime)s] [%(filename)s:%(lineno)d] [%(module)s:%(funcName)s] '
 | ||
|                       '[%(levelname)s]- %(message)s'},
 | ||
|         'simple': {  # 简单格式
 | ||
|             'format': '%(levelname)s %(message)s'
 | ||
|         },
 | ||
|     },
 | ||
|     # 过滤
 | ||
|     'filters': {
 | ||
|     },
 | ||
|     # 定义具体处理日志的方式
 | ||
|     'handlers': {
 | ||
|         # 默认记录所有日志
 | ||
|         'default': {
 | ||
|             'level': 'INFO',
 | ||
|             'class': 'logging.handlers.RotatingFileHandler',
 | ||
|             'filename': os.path.join(LOG_PATH, 'all-{}.log'.format(time.strftime('%Y-%m-%d'))),
 | ||
|             'maxBytes': 1024 * 1024 * 5,  # 文件大小
 | ||
|             'backupCount': 5,  # 备份数
 | ||
|             'formatter': 'standard',  # 输出格式
 | ||
|             'encoding': 'utf-8',  # 设置默认编码,否则打印出来汉字乱码
 | ||
|         },
 | ||
|         # 输出错误日志
 | ||
|         'error': {
 | ||
|             'level': 'ERROR',
 | ||
|             'class': 'logging.handlers.RotatingFileHandler',
 | ||
|             'filename': os.path.join(LOG_PATH, 'error-{}.log'.format(time.strftime('%Y-%m-%d'))),
 | ||
|             'maxBytes': 1024 * 1024 * 5,  # 文件大小
 | ||
|             'backupCount': 5,  # 备份数
 | ||
|             'formatter': 'standard',  # 输出格式
 | ||
|             'encoding': 'utf-8',  # 设置默认编码
 | ||
|         },
 | ||
|         # 控制台输出
 | ||
|         'console': {
 | ||
|             'level': 'DEBUG',
 | ||
|             'class': 'logging.StreamHandler',
 | ||
|             'formatter': 'standard'
 | ||
|         },
 | ||
|         # 输出info日志
 | ||
|         'info': {
 | ||
|             'level': 'INFO',
 | ||
|             'class': 'logging.handlers.RotatingFileHandler',
 | ||
|             'filename': os.path.join(LOG_PATH, 'info-{}.log'.format(time.strftime('%Y-%m-%d'))),
 | ||
|             'maxBytes': 1024 * 1024 * 5,
 | ||
|             'backupCount': 5,
 | ||
|             'formatter': 'standard',
 | ||
|             'encoding': 'utf-8',  # 设置默认编码
 | ||
|         },
 | ||
|     },
 | ||
|     # 配置用哪几种 handlers 来处理日志
 | ||
|     'loggers': {
 | ||
|         # 类型 为 django 处理所有类型的日志, 默认调用
 | ||
|         'django': {
 | ||
|             'handlers': ['default', 'console'],
 | ||
|             'level': 'INFO',
 | ||
|             'propagate': False
 | ||
|         },
 | ||
|         # log 调用时需要当作参数传入
 | ||
|         'log': {
 | ||
|             'handlers': ['error', 'info', 'console', 'default'],
 | ||
|             'level': 'INFO',
 | ||
|             'propagate': True
 | ||
|         },
 | ||
|     }
 | ||
| } |