如何理解池化技术?

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

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

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

呼啦一阵风
浏览 479回答 3
3回答

繁星淼淼

Q1:你说的这个是一个方面,我认为还是并发量的限制才会带来“池化”技术,假如mysql只能维持256个长连接,但是我们有1000000个用户每天嗷嗷待哺,那么就得帮mysql请一个经纪人,不管多少人访问,mysql本体都不需要一直处理连接,只需要管好怎么处理数据库相关的部分就好了(仔细想想,这样事务独立性不就被打破了么....)。 Q2:php-fpm不是连接池(网络的),大概可以叫:进程池(本地的)。 Q3:只要是有限的资源,都可以被“池化”。 个人主观观点,仅供参考,如有不足,评论交流~

泛舟湖上清波郎朗

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

相关分类

Java