测试一

  1. $begin = time();
  2. for ($i=0; $i<10000; $i++) {
  3. $fp = fopen("tmp", 'r+');
  4. fseek($fp, 0, SEEK_END);
  5. fwrite($fp, str_repeat($argv[1],1024*32).PHP_EOL);
  6. fclose($fp);
  7. }
  8. $end = time();
  9. echo "time use: ".($end-$begin).PHP_EOL;

php write.php b

php write.php a

wc -l tmp

10450 tmp

测试结果:

与预期的2W行不相符

错误分析:

seek定位到文件末尾的之后,可能因为其他进程已经写入文件,当前进程进行了覆盖

测试二

  1. $begin = time();
  2. for ($i=0; $i<10000; $i++) {
  3. $fp = fopen("tmp", 'a+');
  4. fwrite($fp, str_repeat($argv[1],1024*32).PHP_EOL);
  5. fclose($fp);
  6. }
  7. $end = time();
  8. echo "time use: ".($end-$begin).PHP_EOL;

php write.php b

php write.php a

wc -l tmp

20000 tmp

测试结果:

与预期的2W行相符,但是检查文件内容

检查脚本,检查一行是不是同时含有a和b

  1. <?php
  2. $fp = fopen("tmp", 'r+');
  3. while (!feof($fp)) {
  4. $line = fgets($fp, 1024*1024);
  5. if (strstr($line, 'a') && strstr($line, 'b')) {
  6. echo 'not pass'.PHP_EOL;
  7. for ($i=0;$i<strlen($line);$i++){
  8. echo ord($line[$i]).PHP_EOL;
  9. }
  10. die;
  11. }
  12. }
  13. echo 'pass'.PHP_EOL;

php check.php >ts

ts内容

  1. not pass
  2. 97
  3. 97
  4. .
  5. .
  6. .
  7. 98
  8. 98
  9. 10

错误分析:

php的fwrite是带buffer的,写入一行的内容大于buffer的长度,进程A和进程B是轮流调用write到同一行,就导致了这种结果

测试三

顺序写

  1. $begin = time();
  2. $fp = fopen("tmp", 'w+');
  3. for ($i=0; $i<200000; $i++) {
  4. fwrite($fp, str_repeat($argv[1],1024*32).PHP_EOL);
  5. }
  6. fclose($fp);
  7. $end = time();
  8. echo "time use: ".($end-$begin).PHP_EOL;

php write.php a

time use: 13

  1. $begin = time();
  2. for ($i=0; $i<200000; $i++) {
  3. $fp = fopen("tmp", 'a+');
  4. fwrite($fp, str_repeat($argv[1],1024*32).PHP_EOL);
  5. fclose($fp);
  6. }
  7. $end = time();
  8. echo "time use: ".($end-$begin).PHP_EOL;

php write.php a

time use: 16

php多进程写入文件的更多相关文章

  1. php利用curl实现多进程下载文件类

    批量下载文件一般使用循环的方式,逐一执行下载.但在带宽与服务器性能允许的情况下,使用多进程进行下载可以大大提高下载的效率.本文介绍PHP利用curl的多进程请求方法,实现多进程同时下载文件. 原理: ...

  2. Django多进程日志文件问题

    Django多进程日志文件问题 最近使用Django做一个项目.在部署的时候发现日志文件不能滚动(我使用的是RotatingFileHandler),只有一个日志文件. 查看Log发现一个错误消息:P ...

  3. mac 无法识别seagate硬盘、无法向其写入文件

    1,无法识别 Seagate 硬盘 新买的mac air Captian 10.11.6系统,连上硬盘根本不出现盘符,usb插头不要插得太深,慢慢的插入,看到硬盘白灯亮起就可以了 2,无法向 Seag ...

  4. .NET跨平台之旅:在Linux上将ASP.NET 5运行日志写入文件

    在前一篇博文(增加文件日志功能遇到的挫折)中,我们遇到了这样一个问题:虽然有一些.NET日志组件(比如Serilog, NLog)已经开始支持.NET Core,但目前只支持控制台输出日志,不支持将日 ...

  5. C#文本写入文件,追加写入文件

    写入文件和这个对象 StreamWriter using (StreamWriter fs = new StreamWriter(path, true)) { fs.WriteLine(strLog) ...

  6. JMeter中BeanShell实现写入文件

    1.首先F:\test.txt文件为空

  7. 利用其它带文件防护功能的软件防止*.asp;*.jpg写入文件。

    此木马是一个.NET程序制作,如果你的服务器支持.NET那就要注意了,,进入木马有个功能叫:IIS Spy,点击以后可以看到所有站点所在的物理路径.以前有很多人提出过,但一直没有人给解决的答案.. 防 ...

  8. 写入文件(txt格式)

    #region 写入文件       /// <summary>       /// 写入文件       /// </summary>       /// <param ...

  9. C++重载流运算符,将存储结构体的vector直接写入文件

    我们知道,当vector很大的时候,如果使用循环的方式将其中的元素写入文件将非常费时,因此有没有办法将vector一次性写入文件呢? 采用流运算符重载的方法可以做到,不仅基本类型的vector可以一次 ...

随机推荐

  1. linux命令eval的用法

    [转自]http://blog.chinaunix.net/uid-21411227-id-1826706.html 1. eval command-line 其中command-line是在终端上键 ...

  2. html自定义垂直导航菜单(加强版--自定义传入menu参数,支持JSONArray、JSArray、JSONObject、JSObject)

    在上一篇中我简单写了个html自定义垂直导航菜单,缺点很明显,里面的数据是固定死的,不能动态更改数据. 这里我重写了一个修改版的垂直二级导航菜单,将原先的menuBox.init(config);修改 ...

  3. Win32 进程间通信的分析与比较

    1 进程与进程通信 进程是装入内存并准备执行的程序,每个进程都有私有的虚拟地址空间,由代码.数据以及它可利用的系统资源(如文件.管道等)组成.多进程/多线 程是Windows操作系统的一个基本特征.M ...

  4. 解决ios、微信移动端的position: fixed; 支持性不好的问题 && 禁用下拉暴露黑底的功能

    解决ios.微信移动端的position: fixed; 支持性不好的问题 在chrome中的多个部分使用了position: fixed之后,都可以正常的布局,但是放在微信上却出现了不能正常显示的问 ...

  5. 【Linux】Linux下使用Docker快速部署Oracle数据库

    安装最新Docker wget -qO- https://get.docker.com/ | sh` 安装 docker-compose sudo curl -L https://github.com ...

  6. Beyond Compare 4试用期已过

    Beyond Compare 很好用,但是只有一段时间的试用时间,当试用期过了之后就提示不能试用了 怎么办呢? 我在网上找到了两个方法: 1.直接用注册码(来自:https://blog.csdn.n ...

  7. html 复选框checkbox

    统计选中复选框的个数 <html> <head> <title> </title> <script> function static_num ...

  8. JS常用的设计模式(6)——桥接模式

    桥接模式的作用在于将实现部分和抽象部分分离开来, 以便两者可以独立的变化.在实现api的时候, 桥接模式特别有用.比如最开始的singleton的例子. var singleton = functio ...

  9. DW网页制作,数学,数据库管理

    数学(函数关系的建立) 函数关系:确定性现象之间的关系常常表现为函数关系,即一种现象的数量确定以后,另一种现象的数量也随之完全确定,表现为一种严格的函数关系. 如:记为y=f(x),其中x称为自变量, ...

  10. 使用IDEA创建java项目(hello word)

    前提:已安装好jdk,配置好环境变量.我使用的是java 8. 首先在自己的D盘下建一个文件夹,用来存放我们待会新建的项目,我创建了IdeaProject: 1,第一步打开idea 第二步选择创建ja ...