{"id":623,"date":"2015-06-19T18:03:07","date_gmt":"2015-06-19T21:03:07","guid":{"rendered":"http:\/\/thiagosantos.com\/blog\/?p=623"},"modified":"2015-06-19T18:23:14","modified_gmt":"2015-06-19T21:23:14","slug":"php-curl-timeout-e-connecttimeout","status":"publish","type":"post","link":"https:\/\/thiagosantos.com\/blog\/623\/php\/php-curl-timeout-e-connecttimeout\/","title":{"rendered":"PHP Curl Timeout e ConnectTimeout"},"content":{"rendered":"<p>Encontrei um problema no usando o php curl timeout . Problema relativamente leve no meu c\u00f3digo. Utilizando o cURL para fazer o download de arquivos em um dos meus projetos me deparei com o cancelamento do download. Debugando inicialmente pensei que o arquivo que estava baixando estivesse corrompido, mas n\u00e3o estava, conferi todas as fontes e elas estavam perfeitas.<br \/>\nSegundo achei que fosse o tempo de execu\u00e7\u00e3o do PHP, mas reparei que estava usando ele em CLI, logo n\u00e3o teria esse problema.<br \/>\nTerceiro alguma <em>merendagem<\/em> minha na configura\u00e7\u00e3o do cURL, esse dentre os dois primeiros tinha altas chances de ser a correta, ou a incorreta. Depende da interpreta\u00e7\u00e3o. Esse era mesmo o problema, mas como ter certeza disso? Debugando!<\/p>\n<p>Observando o c\u00f3digo que eu tinha que est\u00e1 abaixo, \u00e9 poss\u00edvel ver que ele \u00e9 um c\u00f3digo simples que qualquer tutorial de php cURL na internet te ensina a montar.<!--more--><\/p>\n<pre lang=\"php\">&lt;?php\r\n$url = \"http:\/\/example.com\/arquivo_grandao.zip\";\r\n\r\n$ch = curl_init();\r\ncurl_setopt($ch, CURLOPT_HEADER, 0);\r\ncurl_setopt($ch, CURLOPT_HTTPHEADER, array( 'Expect:' ) );\r\ncurl_setopt($ch, CURLOPT_URL, $url);\r\ncurl_setopt($ch, CURLOPT_USERAGENT, \"Arktre::odiopuro\");\r\ncurl_setopt($ch, CURLOPT_RETURNTRANSFER, true);\r\ncurl_setopt($ch, CURLOPT_POST, true);\r\ncurl_setopt($ch, CURLOPT_POSTFIELDS, $data);\r\n$response = curl_exec($ch);\r\n<\/pre>\n<p>&nbsp;<\/p>\n<p>Como ter certeza agora que o problema era mesmo do cURL? Simples! <a href=\"http:\/\/thiagosantos.com\/blog\/627\/php\/acompanhamento-de-progresso-no-curl-com-php\/\">Analisando o progresso do download, explico como fazer isso nesse post.<\/a> Logo como sa\u00edda eu tinha porcentagens de progresso variadas entre 40% e 80%, mas nunca 100%.<\/p>\n<p>&nbsp;<\/p>\n<pre>Progresso: 0.6532900454675\r\nProgresso: 2.5532900454675\r\nProgresso: 2.5532900454675\r\nProgresso: 2.5532900454675\r\n[...]\r\nProgresso: 76.914346406643\r\nProgresso: 77.548795145797\r\nProgresso: 78.755615489735\r\n<\/pre>\n<p>Depois disso ficou f\u00e1cil entender que o pr\u00f3prio cURL\u00a0estava interrompendo o download do arquivo. O cURL\u00a0tem dois par\u00e2metros importantes de timeout o CURLOPT_CONNECTTIMEOUT e o CURLOPT_TIMEOUT, o primeiro especifica o tempo m\u00e1ximo que o cURL pode levar para conectar a outra ponta, e o segundo o tempo m\u00e1ximo de execu\u00e7\u00e3o do cURL. Meu problema estava nesse segundo par\u00e2metro. Como o arquivo baixado era muito grande e a minha banda n\u00e3o t\u00e3o larga, o cURL precisava de mais tempo para baixar o arquivo completo.<\/p>\n<pre lang=\"php\">&lt;?php\r\n$url = \"http:\/\/example.com\/arquivo_grandao.zip\";\r\n\r\n$ch = curl_init();\r\ncurl_setopt($ch, CURLOPT_HEADER, 0);\r\ncurl_setopt($ch, CURLOPT_HTTPHEADER, array( 'Expect:' ) );\r\ncurl_setopt($ch, CURLOPT_URL, $url);\r\ncurl_setopt($ch, CURLOPT_USERAGENT, \"Arktre::odiopuro\");\r\n<strong>curl_setopt($ch, CURLOPT_CONNECTTIMEOUT ,0);\r\ncurl_setopt($ch, CURLOPT_TIMEOUT, 900);<\/strong>\r\ncurl_setopt($ch, CURLOPT_RETURNTRANSFER, true);\r\ncurl_setopt($ch, CURLOPT_POST, true);\r\ncurl_setopt($ch, CURLOPT_POSTFIELDS, $data);\r\n$response = curl_exec($ch);\r\n<\/pre>\n<p>&nbsp;<\/p>\n<p>Depois disso o progresso funcionou normalmente, indo at\u00e9 o 100. Simples de resolver!<\/p>\n<p>&nbsp;<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Encontrei um problema no usando o php curl timeout . Problema relativamente leve no meu c\u00f3digo. Utilizando o cURL para fazer o download de arquivos em um dos meus projetos me deparei com o cancelamento do download. Debugando inicialmente pensei que o arquivo que estava baixando estivesse corrompido, mas n\u00e3o estava, conferi todas as fontes [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[33,4],"tags":[],"class_list":["post-623","post","type-post","status-publish","format-standard","hentry","category-linux","category-php"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v24.3 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>PHP Curl Timeout e ConnectTimeout - Pereira, Thiago Santos.<\/title>\n<meta name=\"description\" content=\"Resolvendo o problema do php curl timeout. Normalmente ocasionando no arquivo baixado pela metade.\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/thiagosantos.com\/blog\/623\/php\/php-curl-timeout-e-connecttimeout\/\" \/>\n<meta property=\"og:locale\" content=\"pt_BR\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"PHP Curl Timeout e ConnectTimeout - Pereira, Thiago Santos.\" \/>\n<meta property=\"og:description\" content=\"Resolvendo o problema do php curl timeout. Normalmente ocasionando no arquivo baixado pela metade.\" \/>\n<meta property=\"og:url\" content=\"https:\/\/thiagosantos.com\/blog\/623\/php\/php-curl-timeout-e-connecttimeout\/\" \/>\n<meta property=\"og:site_name\" content=\"Pereira, Thiago Santos.\" \/>\n<meta property=\"article:published_time\" content=\"2015-06-19T21:03:07+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2015-06-19T21:23:14+00:00\" \/>\n<meta name=\"author\" content=\"Pereira, Thiago Santos\" \/>\n<meta name=\"twitter:label1\" content=\"Escrito por\" \/>\n\t<meta name=\"twitter:data1\" content=\"Pereira, Thiago Santos\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. tempo de leitura\" \/>\n\t<meta name=\"twitter:data2\" content=\"2 minutos\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/thiagosantos.com\/blog\/623\/php\/php-curl-timeout-e-connecttimeout\/\",\"url\":\"https:\/\/thiagosantos.com\/blog\/623\/php\/php-curl-timeout-e-connecttimeout\/\",\"name\":\"PHP Curl Timeout e ConnectTimeout - Pereira, Thiago Santos.\",\"isPartOf\":{\"@id\":\"https:\/\/thiagosantos.com\/blog\/#website\"},\"datePublished\":\"2015-06-19T21:03:07+00:00\",\"dateModified\":\"2015-06-19T21:23:14+00:00\",\"author\":{\"@id\":\"https:\/\/thiagosantos.com\/blog\/#\/schema\/person\/56683334c52027e200fd9270c17c629d\"},\"description\":\"Resolvendo o problema do php curl timeout. Normalmente ocasionando no arquivo baixado pela metade.\",\"inLanguage\":\"pt-BR\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/thiagosantos.com\/blog\/623\/php\/php-curl-timeout-e-connecttimeout\/\"]}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/thiagosantos.com\/blog\/#website\",\"url\":\"https:\/\/thiagosantos.com\/blog\/\",\"name\":\"Pereira, Thiago Santos.\",\"description\":\"the fun of code.\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/thiagosantos.com\/blog\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"pt-BR\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/thiagosantos.com\/blog\/#\/schema\/person\/56683334c52027e200fd9270c17c629d\",\"name\":\"Pereira, Thiago Santos\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"pt-BR\",\"@id\":\"https:\/\/thiagosantos.com\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/ed936469f86e5f07085e7540b2c0a115?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/ed936469f86e5f07085e7540b2c0a115?s=96&d=mm&r=g\",\"caption\":\"Pereira, Thiago Santos\"},\"description\":\"Um cara que mora no Rio e n\u00e3o sabe nadar.\",\"sameAs\":[\"http:\/\/thiagosantos.com\"],\"url\":\"https:\/\/thiagosantos.com\/blog\/author\/admin\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"PHP Curl Timeout e ConnectTimeout - Pereira, Thiago Santos.","description":"Resolvendo o problema do php curl timeout. Normalmente ocasionando no arquivo baixado pela metade.","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/thiagosantos.com\/blog\/623\/php\/php-curl-timeout-e-connecttimeout\/","og_locale":"pt_BR","og_type":"article","og_title":"PHP Curl Timeout e ConnectTimeout - Pereira, Thiago Santos.","og_description":"Resolvendo o problema do php curl timeout. Normalmente ocasionando no arquivo baixado pela metade.","og_url":"https:\/\/thiagosantos.com\/blog\/623\/php\/php-curl-timeout-e-connecttimeout\/","og_site_name":"Pereira, Thiago Santos.","article_published_time":"2015-06-19T21:03:07+00:00","article_modified_time":"2015-06-19T21:23:14+00:00","author":"Pereira, Thiago Santos","twitter_misc":{"Escrito por":"Pereira, Thiago Santos","Est. tempo de leitura":"2 minutos"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/thiagosantos.com\/blog\/623\/php\/php-curl-timeout-e-connecttimeout\/","url":"https:\/\/thiagosantos.com\/blog\/623\/php\/php-curl-timeout-e-connecttimeout\/","name":"PHP Curl Timeout e ConnectTimeout - Pereira, Thiago Santos.","isPartOf":{"@id":"https:\/\/thiagosantos.com\/blog\/#website"},"datePublished":"2015-06-19T21:03:07+00:00","dateModified":"2015-06-19T21:23:14+00:00","author":{"@id":"https:\/\/thiagosantos.com\/blog\/#\/schema\/person\/56683334c52027e200fd9270c17c629d"},"description":"Resolvendo o problema do php curl timeout. Normalmente ocasionando no arquivo baixado pela metade.","inLanguage":"pt-BR","potentialAction":[{"@type":"ReadAction","target":["https:\/\/thiagosantos.com\/blog\/623\/php\/php-curl-timeout-e-connecttimeout\/"]}]},{"@type":"WebSite","@id":"https:\/\/thiagosantos.com\/blog\/#website","url":"https:\/\/thiagosantos.com\/blog\/","name":"Pereira, Thiago Santos.","description":"the fun of code.","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/thiagosantos.com\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"pt-BR"},{"@type":"Person","@id":"https:\/\/thiagosantos.com\/blog\/#\/schema\/person\/56683334c52027e200fd9270c17c629d","name":"Pereira, Thiago Santos","image":{"@type":"ImageObject","inLanguage":"pt-BR","@id":"https:\/\/thiagosantos.com\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/ed936469f86e5f07085e7540b2c0a115?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/ed936469f86e5f07085e7540b2c0a115?s=96&d=mm&r=g","caption":"Pereira, Thiago Santos"},"description":"Um cara que mora no Rio e n\u00e3o sabe nadar.","sameAs":["http:\/\/thiagosantos.com"],"url":"https:\/\/thiagosantos.com\/blog\/author\/admin\/"}]}},"_links":{"self":[{"href":"https:\/\/thiagosantos.com\/blog\/wp-json\/wp\/v2\/posts\/623","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/thiagosantos.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/thiagosantos.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/thiagosantos.com\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/thiagosantos.com\/blog\/wp-json\/wp\/v2\/comments?post=623"}],"version-history":[{"count":4,"href":"https:\/\/thiagosantos.com\/blog\/wp-json\/wp\/v2\/posts\/623\/revisions"}],"predecessor-version":[{"id":630,"href":"https:\/\/thiagosantos.com\/blog\/wp-json\/wp\/v2\/posts\/623\/revisions\/630"}],"wp:attachment":[{"href":"https:\/\/thiagosantos.com\/blog\/wp-json\/wp\/v2\/media?parent=623"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/thiagosantos.com\/blog\/wp-json\/wp\/v2\/categories?post=623"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/thiagosantos.com\/blog\/wp-json\/wp\/v2\/tags?post=623"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}