PHP 数据库连接池实现
来源:互联网 发布:淘宝 答案宠物店 假粮 编辑:程序博客网 时间:2024/05/20 00:53
- 摘要
- xml
- 读取配置文件
- 简易方式
- 常规方式
- PHP解析XML
- 配置文件
- 解析
- 读取配置文件
- 数据库连接池
- 测试
- 申请过多时拒绝请求
- 已满后拒绝放入
- 总结
摘要
之前总是以脚本面向过程的方式写PHP代码,所以很大程度上来说,既不规范,也不安全,更不容易维护。为了代码的重用,准备写一套自己的工具库,这样的话,以后写项目的时候就可以很轻松的进行使用啦。
今天要进行实现的是一个数据库连接池,以配置文件的方式来实现。
xml
XML作为一门高可用的结构化语言,作为配置文件真的是言简意赅,虽然相比于近来配置文件界的YAML, JSON等翘楚来说,可能有效数据的占比比较小,但是这种冗余是有其存在的价值的。
基本上,看完xml的节点就可以知道其功能。这也是为什么大项目都会使用XML作为配置文件的原因。
可以容忍冗余,但是不能带来一点歧义,或者维护困难方面的问题。
在php中,使用XML文件会是一件赏心悦目的事情,虽然相对于Java程序而言,如此。但是相比于Python处理,PHP程序就显得没有那么优雅了。
读取配置文件
读取配置文件其实说白了就是对文件的读取,然后包装一下。我常用的有如下两种方式。
简易方式
第一次使用这个简易方式的时候,真的是有点郁闷。
- 1
- 2
- 1
- 2
结果使用浏览器访问这个测试用的php文件时,却只显示了xml的内容部分,但是节点信息什么的根本没有显示。
然后我还特地查阅了一下帮助文档,这个函数返回的结果是字符串无疑的啊。然后vardump之后也证明了这一点。于是也没有多想,还以为这种方式能自动的过滤掉XML的标签TAG信息呢。
最后一个偶然的测试,打开了网页源代码,发现这个函数确实读到了XML的所有信息,只不过显示在浏览器上就会被浏览器给自动解析了。所以只能看到相关的内容部分。
常规方式
常规方式就是按部就班的读取文件了。其余的话和上述方案一致。
- 1
- 2
- 3
- 1
- 2
- 3
PHP解析XML
上述两种读取文件,其实都是为了PHP解析XML来做准备的。关于PHP解析XML的方式的博客有很多。方式也有很多,像simplexml,XMLReader,DOM啦等等。但是对于比较小型的xml配置文件,simplexml就足够了。
配置文件
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
解析
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
数据库连接池
对于PHP程序而言,优化永无止境。而数据库连接池就在一定程度上起到了优化的作用。其使得对用户的每一个请求而言,无需每次都像数据库申请链接资源。而是通过已存在的数据库连接池中的链接来返回,从时间上,效率上,都是一个大大的提升。
于是,这里简单的模拟了一下数据库连接池的实现。核心在于维护一个“池”。
从池子中取,用毕,归还给池子。
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
- 48
- 49
- 50
- 51
- 52
- 53
- 54
- 55
- 56
- 57
- 58
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
- 48
- 49
- 50
- 51
- 52
- 53
- 54
- 55
- 56
- 57
- 58
测试
申请过多时,拒绝请求
在申请数据库连接小于20的时候,程序直接从数据库连接池中获取。
当申请的数据库链接资源大于数据库连接池的上限时,不予提供。并提示异常。
已满后拒绝放入
当数据库连接池内已满的时候,如果想回首自定义的数据库链接资源,则不予支持,并报错提示。
总结
回顾一下,本次试验主要是以面向对象的角度,设计并实现了一个简易的数据库连接池。在一定程度上对PHP代码的优化起到了作用。
另外简单的使用了simplexml对于XML文件的解析处理, 以及常用的对于文件读取的操作。
来源:http://blog.csdn.net/Marksinoberg/article/details/53857511
- PHP 数据库连接池实现
- PHP 数据库连接池实现
- C实现PHP的mysql数据库连接池
- 关于PHP数据库连接池
- PHP数据库连接池
- 基于swoole扩展实现真正的PHP数据库连接池
- 基于swoole扩展实现真正的PHP数据库连接池
- java实现数据库连接池
- 数据库连接池实现原理
- 自己实现数据库连接池
- Java数据库连接池实现
- 自己实现数据库连接池
- 数据库连接池-DataSource实现
- JAVA数据库连接池实现
- 数据库连接池实现
- 数据库连接池实现原理
- Java 数据库连接池 实现
- JAVA数据库连接池实现
- GetRowWithCellText
- js 访问的js文件不是应有的内容,而是其他的
- SSM系列3:SSM+easyUI+HTML5部分新特性
- [原]如何用Android NDK编译FFmpeg
- 用StretchBlt()来设置图片时,图片背景变黑色。
- PHP 数据库连接池实现
- wrapper log4j 中文乱码
- 要给嵌套sql的列例子
- 工厂模式
- Struts2下载文件时文件名乱码
- js及JQuery之event
- UMeditor使用
- Linux之定时任务
- python 获取文件字符编码类型