皮皮网

【新荣耀程序源码】【snap源码】【etracing源码】nginx源码注释

2025-01-20 00:20:45 来源:朝夕不倦指标源码

1.LNMP LNMPA 504 Gateway Time-out错误解决方法
2.树莓派4B 64bit 8GB 启动配置(换源/Miniconda/SSH/Xrdp远程桌面/仪表盘/固件更新)
3.如何安装nginx
4.django如何启动服务器(部署django到服务器)

nginx源码注释

LNMP LNMPA 504 Gateway Time-out错误解决方法

       systems的码注VPS放那里很久没用,刚好W2被停了一些时日,码注实在无聊,码注想把美女还是码注放在上面,所以,码注直接卡擦重装了systems的码注新荣耀程序源码VPS的系统,$刀的码注小内存,自然不弄面板了,码注直接LNMP,码注结果出现了意想不到的码注问题。

       VPS安装LNMPA一路比较顺利,码注貌似时间比较长,码注花了2小时左右(哎,码注snap源码够郁闷的码注,晚点写个systems$/年VPS的码注评测吧),下载源码,解压都不错,安装dedecms,完全OK。这个源码,是别人提供的,上传空间需要安装后再还原下数据,问题就在还原数据的时候出现了,每次均很快提示: Gateway Time-out!

       因为后台要还原的etracing源码数据文件很多,我发现,前面比较小的没问题,问题总是出现在恢复某个大的数据库文件上,首先想到可能是php执行时间问题,打开/usr/local/php/etc/,编辑php.ini文件:

       max_execution_time 设置为0(或者高于目前值的数值)

       重启过LNMP之后,忐忑的重新还原数据,OH,仍然,头疼,继续搜索解决方法。

       编辑:/usr/local/apache/conf/extra/下的tool源码/softdown/.htm

       nginx

       windows安装配置方法

       ç¬¬ä¸€æ­¥ã€å®‰è£…方法

       ä¸€ã€ä¸‹è½½å¥½åŽï¼ŒæŠŠnginx

       windows版软件解压到c盘根目录。

       äºŒã€åŒå‡»nginx.exe图标,可见黑窗口一闪而过,启动完毕。

       ä¸‰ã€æŒ‰ä¸‹win+R快捷键,输入cmd打开命令行。

       å››ã€å‘½ä»¤è¡Œåˆ°nginx目录,输入nginx启动。(注,此方式命令行窗口无任何提示,且被锁定)

       äº”、打开浏览器,输入mand_line() 通过命令行参数,创建一个管理类。然后运行他的 execute() 。

        如果设置了reload,将会在启动前先 check_errors 。

       check_errors() 是个闭包,所以上文结尾是 (django.setup)() 。

        直接看最后一句 settings.INSTALLED_APPS 。从settings中抓取app

        注意,这个settings还不是我们项目中的settings.py。而是一个对象,位于 django\conf\__init__.py

        这是个Settings类的懒加载封装类,直到 __getattr__ 取值时才开始初始化。paperwork 源码然后从Settings类的实例中取值。且会讲该值赋值到自己的 __dict__ 上(下次会直接在自己身上找到,因为 __getattr__ 优先级较低)

       为了方便debug,我们直接写个run.py。不用命令行的方式。

        项目下建个run.py,模拟runserver命令

       debug抓一下setting_module

        回到 setup() 中的最后一句 apps.populate(settings.INSTALLED_APPS)

        开始看 apps.populate()

        首先看这段

        这些App最后都会封装成为AppConfig。且会装载到 self.app_configs 字典中

        随后,分别调用每个appConfig的 import_models() 和 ready() 方法。

       App的装载部分大体如此

        为了方便debug我们改写下最后一句

        res的类型是Command django.contrib.staticfiles.management.commands.runserver.Command object at 0xEDA0

        重点是第二句,让我们跳到 run_from_argv() 方法,这里对参数进行了若干处理。

        用pycharm点这里的handle会进入基类的方法,无法得到正确的走向。实际上子类Commond重写了这个方法。

        这里分为两种情况,如果是reload重载时,会直接执行 inner_run() ,而项目启动需要先执行其他逻辑。

       django 项目启动时,实际上会启动两次,如果我们在项目入口(manage.py)中设置个print,会发现它会打印两次。

        第一次启动时, DJANGO_AUTORELOAD_ENV 为None,无法进入启动逻辑。会进入 restart_with_reloader() 。

        在这里会将 DJANGO_AUTORELOAD_ENV 置为True,随后重启。

        第二次时,可以进入启动逻辑了。

       这里创建了一个django主线程,将 inner_run() 传入。

        随后本线程通过 reloader.run(django_main_thread) ,创建一个轮询守护进程。

        我们接下来看django的主线程 inner_run() 。

       当我们看到wsgi时,django负责的启动逻辑,就此结束了。接下来的工作交由wsgi服务器了

        这相当于我们之前在fastapi中说到的,将fastapi的app交由asgi服务器。(asgi也是django提出来的,两者本质同源)

        那么这个wsgi是从哪来的?让我们来稍微回溯下

        这个settings是一个对象,在之前的操作中已经从 settings.py 配置文件中获得了自身的属性。所以我们只需要去 settings.py 配置文件中寻找。

        我们来寻找这个 get_wsgi_application() 。

        它会再次调用 setup() ,重要的是,返回一个 WSGIHandler 类的实例。

        这就是wsgiapp本身。

       load_middleware() 为构建中间件堆栈,这也是wsgiapp获取setting信息的唯一途径。导入settings.py,生成中间件堆栈。

        如果看过我之前那篇fastapi源码的,应该对中间件堆栈不陌生。

        app入口→中间件堆栈→路由→路由节点→endpoint

        所以,wsgiapp就此构建完毕,服务器传入请求至app入口,即可经过中间件到达路由进行分发。

       django如何启动服务器的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于部署django到服务器、django如何启动服务器的信息别忘了在本站进行查找喔。