相思资源网 Design By www.200059.com
这篇文章主要介绍了python manage.py runserver流程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
版本
- python27
- django 1.0
搭建可运行的环境
创建python27 虚拟环境
github 下载 django-1.0.tar.gz(1.0 版本的django)
解压
可以看到,有个 demo 在 examples 目录
把 django 目录拷贝到 examples 下面,这样 example 可以正确导入 django1.0
启动项目
python manage.py runserver
项目启动成功,可以修改代码来跟踪执行流程
流程
以下代码存在删减,主要展示代码流程
从 manage.py 开始,执行了 execute_manager 方法,传入 settings 模块
execute_manager(settings)
django.core.management.execute_manager 方法
def execute_manager(settings_mod, argv=None): # setup_environ 函数,只是设置了环境变量,执行配置模块 # os.environ['DJANGO_SETTINGS_MODULE'] = examples.settting setup_environ(settings_mod) # admin manage 工具类 utility = ManagementUtility(argv) utility.execute()
ManagementUtility 类
class ManagementUtility(object): def __init__(self, argv=None): # 初始化,例如 self.argv = ['.../examples/manage.py', 'runserver'] self.prog_name = 'manage.py' def execute(self): # 删除了部分代码,最终执行代码大致如下 # 这是一个命令行工具类,表名能接受什么样的参数,这里主要检查两个参数 # --settings 指定配置文件 # --pythonpath 执行 python 环境变量 parser = LaxOptionParser(usage="%prog subcommand [options] [args]", version=get_version(), option_list=BaseCommand.option_list) # 使用命令行工具类解析命令行参数,也就是获取 --settings 和 --pythonpath 的参数值 options, args = parser.parse_args(self.argv) # 如果 --settings 参数存在,会覆盖之前设置的 os.environ['DJANGO_SETTINGS_MODULE'] # 如果 --pythonpath 参数存在,会把指定路径添加到 sys.path 的第一位,优先从此处加载模块 handle_default_options(options) # fetch_command # fetch_command 分析在下边 # fetch_command 返回 django.core.management.commands.runserver.Command # run_from_argv # run_from_argv 分析在下边 self.fetch_command(subcommand).run_from_argv(self.argv) def fetch_command(self, subcommand): # get_commands # get_commands 返回 django.core.management.commands 目录下的所有模块,每个模块处理对应的参数 # 每个模块的值都是 django.core,app_name = 'django.core' app_name = get_commands()[subcommand] # load_command_class 方法 # 返回了 django.core.management.commands.runserver.Command klass = load_command_class(app_name, subcommand) return klass
run_from_argv 方法
# django.core.management.commands.runserver.Command # 继承 django.core.management.base import BaseCommand # run_from_argv 也是继承的 def run_from_argv(self, argv): # 调用 execute self.execute(*args, **options.__dict__) def execute(self, *args, **options): # 调用 handle # 注意 handle 被重写了 # 调用的是 django.core.management.commands.runserver.Command.handle output = self.handle(*args, **options)
handle
def handle(self, addrport='', *args, **options): def inner_run(): # WSGI 处理程序 # WSGIHandler 可调用,是 WSGI 处理程序 # AdminMediaHandler 是对 WSGIHandler 的封装 # AdminMediaHandler 特殊处理媒体文件请求 # AdminMediaHandler 非媒体文件的 HTTP 请求,直接返回 WSGIHandler handler = AdminMediaHandler(WSGIHandler(), path) # run(addr, int(port), handler) # run 在 django.core.servers.basehttp.run # run 定义如下 # run 启动了 HTTP 服务,这个服务器只能用于开发调试 def run(addr, port, wsgi_handler): # 绑定地址端口 server_address = (addr, port) # 服务实例 httpd = WSGIServer(server_address, WSGIRequestHandler) # 传入 WSGI 处理程序 httpd.set_app(wsgi_handler) # 监听请求 httpd.serve_forever() inner_run()
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
相思资源网 Design By www.200059.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
相思资源网 Design By www.200059.com
暂无python manage.py runserver流程解析的评论...
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?