django Python manage.py runserver 启动测试服务, 每次新的 http 请求 都会新建一个 thread 处理, 之后会自动关闭这个线程

2020-11-10 08:44:25 +08:00
 chaleaoch
是这样的吗?
关闭线程的同时, 资源会自动释放,譬如和数据库的连接, 包括 Django orm 新建的连接和手动 db.connection 创建的连接都会自动释放.

我是疑问句. 提前感谢大佬解答.
2459 次点击
所在节点    Python
16 条回复
ltttx
2020-11-10 08:53:20 +08:00
是的
nonduality
2020-11-10 10:56:29 +08:00
这个事实对你的开发有什么影响吗?
SjwNo1
2020-11-10 11:22:06 +08:00
测试应该是的
no1xsyzy
2020-11-10 12:29:21 +08:00
手动连接不一定看具体实现,一般会包含 with 调用方式,请用 with
chaleaoch
2020-11-10 17:20:42 +08:00
@nonduality 如果我在 view 里面创建一个 connection 或者 什么东西而没有释放,如果线程没有关闭, 那么 这个 connection 会一直存在. 我个人理解是这样的.
当然后来我才知道 django 有一个信号 专门处理这种情况,但是还是会有其他影响. 譬如 全局变量? 之类.
chaleaoch
2020-11-10 17:21:57 +08:00
@nonduality 另外本人一直好奇, 一个 HTTP 请求过来 gunicorn 或者 gevent 是如何做命名空间隔离的. 一直没时间精力看代码. 就好奇先问一嘴.
freakxx
2020-11-10 17:31:34 +08:00
@chaleaoch #5

手动创建的连接需要自己管理,


源码一般是两种写法
用 with 来控制退出时候 close
或者结束执行 cursor.close()
chaleaoch
2020-11-10 17:36:13 +08:00
@freakxx 我的问题就在于此, 我在想如果线程都退出了 那这个连接是不是也就断了?
freakxx
2020-11-10 17:53:23 +08:00
@chaleaoch #8


是的,连接会断,但会有情况就是炸裂的情况下,执行不到


也就是说,你有一个 http 请求,正常来到结束的时候,它会处理
但是假设你在 request 过程异常,这个执行应该是执行不到的


django/http/response.py -L 242

# The WSGI server must call this method upon completion of the request.
# See http://blog.dscpl.com.au/2012/10/obligations-for-calling-close-on.html
def close(self)

这里会做一些处理
你要继续了解,可以从这里追代码回去。
freakxx
2020-11-10 17:58:37 +08:00
你也可以简单看下
有兴趣也可以简单看下 django/db/__init__.py

-L 60,
这里是做了处理
signals.request_started.connect(close_old_connections)
signals.request_finished.connect(close_old_connections)
chaleaoch
2020-11-10 18:53:34 +08:00
@freakxx 谢谢,对的我今天下午看到了.
chaleaoch
2020-11-10 18:55:40 +08:00
@freakxx #10 你说得对,这块我也看到了.
#9 看来我还是没说明白. 我的意思是,和 django 没关系
就起了一个线程 创建了一个 connection, 然后线程退出, connection 自动销毁吗? 应该自动断开吧?
freakxx
2020-11-10 20:20:35 +08:00
@chaleaoch #12

会的,
这跟客户端没关系。

你连接结束了,服务端能感知到,会关闭的。


------------------------------

我们上面谈的只是说,在某些情况,你不主动关闭,可能会引起 too many connections 这种情况。
johnsona
2020-11-10 20:37:59 +08:00
@chaleaoch 意思就是比如 wsgi server 创建一个线程去执行引用 django 对象,创建了 connection,但是没执行完,线程结束,这个 connection 还在不在?
没看过源码,不太清楚,我有几个疑问。
gunicorn 好像是 prefork 模式,也就是 gunicorn 服务器起来了,django 的 app 对象就在 worker 进程中存在了。假如一个请求来了,一个线程,那会引用当前进程的 django app 对象而不是创建(应该)。django 代码创建了 connection,但是不同线程有不同的 connection,为了不同的 connection 不搞错,会不会有类似 flask 的 threadlocal 这样的东西。
然后 django 可能会有异常处理,在捕捉到异常后,把对应 connection close 掉
chaleaoch
2020-11-10 21:22:40 +08:00
@freakxx thanks,
也就是说客户端 线程没了, 并不会自动发送断开连接的 socket 请求.
而是服务端发现这个 socket 好久都没有接到消息自动断开.

多谢多谢!无意间一句话又提点我一下.
phithon
2020-11-11 00:27:06 +08:00
web 会自动关闭连接,如果不在 web 里,连接需要手工关

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/723430

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX