luffy项目01

1. 项目基础

1.1 企业中项目类型

1. 商城类的 --> 某某团 
2. 门户网站[企业站和门户站]
	- 新加坡企业推广 -- 游戏的展示页面
    - 展示页面
3. 社交网络 --> app后端
	- 擦边球...一堆女生,发图片视频,注册用户聊5句话,再聊冲会员...
    - 正规社交网络-Sanic框架-号称1亿用户量
   
4. 资讯论坛
	稀土掘金,抽屉,知乎,豆瓣...
    技术类论坛 --> 慢慢就开始卖课卖资料之类的
   
"5." 内部系统(一般出去做的最多的了)--python主要就是做这种类型的多
	- 办公管理
    - 人事管理
    - 进销存
    - 客户关系管理(crm)
    - 自动化运维项目
    - 自动化测试项目
   
6. 个人博客
7. 内容收费网站
	稀土掘金里面有小课
    拉钩教育...

1.2 企业项目开发流程

# 公司项目来源
	1. 公司需要自用
    2. 给客户定制(银行/医院/...)
    3. 互联网项目(针对整个互联网用户)
   
# 立项 --> 需求分析(来自于哪里取决与项目来源/互联网项目的话就是源于产品经理的把控了/其他方面的产品经理就没有什么技术可言) --> 产品原型(画原型/原型图软件axure等等) --> 
分两支 -- 前端 和 后端
# 前端团队---根据原型图:ui+前端 --> ui根据原型图画图(ui的切图)  --> 前端去实现 --> mock数据(自己造的假数据)

# 后端团队:开会确定确立项目架构,技术选型(基本就是沿用公司一直的技术栈,不会轻易去换) --> 需求说明书+原型图 --> 开发接口,自己测试 --> 接口文档

# 前后端代码整合 --> 前后端联调 --> 集成测试(测试部门/质量控制部)

# 上线发布

"我以后面试该聊的工作流程就是:"
在公司项目管理平台(禅道,国内中小型公司用的多;jira) --> 查看自己的任务 --> 确定需求(千万要搞懂之后再开始,不懂就问清楚:测试/问领导/问同事/) --> 写代码 --> 提交到git仓库 --> 管理平台把需求设置成 完成


# 刚去公司困惑的点就是业务需求 -- 就是对业务不清楚


"软件开发模式(可以写在简历上了解敏捷开发的流程)"
	- 瀑布模式:早期被广泛采用的软件开发模型 --> bbs项目
    - 敏捷开发(现在很火) --> 不停的开发 -- 测试 -- 上线 转圈
    	# scrum --> sprint周期(小功能从开发到完成的时间) --> 基本上就是一周搞定一个版块
     
    - 路飞--先不做整体数据库的设计 --> 写到哪个板块,再去设计相关表
   
# 路飞项目没有将太多功能,只是带你熟悉项目开发流程
# 需求
	- 首页轮播图
    - 登录注册
    	- 多方式登录
        - 手机号登录
        - 手机号注册
    - 课程列表功能
    	- 过滤
        - 排序
    - 课程详情
    	- 视频播放,课程介绍
    - 下单 --> 支付
    	- 支付宝支付
    - 回调修改订单
    
    - 上线
    

image

image

2. pip换源

# pip install 的时候 pypi源地址去下载,在国外,比较慢 --> 镜像(pypi在国内备份) --> 豆瓣,清华,阿里

# pip install -i 源地址 模块名 --> 临时生效

# 想要以后只要pip install 不用指定模块名,以后直接去国内镜像站下载

# 配置一下永久生效
"win平台"
[global]
index-url = http://pypi.douban.com/simple
[install]
user-mirrors =true
mirrors =http://pypi.douban.com/simple/
trusted-host =pypi.douban.com


"mac/linux"
1、在用户根目录下 ~ 下创建 .pip 隐藏文件夹,如果已经有了可以跳过
	-- mkdir ~/.pip
2、进入 .pip 隐藏文件夹并创建 pip.conf 配置文件
	-- cd ~/.pip && touch pip.conf
3、启动 Finder(访达) 按 cmd+shift+g 来的进入,输入 ~/.pip 回车进入
4、新增 pip.conf 配置文件内容


"pycharm最好配置多个源,豆瓣源现在不是很稳定"
# pycharm更换之后只针对于在pycharm当中使用。

# pypi python官方模块站点,我们个人也可以传模块
	- 注册账号
    - 写一个模块
    - setup.py
    - 上传

image

image

image

3. 虚拟环境介绍和搭建

3.1 pycharm设置虚拟环境

# 为什么会出现虚拟环境?
	- 假设有个项目django 1.11.8
    - 又有一个项目django 2.2.2
    - 由于在系统的解释器上只能装一个django,导致同时只能跑一个项目
    - 每个项目使用自己的一个解释器 --> 虚拟环境 -> 通过系统解释器创造出一个解释器环境,他俩相互不干扰
    - 系统有个解释器,第一个项目有个虚拟环境 django 1.11.8,第二个项目有个虚拟环境 django 2.2.2
    - 以后就变成,一个项目一个解释器,一个系统解释器一堆虚拟环境,这样他们之间的模块不会互相冲突了
    
   
# 其他语言相关方案
	- vue 项目路径下 -> node_modules --> 就是这个项目依赖的环境 -> 删除 -> 再 npm install 可以再装上
    - go:go mod解决多版本共存的问题
    - Java:maven解决多版本jar包的问题
    - python:使用虚拟环境
   
# python中虚拟环境解决方案有好几个(virtualenv,...)

# 如果不使用virtualenv,可以直接在pycharm中用

image

3.2 命令方式操作虚拟环境

3.2.1 win安装
# centos 没有图像化界面的话 --没办法安装pycharm --就没法点点点创建,只能只用命令

# 虚拟环境,命令的配置方案
# win环境
1. 安装
pip3 install virtualenv  # 虚拟环境模块(创建虚拟环境麻烦)
pip3 install virtualenvwrapper-win  # 虚拟环境辅助模块(更快捷方便的操作和管理虚拟环境)
安装完在scripts文件夹下会有virtualenv.exe 和 vir....bat批处理文件
# 而你的scripts文件夹又在环境变量里 --> 所以这两个命令可以在任意路径下执行

2. 配置环境
找到用户的环境变量 -- 新建
WORKON_HOME: D:/Virtualenv
然后创建出来这个文件夹
# 
# 同步配置信息:
# 去向Python3的安装目录 => Scripts文件夹 => virtualenvwrapper.bat => 双击

# 虚拟环境命令


"补充!!!!!"
环境变量:在命令行下敲某个命令,为什么能执行???要么这个命令就在当前路径下,要么就在环境变量的path当中,能找到就执行,找不到就报错
# 环境变量有两种
1. 系统环境变量 -- 所有人都有效
2. 用户环境变量 -- 当前用户有效

敲python --> 你得确认好,python到底是python2,python3,还是你虚拟环境的python3
根据你的环境变量的上下顺序
# pip 和python是成对的,装的模块,给python解释器用的
	pip install django  你也不知道安装到哪个python解释器上了
    
# 最简单的就是本地只装一个环境,然后配置一些虚拟环境

# 也可以通过起别名的方式来多版本共存
"退出:deactivate"
"删除虚拟环境:可以去文件夹下,也可以:rmvirtualenv"
3.3.2 mac/linux配置虚拟环境
# mac和linux
## 第一步安装
pip3 install -i https://pypi.douban.com/simple virtualenv
pip3 install -i https://pypi.douban.com/simple virtualenvwrapper
## 第二步:找到virtualenvwrapper
先找到virtualenvwrapper的工作文件 virtualenvwrapper.sh,该文件可以刷新自定义配置,但需要找到它
MacOS可能存在的位置 /Library/Frameworks/Python.framework/Versions/版本号文件夹/bin
Linux可能所在的位置 /usr/local/bin  |  ~/.local/bin  |  /usr/bin
建议不管virtualenvwrapper.sh在哪个目录,保证在 /usr/local/bin 目录下有一份
如果不在 /usr/local/bin 目录,如在 ~/.local/bin 目录,则复制一份到 /usr/local/bin 目录
	-- sudo cp -rf ~/.local/bin/virtualenvwrapper.sh /usr/local/bin

### 第三步:配置环境变量
# 在 ~/.bash_profile 完成配置,virtualenvwrapper的默认默认存放虚拟环境路径是 ~/.virtualenvs
# WORKON_HOME=自定义存放虚拟环境的绝对路径,需要自定义就解注
VIRTUALENVWRAPPER_PYTHON=/usr/local/bin/python3
source /usr/local/bin/virtualenvwrapper.sh

# 在终端让配置生效:
	-- source ~/.bash_profile

3.3 虚拟环境命令

##  虚拟环境命令
# 1、创建虚拟环境到配置的WORKON_HOME路径下
# 选取默认Python环境创建虚拟环境:
	-- mkvirtualenv 虚拟环境名称
# 基于某Python环境创建虚拟环境,并进入到虚拟环境:
	-- mkvirtualenv -p python2.7 虚拟环境名称
	-- mkvirtualenv -p python3.6 虚拟环境名称

# 2、查看已有的虚拟环境
	-- workon

# 3、使用某个虚拟环境
	-- workon 虚拟环境名称
	
# 4、进入|退出 该虚拟环境的Python环境
	-- python | exit()

# 5、为虚拟环境安装模块
	-- pip或pip3 install 模块名

# 6、退出当前虚拟环境
	-- deactivate

# 7、删除虚拟环境(删除当前虚拟环境要先退出)
	-- rmvirtualenv 虚拟环境名称

4. luffy后台创建和目录调整

# 创建路飞项目

# 1. 进入luffy虚拟环境安装django
# 2. 使用pycharm创建后台路飞项目,使用已存在的虚拟环境的python解释器
	existing interpreter
    
	system interpreter
    
# django2.2.2
# djangorestframework
# pycharm装不上的时候用命令装
"千万注意,环境不要搞乱了"


# 第三步,调整目录
	# 调整配置文件
	- 把配置文件移动到setting文件夹下,改名为dev.py,又新建一个pro.py
    - dev.py:开发阶段用的配置
    - pro.py:上线阶段用的配置
    - manage.py中指向的配置文件,改成咱们修改后的路径
    - 控制台:python manage.py runserver 或者绿色箭头就可以启动项目了
    
    # 调整app的路径,以后把所有app都放到luffy_api/apps文件夹 --> 看上去整洁
    - 切换到apps路径下,执行创建app的命令
    	-python ../../manage.py startapp user
    - 在dev.py中注册app,运行报错,报错原因是找不到user模块
    - 原来直接写app名字不报错,原因是app就在项目根路径下(模块的查找)--> 由于项目的根路径在环境变量中,app就在根路径下,他直接能找到
    - 现在的问题是apps路径不在环境变量中,他就找不到
    - 把apps的路径加入到环境变量中 -- 要在项目的启动时加 -- 启动入口在配置文件中
    	到配置文件中写入
        sys.path.append(os.path.join(BASE_DIR, 'apps'))
    # 以后再install_apps中只需要写app的名字即可
    # 当然也可以在配置文件注册app里面更改app路径即可
  
# 新建logs文件夹,luffy_api/lib文件夹,luffy_api/utils,script文件夹

# 测试阶段运行没问题,项目上线,使用uwsgi上线 --> 运行wsgi.py
也要更改其配置
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'luffy_api.setting.pro')

# 项目目录结构如下:
"""
├── luffy_api
  ├── logs/				      # 项目运行时/开发时日志目录 - 包
  ├── luffy_api/      # 项目主应用,开发时的代码保存 - 包
      ├── apps/      		# 开发者的代码保存目录,以模块[子应用]为目录保存 - 包
      ├── libs/      		# 第三方类库的保存目录[第三方组件、模块] - 包
      ├── setting/  		# 配置目录 - 包
			├── dev.py   	 # 项目开发时的本地配置
			└── prod.py  	 # 项目上线时的运行配置
	  ├── urls.py    		 # 总路由
	  └── utils/     		 # 多个模块[子应用]的公共函数类库[自己开发的组件]
  ├── manage.py			   # 脚本文件
  └── scripts/       	# 保存项目运营时的脚本文件 - 文件夹
"""


# 国际化,改中文
zh-hans
Asia/Shanghai
USE_TZ = False

======================
# dev.py
sys.path.append(BASE_DIR)
# 把这个也加入到环境变量
导入模块的时候,只要从环境的路径开始导就可以,从小luffy_api开始导入即可,但是pycharm会飘红,但是没错,点右键,把改路径(在环境变量中的),做成source root即可

"注意:"以后导入包
	尽量用最短路径导入
    如果从长路径导入,只要经过的py文件都会去执行,可能会导致循环导入的问题
    # 个人推荐用相对导入
    
    # py文件中有相对导入,这个py文件不能作为脚本运行
    	django项目中,由于没有右键运行的脚本,所以都可以用相对导入。
        

image

image

5. luffy后台配置

5.1 配置日志

在配置文件中加入:

"笔记copy"
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.utils.log.RequireDebugTrue',
        },
    },
    'handlers': {
        'console': {
            # 实际开发建议使用WARNING
            'level': 'DEBUG',
            'filters': ['require_debug_true'],
            'class': 'logging.StreamHandler',
            'formatter': 'simple'
        },
        'file': {
            # 实际开发建议使用ERROR
            'level': 'INFO',
            'class': 'logging.handlers.RotatingFileHandler',
            # 日志位置,日志文件名,日志保存目录必须手动创建,注:这里的文件路径要注意BASE_DIR代表的是小luffyapi
            'filename': os.path.join(os.path.dirname(BASE_DIR), "logs", "luffy.log"),
            # 日志文件的最大值,这里我们设置300M
            'maxBytes': 300 * 1024 * 1024,
            # 日志文件的数量,设置最大日志数量为10
            'backupCount': 10,
            # 日志格式:详细格式
            'formatter': 'verbose',
            # 文件内容编码
            'encoding': 'utf-8'
        },
    },
    # 日志对象
    'loggers': {
        'django': {
            'handlers': ['console', 'file'],
            'propagate': True, # 是否让日志信息继续冒泡给其他的日志处理系统
        },
    }
}


# utils/logging.py == 名字冲突了 改成了mylogging.py
# 创造一个logger对象,使用的是配置文件中的django这个
import logging
logger = logging.getLogger('django')

# 以后使用,直接导入
from utils.logging import logger
logger.info('xxxxxxx')

5.2 处理异常

# utils/exception.py


第一步:写一个函数
from utils.logging import logger
from rest_framework.views import exception_handler  # 默认没有配置,出了异常会走它
from rest_framework.response import Response


def common_exception_handler(exc, context):
    
    res = exception_handler(exc, context)
    if res: 
        res = Response(data={'code': 998, 'msg': res.data.get('detail', '服务器异常,请联系系统管理员')})
    else:
       
        res = Response(data={'code': 999, 'msg': str(exc)})

    # 注意:咱们在这里,可以记录日志---》只要走到这,说明程序报错了,记录日志,以后查日志---》尽量详细

    request = context.get('request')
    view = context.get('view')
    logger.error('错误原因:%s,错误视图类:%s,请求地址:%s,请求方式:%s' % (str(exc), str(view), request.path, request.method))
    return res




# 配置文件中配置dev.py

REST_FRAMEWORK = {
    'EXCEPTION_HANDLER': 'utils.exception.common_exception_handler'
}
posted @ 2022-04-19 08:14  Joshua_jiaxue  阅读(34)  评论(0编辑  收藏  举报