如何实现连接池?
![]() 能必然会急剧下降,甚至会导致系统崩溃。 连接池正是是解决这个问题最常用的方法,其思想非常简单,即是在服务启动的时候,先建立好若干连接,当有请求过来,就从中取出一个,执行下游操作,执行完再放回,从而避免反复的建立和销毁连接,以提升性能。 如何实现连接池 连接池是一个独立的服务,需要常驻进程。一个完整的连接池操作,通常要经历如下几步: (1)建立连接池对象(服务启动)。 (2)按照事先指定的参数创建初始数量的连接(即:空闲连接数)。 (3)对于一个访问请求,直接从连接池中得到一个连接。如果连接池对象中没有空闲的连接,且连接数没有达到最大(即:最大活跃连接数),创建一个新的连接;如果达到最大,则设定一定的超时时间,来获取连接。 (4)运用连接访问服务。 (5)访问服务完成,释放连接(此时的释放连接,并非真正关闭,而是将其放入空闲队列中。如实际空闲连接数大于初始空闲连接数则释放连接)。 (6)释放连接池对象(服务停止、维护期间,释放连接池对象,并释放所有连接)。 Java对连接池比较友好,有着很多成熟的解决方案,如DBCP 、C3P0、Druid等。而PHP在这方面就相对较弱,虽然Mysql提供了长连接的API,但在PHP机器数量较多,规模较大的情况下,mysql_pconnect非但不能节约MySQL资源,反而会加剧数据库的负荷。这主要是由于它需要依赖apache或fpm,比如,假设有100台PHP的应用服务器,每个机器需要启动100个apache或fpm工作进程,每个进程都会产生一个长连接到MySQL,这样一共会产生1万个My SQL连接。大家都知道,MySQL是每个连接会占用1个线程,如果有1万个连接,那MYSQL就需要创建1万个线程,这样大量的系统资源会被浪费在线程间上下文切换上。实际上,你的业务代码中并不是所有地方都在做数据库操作,所以,如果创建了这么多的连接,但是很多都是空闲的,那这样就会很浪费资源。 鉴于此,PHP要想独立解决连接复用的问题,那必须实现自己的连接池。所幸,PHP扩展swoole刚好可以做到这一点,利用swoole提供的task功能 (编辑:阜阳站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |

