php多进程写入文件
测试一
$begin = time();
for ($i=0; $i<10000; $i++) {
$fp = fopen("tmp", 'r+');
fseek($fp, 0, SEEK_END);
fwrite($fp, str_repeat($argv[1],1024*32).PHP_EOL);
fclose($fp);
}
$end = time();
echo "time use: ".($end-$begin).PHP_EOL;
php write.php b
php write.php a
wc -l tmp
10450 tmp
测试结果:
与预期的2W行不相符
错误分析:
seek定位到文件末尾的之后,可能因为其他进程已经写入文件,当前进程进行了覆盖
测试二
$begin = time();
for ($i=0; $i<10000; $i++) {
$fp = fopen("tmp", 'a+');
fwrite($fp, str_repeat($argv[1],1024*32).PHP_EOL);
fclose($fp);
}
$end = time();
echo "time use: ".($end-$begin).PHP_EOL;
php write.php b
php write.php a
wc -l tmp
20000 tmp
测试结果:
与预期的2W行相符,但是检查文件内容
检查脚本,检查一行是不是同时含有a和b
<?php
$fp = fopen("tmp", 'r+');
while (!feof($fp)) {
$line = fgets($fp, 1024*1024);
if (strstr($line, 'a') && strstr($line, 'b')) {
echo 'not pass'.PHP_EOL;
for ($i=0;$i<strlen($line);$i++){
echo ord($line[$i]).PHP_EOL;
}
die;
}
}
echo 'pass'.PHP_EOL;
php check.php >ts
ts内容
not pass
97
97
.
.
.
98
98
10
错误分析:
php的fwrite是带buffer的,写入一行的内容大于buffer的长度,进程A和进程B是轮流调用write到同一行,就导致了这种结果
测试三
顺序写
$begin = time();
$fp = fopen("tmp", 'w+');
for ($i=0; $i<200000; $i++) {
fwrite($fp, str_repeat($argv[1],1024*32).PHP_EOL);
}
fclose($fp);
$end = time();
echo "time use: ".($end-$begin).PHP_EOL;
php write.php a
time use: 13
$begin = time();
for ($i=0; $i<200000; $i++) {
$fp = fopen("tmp", 'a+');
fwrite($fp, str_repeat($argv[1],1024*32).PHP_EOL);
fclose($fp);
}
$end = time();
echo "time use: ".($end-$begin).PHP_EOL;
php write.php a
time use: 16
php多进程写入文件的更多相关文章
- php利用curl实现多进程下载文件类
		批量下载文件一般使用循环的方式,逐一执行下载.但在带宽与服务器性能允许的情况下,使用多进程进行下载可以大大提高下载的效率.本文介绍PHP利用curl的多进程请求方法,实现多进程同时下载文件. 原理: ... 
- Django多进程日志文件问题
		Django多进程日志文件问题 最近使用Django做一个项目.在部署的时候发现日志文件不能滚动(我使用的是RotatingFileHandler),只有一个日志文件. 查看Log发现一个错误消息:P ... 
- mac  无法识别seagate硬盘、无法向其写入文件
		1,无法识别 Seagate 硬盘 新买的mac air Captian 10.11.6系统,连上硬盘根本不出现盘符,usb插头不要插得太深,慢慢的插入,看到硬盘白灯亮起就可以了 2,无法向 Seag ... 
- .NET跨平台之旅:在Linux上将ASP.NET 5运行日志写入文件
		在前一篇博文(增加文件日志功能遇到的挫折)中,我们遇到了这样一个问题:虽然有一些.NET日志组件(比如Serilog, NLog)已经开始支持.NET Core,但目前只支持控制台输出日志,不支持将日 ... 
- C#文本写入文件,追加写入文件
		写入文件和这个对象 StreamWriter using (StreamWriter fs = new StreamWriter(path, true)) { fs.WriteLine(strLog) ... 
- JMeter中BeanShell实现写入文件
		1.首先F:\test.txt文件为空 
- 利用其它带文件防护功能的软件防止*.asp;*.jpg写入文件。
		此木马是一个.NET程序制作,如果你的服务器支持.NET那就要注意了,,进入木马有个功能叫:IIS Spy,点击以后可以看到所有站点所在的物理路径.以前有很多人提出过,但一直没有人给解决的答案.. 防 ... 
- 写入文件(txt格式)
		#region 写入文件 /// <summary> /// 写入文件 /// </summary> /// <param ... 
- C++重载流运算符,将存储结构体的vector直接写入文件
		我们知道,当vector很大的时候,如果使用循环的方式将其中的元素写入文件将非常费时,因此有没有办法将vector一次性写入文件呢? 采用流运算符重载的方法可以做到,不仅基本类型的vector可以一次 ... 
随机推荐
- 全排列 next_permutation() 函数的使用
			看来看去还是这篇博客比较简洁明了 https://www.cnblogs.com/My-Sunshine/p/4985366.html 顺便给出牛客网的一道题,虽然这道题用dfs写出全排列也能做,题意 ... 
- 基于WebImage的图片上传工具类
			支持缩略图和水印. using System; using System.IO; using System.Linq; using System.Web; using System.Web.Helpe ... 
- 弹出table页面--hq
			function queryRelation(tableID,prosourceID){ //弹出页面 debugger; initqueryRelationGrid(tableID,prosour ... 
- XLua 网络加载(基础操作)
			LoadGameMethod 网上资源加载更新:加载场景中另建协程用来加载; public void LoadGameMethod() { StartCoroutine(start()); ... 
- Proguard breaking audio file in assets or raw
			http://stackoverflow.com/questions/21440572/proguard-breaking-audio-file-in-assets-or-raw Issue: I h ... 
- 在SourceTree中使用Git submodule
			在開發的過程中我們的項目可能會引用其他的版本庫中的代碼, 例如公司已經累積了一套公用的函式庫, 被多個項目調用; 很顯然地, 不能把公用函式庫的文件直接放到我們開發中的項目中, 這樣不但項目的冗餘, ... 
- 深入理解JavaScript系列(20):《你真懂JavaScript吗?》答案详解
			介绍 昨天发的<大叔手记(19):你真懂JavaScript吗?>里面的5个题目,有很多回答,发现强人还是很多的,很多人都全部答对了. 今天我们来对这5个题目详细分析一下,希望对大家有所帮 ... 
- [转](.NET Core C#) AES Encryption
			本文转自:https://www.example-code.com/dotnet-core/crypt2_aes.asp Chilkat.Crypt2 crypt = new Chilkat.Cryp ... 
- MVC页面简单post提交
			页面代码 <script src="~/Scripts/jquery-1.10.2.js"></script> <script> $(funct ... 
- HDU 4268 multiset
			http://acm.hust.edu.cn/vjudge/contest/123100#problem/B #include <iostream> #include <string ... 
