测试:
耗时:0.015秒,消费时光包含:
- 过程cat读出文本
- 经由过程管道将数据传入Golang
- go处理数据,将结不雅返回到屏幕
经由过程比较测试,计算出各个流程占用的时光。下面提到的title.txt文件,包含100万行文本,每行文本是大年夜b2b平台取的商品标题
1: 整体流程耗时
- # time cat title.txt | ./test > /dev/null
耗时:14.819秒,消费时光包含:
- 过程cat读出文本
- 经由过程管道将数据传入Golang
- Golang处理数据,将结不雅返回到屏幕
2:计算分词函数耗时。筹划:去除分词函数的调取,即:注释掉落Golang源代码中的调取分词那行的代码
- time cat title.txt | ./test > /dev/null
耗时:1.817秒时光,消费时光包含:
- 过程cat读出文本
- 经由过程管道将数据传入Golang
- Golang处理数据,将结不雅返回到屏幕
分词耗时 = (第一步耗时) - (以上敕令所耗时)
分词耗时 : 14.819 - 1.817 = 13.002秒
3:测试cat过程与Golang过程之间通信所占时光
- time cat title.txt > /dev/null
好吧,也许你已经发明,我是标题档,这里重点要讲的并不只是PHP与Golang若何通信。而是在介绍一种办法: 经由过程双向管道让随便率性说话通信。(所有说话都邑实现管道相干内容)
管道通信耗时:(第二步耗时) - (第三步耗时)
管道通信耗时: 1.817 - 0.015 = 1.802秒
4:PHP与Golang通信的时光消费
编写简单的php文件:
- <?php
- $descriptorspec = array(
- 0 => array("pipe", "r"),
- 1 => array("pipe", "w")
- );
- $handle = proc_open(
- '/webroot/go/src/test/test',
- $descriptorspec,
- $pipes
- );
- $fp = fopen("title.txt", "rb");
- while (!feof($fp)) {
- fwrite($pipes['0'], trim(fgets($fp))."\n");
- echo fgets($pipes[1]);
- }
- fclose($pipes['0']);
- fclose($pipes['1']);
- proc_close($handle);
流程与膳绫擎根本一致,读出title.txt内容,经由过程双向管道传入Golang过程分词后,再返回给php (比膳绫擎的测试多一步:数据再经由过程管道返回)
- time php popen.php > /dev/null
耗时:24.037秒,消费时光包含:
- 过程PHP读出文本
- 经由过程管道将数据传入Golang
推荐阅读
LSTM之父预测人工智能奇点或在2030年到来|GMIS2017 上的AI大佬都说了啥
5 月 27 日,由机械之心主办的为期两天的GMIS 2017 大年夜会在北京拉开帷幕。据悉,浩瀚来自瑞士、美国、加拿大年夜以及国内的浩瀚人工智能学术大年夜咖、业界大年夜牛都邑表态GMIS的舞台>>>详细阅读
本文标题:PHP与Golang如何通信?
地址:http://www.17bianji.com/lsqh/35483.html
1/2 1