在控制器中  使用以下代码测试

for ($i = 0; $i < 1000; $i++) {

$tmp['name'] = 'f_'.$i;

$tmp['times'] = date('Y-m-d H:i:s');

//第一测试 不采用 持久连接 mysql max_connection = 500  本次数据插入

//500 条之后 提示 too many connecntios 错误

//第二次测试 TP 采集持久连接

db('task')->insert($tmp);

}

  数据库配置文件中 database.php

// 数据库连接参数

'params' => [

\PDO::ATTR_PERSISTENT   => true,

\PDO::ATTR_CASE         => \PDO::CASE_LOWER,

],

// 是否需要断线重连

'break_reconnect' => true,

采用持久连接参数之后,确实没有报错,数据库中顺利插入了 1000条记录

但是查看日志文件,

[ 2019-10-25T09:53:48+08:00 ][ sql ] [ DB ] CONNECT:[ UseTime:0.000315s ] mysql:host=127.0.0.1;dbname=xun_php_cn;charset=utf8

[ 2019-10-25T09:53:48+08:00 ][ sql ] [ SQL ] INSERT INTO `op_task` (`name` , `times`) VALUES ('f_697' , '2019-10-25 09:53:48') [ RunTime:0.000604s ]

[ 2019-10-25T09:53:48+08:00 ][ sql ] [ DB ] CONNECT:[ UseTime:0.000292s ] mysql:host=127.0.0.1;dbname=xun_php_cn;charset=utf8

[ 2019-10-25T09:53:48+08:00 ][ sql ] [ SQL ] INSERT INTO `op_task` (`name` , `times`) VALUES ('f_698' , '2019-10-25 09:53:48') [ RunTime:0.000643s ]

发现还是每插入一条数据,就有一条CONNECT记录 , 不理解了。

下一步用单例模式   新建了一个模型类

<?php

namespace app\index\model;

use think\Model;

use think\Db;

/**

* 使用静态方法 static 而不是 public 在controller里面不用new 直接用 会方便很多

*/

class TaskModel extends Model

{

private static $instance;

protected $defaultField = 'danli';

private function __clone() {}

//禁止被克隆

/**

* 单例

*/

public static function getInstance() {

if (!(self::$instance instanceof self)) {

self::$instance = new static();

}

return self::$instance;

}

/**

* 添加一条数据

*/

public static function insertOne($uname,$times) {

$inserttheone = self::getInstance()->execute("insert into op_task(name,times) value('".$uname."','".$times."')");

if ($inserttheone) {

return true;

} else {

return false;

}

}

/**

* 删除一条数据

*/

public static function deleteOne($uid) {

$delone = self::getInstance()->execute("delete from op_task where id = ".$uid."");

if ($delone) {

return true;

} else {

return false;

}

}

}

for ($i = 0; $i < 1000; $i++) {

$tmp['name'] = 'f_'.$i;

$tmp['times'] = date('Y-m-d H:i:s');

$delOne = TaskModel::insertOne($tmp['name'],$tmp['times']);

}

采用单例模式测试,数据库顺利插入1000条记录,没有报too many connections 错误

[ 2019-10-25T10:02:30+08:00 ][ sql ] [ SQL ] insert into op_task(name,times) value('f_718','2019-10-25 10:02:30') [ RunTime:0.002179s ]

[ 2019-10-25T10:02:30+08:00 ][ sql ] [ SQL ] insert into op_task(name,times) value('f_719','2019-10-25 10:02:30') [ RunTime:0.000588s ]

日志文件,也没有看到 多次的 connect记录。。

从测试结果来看,单例模式,数据库没有多次连接。

当然这只是对于一个页面中的操作,单例模式有效果,这涉及到PHP的执行模式了,对于高并发还是需要长连接。

for ($i = 0; $i < 1000; $i++) {

$tmp['name'] = 'f_'.$i;

$tmp['times'] = date('Y-m-d H:i:s');

//第一测试 不采用 持久连接 mysql max_connection = 500  本次数据插入

//500 条之后 提示 too many connecntios 错误

//第二次测试 TP 采集持久连接

db('task')->insert($tmp);

//$delOne = TaskModel::insertOne($tmp['name'],$tmp['times']);

//usleep(1000000);

}

记录了插入 700条数据的时间

正常连接-2.964616s
持久连接-1.928009s
正常连接-单例模式-1.767899s
持久连接-单例模式-1.652180s

从测试结果来看,,,采用持久连接  单例模式  执行效率确实提高不少。。。这次的测试时在 swoole的 task中进行的。

等下在通过nginx TP5直接测试一次,

thinkphp5.1长连接-单例模式测试!的更多相关文章

  1. [NewLife.Net]单机400万长连接压力测试

    目标 对网络库NewLife.Net进行单机百万级长连接测试,并持续收发数据,检测网络库稳定性. [2020年8月1日晚上22点] 先上源码:https://github.com/NewLifeX/N ...

  2. OpenResty 高阶实战之————Redis授权登录使用短连接(5000)和长连接(500W) 使用连接池AB压力测试结果

    一.短连接开始测试 ab -n 5000 -c 100 -k 127.0.0.1/test_redis_short #demo1 Concurrency Level: Time taken for t ...

  3. HTTP的长连接和短连接——Node上的测试

        本文主要从实践角度介绍长.短连接在TCP层面的表现,借助Node.JS搭建后台服务,使用WinHTTP.Ajax做客户端请求测试,最后简单涉及WebSocket.     关键字:长连接.短连 ...

  4. HTTP长连接、短连接使用及测试

    概念 HTTP短连接(非持久连接)是指,客户端和服务端进行一次HTTP请求/响应之后,就关闭连接.所以,下一次的HTTP请求/响应操作就需要重新建立连接. HTTP长连接(持久连接)是指,客户端和服务 ...

  5. centos LB负载均衡集群 三种模式区别 LVS/NAT 配置 LVS/DR 配置 LVS/DR + keepalived配置 nginx ip_hash 实现长连接 LVS是四层LB 注意down掉网卡的方法 nginx效率没有LVS高 ipvsadm命令集 测试LVS方法 第三十三节课

    centos   LB负载均衡集群 三种模式区别 LVS/NAT 配置  LVS/DR 配置  LVS/DR + keepalived配置  nginx ip_hash 实现长连接  LVS是四层LB ...

  6. 异数OS TCP协议栈测试(三)--长连接篇

    异数OS TCP协议栈测试(三)--长连接篇 本文来自异数OS社区 github:   异数OS-织梦师(消息中间件)群: 476260389 异数OS TCP长连接技术简介 说起长连接,则首先要谈对 ...

  7. telnet 测试网站是否开启长连接

    测试服务器是否开启keepalive(长连接) telnet 主机名(域名|IP) 80 #发起请求GET /index.html HTTP/1.1Host: www.cbnsc.com 如果请求完后 ...

  8. HTTP的长连接和短连接

        本文总结&分享网络编程中涉及的长连接.短连接概念.     关键字:Keep-Alive,并发连接数限制,TCP,HTTP 一.什么是长连接 HTTP1.1规定了默认保持长连接(HTT ...

  9. C#中HttpClient使用注意:预热与长连接

    最近在测试一个第三方API,准备集成在我们的网站应用中.API的调用使用的是.NET中的HttpClient,由于这个API会在关键业务中用到,对调用API的整体响应速度有严格要求,所以对HttpCl ...

随机推荐

  1. js时间查询补充

    先来看下JS中的日期操作: var myDate = new Date(); myDate.getYear(); //获取当前年份(2位) myDate.getFullYear(); //获取完整的年 ...

  2. KafkStream架构

    Kafka Stream 的整体架构图如下. 目前KafkaStream的数据源智能是如上图所示的Kafka,但是处理结果并不一定是如上图所示的输出到Kafka,实际上KStream和Ktable的实 ...

  3. python编程基础之三

    变量 变量定义:变量名 = 值  #不需要给定变量类型 变量命名规范:也就是标识符的命名规则, 1.由数字,字母,下划线组成,不允许数字开头 2.区分大小写 3.不能是系统保留字(keyword) 获 ...

  4. SQL SERVER数据库批量替换某个数据表里的数据update

    批量替换:将A表CMC里面所有包含a替换成b而不影响其他内容UPDATE A SET CMC=REPLACE(CMC,'a','b')

  5. Python数据分析入门与实践 ✌✌

    Python数据分析入门与实践 (一个人学习或许会很枯燥,但是寻找更多志同道合的朋友一起,学习将会变得更加有意义✌✌) 这是一个数据驱动的时代,想要从事机器学习.人工智能.数据挖掘等前沿技术,都离不开 ...

  6. 苹果开始推送 macOS Catalina10.15 正式版系统更新

    北京时间今天凌晨 1 点,苹果正式推送了 macOS Catalina 10.15 正式版升级.macOS Catalina 10.15 正式版带来了许多重大改变,包括Sidecar.iTunes应用 ...

  7. 零基础:如何快速学习JavaScript,html+css技术

    前端开发要学的知识内容涉及的会很宽泛,虽然说主要是HTML.CSS和JavaScript这些基础知识点,但达妹今天想强调一下,学前端开发除了要学这些基础知识外,学员还要在这之上进行延伸和深入的去学,而 ...

  8. splinter操作ie浏览器

    splinter 是在selenium上的封装,很多操作更方便,但是默认似乎不能直接操作ie,通过修改browser.py文件,splinter\driver\webdriver下增加ie.py文件, ...

  9. Python 之Re模块(正则表达式)

    一.简介 正则表达式本身是一种小型的.高度专业化的编程语言,而在python中,通过内嵌集成re模块,程序媛们可以直接调用来实现正则匹配. 二.正则表达式中常用的字符含义 1.普通字符和11个元字符: ...

  10. Echart:前端很好的数据图表展现工具+demo

    官网:  http://echarts.baidu.com/index.html 通过一个简单的小Demo介绍echart的使用:demo均亲测可以运行 demo1: 1.新建一个echarts.ht ...