如何理解池化技术?

发布于 2022-09-06 10:39:18 字数 382 浏览 26 评论 0

Q1: 如何理解池化技术?
我的理解是:
比如连接池,就是将连接看作一个资源,放到一个pool里,有一个调度器(不知道这个说法正不正确)根据请求来调度这些连接。连接池的作用是避免每一次使用都要建立连接、销毁连接等这方面的开销。

Q2: php-fpm 可以算是一个连接池吗?
如果 Q1 我的理解正确,那么 php-fpm 算连接池吗? 因为我有看到 php-fpm 会有一个 pool.d 的目录。
如果 php-fpm 算,那么 fastcgi 的其他实现也都算吗? nginx 的 master worker 进程算吗?

Q3: 除了连接池,还有其他的池化技术吗?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

谜兔 2022-09-13 10:39:18

Q1:你说的这个是一个方面,我认为还是并发量的限制才会带来“池化”技术,假如mysql只能维持256个长连接,但是我们有1000000个用户每天嗷嗷待哺,那么就得帮mysql请一个经纪人,不管多少人访问,mysql本体都不需要一直处理连接,只需要管好怎么处理数据库相关的部分就好了(仔细想想,这样事务独立性不就被打破了么....)。

Q2:php-fpm不是连接池(网络的),大概可以叫:进程池(本地的)。

Q3:只要是有限的资源,都可以被“池化”。

个人主观观点,仅供参考,如有不足,评论交流~

情栀口红 2022-09-13 10:39:18

php-fpm就是fastgi协议的的实现,另外还有内存池、线程池等,php-fpm和nginx master process一方面属于算进程管理器,需要的时候才fork新的进程,当然预设部分也就是进程池了,池化的技术可以这么理解,预设一部分资源,需要的时候直接使用,避免创建过程的开销

酒中人 2022-09-13 10:39:18

java是内存常驻语言,池化技术比较常见,一般池化技术用在有效控制资源和复用而节约系统资源开销;比如
1、假设每一个请求需要操作dba,这个时候每一个并发都需要一个数据库链接session,如果系统并发很大,假设1000,没有池化技术就会同时有1000个session,这很容易导致系统资源崩溃。用上池化技术后,设置池中最大数量上限,高并发下就限制了数据库连接session最大数量了,池化技术核心是复用,这也就不存在session频繁创建和销毁而浪费系统资源,另外一般池化技术几乎都是放在内存中,所以寻找和管理的效率相当高,几乎没有io方面导致的性能问题。

2、另外java中还有线程池概念,复用线程用的;高并发下,既可以有效控制住系统线程过多,也避免了线程创建和销毁浪费系统资源。


5年没有搞php开发了,对于php5后面发展出来的技术已经没有任何了解,见谅不懂php-fpm

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文