1. function curl_multi($urls) {
  2. if (!is_array($urls) or count($urls) == 0) {
  3. return false;
  4. }
  5. $num=count($urls);
  6. $curl = $curl2 = $text = array();
  7. $handle = curl_multi_init();
  8. function createCh($url) {
  9. $ch = curl_init();
  10. curl_setopt ($ch, CURLOPT_URL, $url);
  11. curl_setopt ($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (Windows NT 6.1; Trident/7.0; rv:11.0) like Gecko');//设置头部
  12. curl_setopt ($ch, CURLOPT_REFERER, $url); //设置来源
  13. curl_setopt ($ch, CURLOPT_ENCODING, "gzip"); // 编码压缩
  14. curl_setopt ($ch, CURLOPT_RETURNTRANSFER, 1);
  15. curl_setopt ($ch, CURLOPT_FOLLOWLOCATION, 1);//是否采集301、302之后的页面
  16. curl_setopt ($ch, CURLOPT_MAXREDIRS, 5);//查找次数,防止查找太深
  17. curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE); // 对认证证书来源的检查
  18. curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE); // 从证书中检查SSL加密算法是否存在
  19. curl_setopt ($ch, CURLOPT_TIMEOUT, 20);
  20. curl_setopt ($ch, CURLOPT_HEADER, 0);//输出头部
  21. return $ch;
  22. }
  23. foreach($urls as $k=>$v){
  24. $url=$urls[$k];
  25. $curl[$k] = createCh($url);
  26. curl_multi_add_handle ($handle,$curl[$k]);
  27. }
  28. $active = null;
  29. do {
  30. $mrc = curl_multi_exec($handle, $active);
  31. } while ($mrc == CURLM_CALL_MULTI_PERFORM);
  32. while ($active && $mrc == CURLM_OK) {
  33. if (curl_multi_select($handle) != -1) {
  34. usleep(100);
  35. }
  36. do {
  37. $mrc = curl_multi_exec($handle, $active);
  38. } while ($mrc == CURLM_CALL_MULTI_PERFORM);
  39. }
  40. foreach ($curl as $k => $v) {
  41. if (curl_error($curl[$k]) == "") {
  42. $text[$k] = (string) curl_multi_getcontent($curl[$k]);
  43. }
  44. curl_multi_remove_handle($handle, $curl[$k]);
  45. curl_close($curl[$k]);
  46. }
  47. curl_multi_close($handle);
  48. return $text;
  49. }
  50. $urls=array('http://www.baidu.com',
  51. 'http://www.baidu.com',
  52. 'http://www.baidu.com',
  53. 'http://www.baidu.com',
  54. 'http://www.baidu.com',
  55. 'http://www.baidu.com',
  56. 'http://www.baidu.com',
  57. 'http://www.baidu.com'
  58. );
  59. $res=curl_multi($urls);
  60. print_r($res);

PHP 多线程采集的更多相关文章

  1. Python多线程采集百度相关搜索关键词

    百度相关搜索关键词抓取,读取txt关键词,导出txt关键词 #百度相关搜索关键词抓取,读取txt关键词,导出txt关键词   # -*- coding=utf-8 -*- import request ...

  2. python3 多线程 采集 xpath

    #!/usr/bin/python # -*- coding: UTF-8 -*- '''Thread3 多线程测试采集''' import threading,time,queue,Mongo_ut ...

  3. python多线程采集

    import requests import json import threading Default_Header = { #具体请求头自己去弄 } _session=requests.sessi ...

  4. PHP使用CURL_MULTI实现多线程采集

    $connomains = array( "http://www.baidu.com/", "http://www.hao123.com/", "ht ...

  5. python多线程采集图片

    cmd中运行 >python untitled2.py    图片的网站 import requests import threading from bs4 import BeautifulSo ...

  6. PHP cURL应用实现模拟登录与采集使用方法详解

    对于做过数据采集的人来说,cURL一定不会陌生.虽然在PHP中有file_get_contents函数可以获取远程链接的数据,但是它的可控制性太差了,对于各种复杂情况的采集情景,file_get_co ...

  7. 多线程实际运用<第七篇>

    1.单线程采集100个页面 class Program { static int i = 6991275; static void Main(string[] args) { Stopwatch sw ...

  8. PHP cURL实现模拟登录与采集使用方法详解教程

    来源:http://www.zjmainstay.cn/php-curl 本文将通过案例,整合浏览器工具与PHP程序,教你如何让数据 唾手可得 . 对于做过数据采集的人来说,cURL一定不会陌生.虽然 ...

  9. 转载 多线程实际运用<第七篇>

    多线程实际运用<第七篇> 1.单线程采集100个页面 class Program { static int i = 6991275; static void Main(string[] a ...

随机推荐

  1. MantisBT导出Excel文件名显示中文的修改方法

    我安装的是 mantisbt-2.15.0. 在“查看问题”页面导出Excel文件后,其文件名虽然是我选择的项目名称,但是,若项目名称中有中文,这就是用%加编码显示. 解决方法是: 在  <Ma ...

  2. 发送请求工具—Advanced REST Client的安装使用

    1. 0 下载得到Advanced-REST-client_v3.1.9.zip 链接:http://pan.baidu.com/s/1c0vUnJi 密码:z34d 1.1 解压Advanced-R ...

  3. 天马行空DevOps-Dev平台建设概述

    概述 DevOps(Development和Operations的组合词)是一组过程.方法与系统的统称,用于促进开发(应用程序/软件工程).技术运营和质量保障(QA)部门之间的沟通.协作与整合.它是一 ...

  4. jupyter通过notedown使用markdown

    0 Problem 最近看了下李沐老师的mxnet教程,在使用jupyter的时候打开教程发现全是markdown源文,没有展示markdown格式的文字. 1 Reason 源代码是用markdow ...

  5. 亚马逊中国耳机巨头Jabra官方旗舰店上线

    日前,亚马逊中国(Z.cn)宣布,全球无线技术顶级领导品牌 Jabra (捷波朗)官方旗舰店正式上线,产品品类涵盖蓝牙耳机.音乐耳机.无线音箱和车载系列产品.Jabra 旗舰店上线伊始便汇集了 60 ...

  6. 使用appcmd命令创建iis站点及应用程序池

    参考文章:iis7 appcmd的基础命令及简单用法 验证环境:Windows 7    IIS7 AppCmd.exe工具所在目录 C:\windows\sytstem32\inetsrv\目录下, ...

  7. 学习GIT 你只要这一篇(转)

    http://blog.csdn.net/afei__/article/details/51476529 安装之后第一步 安装 Git 之后,你要做的第一件事情就是去配置你的名字和邮箱,因为每一次提交 ...

  8. 对字符串进行base64加解密---基于python

    本文介绍Python 2.7中的base64模块,该模块提供了基于rfc3548的Base16, 32, 64编解码的接口.官方文档,参考这里. 当前接口基于rfc3548的Base16/32/64编 ...

  9. 到底什么是BFC、IFC、GFC和FFC,次奥?

    软件开发的一般被称为民工,搞前端的,有人形容为是掏粪工,说白了连民工级别高都没有.说直接点就是个制作界面的,注意,连设计界面的都算不上,一般前端都是拿着设计稿去照这样子开发的. 说这些无非是觉得前端前 ...

  10. Hybrid APP基础篇(四)->JSBridge的原理

    说明 JSBridge实现原理 目录 前言 参考来源 前置技术要求 楔子 原理概述 简介 url scheme介绍 实现流程 实现思路 第一步:设计出一个Native与JS交互的全局桥对象 第二步:J ...