python美多商城项目开发小结

 更新时间:2022年02月16日 15:34:55   作者:皮阿玛  
这篇文章主要介绍了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美多商城内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 初步介绍Python中的pydoc模块和distutils模块

    初步介绍Python中的pydoc模块和distutils模块

    这篇文章主要介绍了Python中的pydoc模块和distutils模块,本文来自于IBM官方开发者技术文档,需要的朋友可以参考下
    2015-04-04
  • Python hexstring-list-str之间的转换方法

    Python hexstring-list-str之间的转换方法

    今天小编就为大家分享一篇Python hexstring-list-str之间的转换方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-06-06
  • python装饰器底层原理详解

    python装饰器底层原理详解

    这篇文章主要介绍了python装饰器底层原理讲解,被装饰对象加上装饰器,被装饰对象获得了更强大的功能,更多相关内容,需要的朋友可以参考一下
    2022-07-07
  • 在VSCode中添加Python解释器并安装Python库的方法

    在VSCode中添加Python解释器并安装Python库的方法

    这篇文章主要介绍了在VSCode中添加Python解释器并安装Python库的方法,本文分步骤通过图文并茂的形式给大家介绍的非常详细,需要的朋友可以参考下
    2023-02-02
  • python重试装饰器示例

    python重试装饰器示例

    python 写一些网络服务的时候总会抛出一些异常,当前任务就被终止了,利用@装饰器,写一个重试的装饰器,下面是实现示例,需要的朋友可以参考下
    2014-02-02
  • Django使用AJAX调用自己写的API接口的方法

    Django使用AJAX调用自己写的API接口的方法

    这篇文章主要介绍了Django使用AJAX调用自己写的API接口的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-03-03
  • PyTorch TensorFlow机器学习框架选择实战

    PyTorch TensorFlow机器学习框架选择实战

    这篇文章主要为大家介绍了PyTorch TensorFlow机器学习框架选择实战,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-10-10
  • python 牛顿法实现逻辑回归(Logistic Regression)

    python 牛顿法实现逻辑回归(Logistic Regression)

    这篇文章主要介绍了python 牛顿法实现逻辑回归(Logistic Regression),帮助大家更好的进行机器学习,感兴趣的朋友可以了解下
    2020-10-10
  • 用Python实现写倒序输出(任意位数)

    用Python实现写倒序输出(任意位数)

    这篇文章主要介绍了用Python实现写倒序输出(任意位数),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-05-05
  • Python多进程multiprocessing、进程池用法实例分析

    Python多进程multiprocessing、进程池用法实例分析

    这篇文章主要介绍了Python多进程multiprocessing、进程池用法,结合实例形式分析了Python多进程multiprocessing、进程池相关概念、原理、用法及操作注意事项,需要的朋友可以参考下
    2020-03-03

最新评论