python美多商城项目开发小结
项目总览
创建虚拟环境
mkvirtualenv meiduo_malls
创建项目
django-admin startproject meiduo_malls
pip install django
运行项目
python manage.py runserver [127.0.0.1:9000]
1.项目开发模式
选项 | 技术选型 |
---|---|
开发模式 | 前后端不分离 |
后端框架 | django + jinja2模板引擎 |
前端框架 | vue.js |
说明:
前后端不分离的开发模式,是为了提高搜索引擎排名,即seo。特别是首页,详情页和列表页。
页面需要整体刷新:我们会选择使用jinja2模板引擎来实现。
页面需要局部刷新:我们会选择使用vue.js来实现。
2. 项目运行机制
3. 知识要点
1.项目开发模式
- 前后端不分离,方便seo。
- 采用django + jinja2模板引擎 + vue.js实现前后端逻辑。
2.项目运行机制
- 代理服务:nginx服务器(反向代理)
- 静态服务:nginx服务器(静态首页、商品详情页、...)
- 动态服务:uwsgi服务器(美多商场业务场景)
- 后端服务:mysql、redis、celery、rabbitmq、docker、fastdfs、elasticsearch、crontab
- 外部接口:容联云、qq互联、支付宝
配置开发环境
美多商城项目的环境分为
开发环境:用于编写和调试项目代码。开发环境
和生产环境
。
生产环境:用于项目线上部署运行。
1. 新建配置文件
开发环境 主应用中新建setting包,dev.py,将原来的settings.py内容复制进去
然后修改manage.py的默认开发环境改为dev
生产环境
wsgi.py中修改默认生产环境prod
""" wsgi config for meiduo_malls project. it exposes the wsgi callable as a module-level variable named ``application``. for more information on this file, see https://docs.djangoproject.com/en/4.0/howto/deployment/wsgi/ import os from django.core.wsgi import get_wsgi_application os.environ.setdefault('django_settings_module', 'meiduo_malls.settings.prod') application = get_wsgi_application()
2. 配置jinja2模板引擎
pip install jinja2
修改配置文件中的模板配置
templates = [ { 'backend': 'django.template.backends.jinja2.jinja2',#配置jinja2 'dirs': [os.path.join(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', ], # 补充jinja2模板引擎环境 'environment': 'meiduo_malls.utils.jinja2_env.environment', }, }, { 'backend': 'django.template.backends.django.djangotemplates', 'dirs': [], ]
主应用中添加utils包 ->jinja2_env.py
from django.templatetags.static import static from django.urls import reverse from jinja2 import environment def environment(**options): env = environment(**options) env.globals.update({ 'static': static, 'url': reverse, }) return env """ 确保可以使用模板引擎中的{{ url('') }} {{ static('') }}这类语句 在配置模板处配置使用 此配置信息可在官网查找复制
最后一步配置pycharm,模板语言由django 改为jinja2
ssh root@82.157.143.241 连接linux
3.配置mysql
使用宝塔安装数据库
想要实现远程可以操控,腾讯云防火墙中添加规则3306,宝塔中防火墙也要添加放行端口3306
1.新建mysql数据库:meiduo_mall
$ create database meiduo charset=utf8;
2.新建mysql用户
$ create user itheima identified by '123456';
3.授权
itcast
用户访问meiduo_mall
数据库
$ grant all on meiduo.* to 'itheima'@'%';
4.授权结束后刷新特权
$ flush privileges;
配置数据库dev.py
# django数据迁移支持的mysql5.6以上 django框架生成的sql语句不兼容mysql5.5 # 以下代码兼容低版本mysql from django.db.backends.mysql.base import databasewrapper databasewrapper.data_types['datetimefield'] = 'datetime' databases = { 'default': { 'engine': 'django.db.backends.mysql', # 数据库引擎 'host': '82.157.143.241', # 数据库主机 'port': 3306, # 数据库端口 'user': 'itheima', # 数据库用户名 'password': '123456', # 数据库用户密码 'name': 'meiduo' # 数据库名字 # 采用数据库严格模式 'options': { 'charset': 'utf8mb4', 'autocommit': true, 'init_command': 'set sql_mode="strict_trans_tables"', } } }
安装驱动
pip install pymysql
工程的__init__.py中配置初始化
from pymysql import install_as_mysqldb install_as_mysqldb()
4.配置redis
pip install django-redis
django-redis使用说明文档
配置可以远程访问 /etc/redis.conf
#bind 127.0.0.1 ip注释掉
daemonize yes 后台运行
requirepass zndroid 设置密码
protected-mode no 保护模式设为no
远程访问的话记得宝塔和腾讯云都要放行6379端口
dos远程连接redis-cli -h 82.157.143.241 -a zndroid
caches = { "default": { # 默认 "backend": "django_redis.cache.rediscache", #"location": "redis://127.0.0.1:6379/0", "location": "redis://:zndroid@82.157.143.241:6379/0", "options": { "client_class": "django_redis.client.defaultclient", } }, "session": { # session "backend": "django_redis.cache.rediscache", "location": "redis://:zndroid@82.157.143.241:6379/1", "options": { "client_class": "django_redis.client.defaultclient", } }, } session_engine = "django.contrib.sessions.backends.cache" session_cache_alias = "session"
default:
- 默认的redis配置项,采用0号redis库。
session:
- 状态保持的redis配置项,采用1号redis库。
session_engine
- 修改
session存储机制
使用redis保存。
session_cache_alias:
- 使用名为"session"的redis配置项存储
session数据
。
5.配置工程日志
配置文件dev.py中添加
# 配置工程日志 logging = { 'version': 1, 'disable_existing_loggers': false, # 是否禁用已经存在的日志器 'formatters': { # 日志信息显示的格式 'verbose': { 'format': '%(levelname)s %(asctime)s %(module)s %(lineno)d %(message)s' }, 'simple': { 'format': '%(levelname)s %(module)s %(lineno)d %(message)s' }, }, 'filters': { # 对日志进行过滤 'require_debug_true': { # django在debug模式下才输出日志 '()': 'django.utils.log.requiredebugtrue', }, }, 'handlers': { # 日志处理方法 'console': { # 向终端中输出日志 'level': 'info', 'filters': ['require_debug_true'], 'class': 'logging.streamhandler', 'formatter': 'simple' }, 'file': { # 向文件中输出日志 'level': 'info', 'class': 'logging.handlers.rotatingfilehandler', 'filename': os.path.join(os.path.dirname(base_dir), 'logs/meiduo.log'), # 日志文件的位置 'maxbytes': 300 * 1024 * 1024, 'backupcount': 10, 'formatter': 'verbose' }, }, 'loggers': { # 日志器 'django': { # 定义了一个名为django的日志器 'handlers': ['console', 'file'], # 可以同时向终端与文件中输出日志 'propagate': true, # 是否继续传递日志信息 'level': 'info', # 日志器接收的最低日志级别 }, } }
且需要在项目的根目录中创建目录logs 创建meiduo.log文件和 .gitkeep文件(git的时候保证空目录也可以git过去)
此时git的时候logs文件夹是空目录,默认git是不允许提交一个空的目录到版本库上的
此时使用.gitkeep允许提交空目录
使用方式
import logging # 创建日志记录器 logger = logging.getlogger('django') # 输出日志 logger.debug('测试logging模块debug') logger.info('测试logging模块info') logger.error('测试logging模块error')
6.配置静态资源dev.py
static_url = '/static/' # 配置静态文件加载路径 staticfiles_dirs = [os.path.join(base_dir, 'static')]
到此这篇关于python美多商城一的文章就介绍到这了,更多相关python美多商城内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
上一篇: mysql中#{}和${}的区别详解
下一篇: Redis命令处理过程源码解析