Foros del Web » Programando para Internet » PHP »

Problemas con la instrucción curl_multi_getcontent

Estas en el tema de Problemas con la instrucción curl_multi_getcontent en el foro de PHP en Foros del Web. Hola a todos, tengo un problemilla bastante complicado, o eso creo yo. Es con la instrucción CURL. Tengo barios crones que utilizan la instrucción CURL ...
  #1 (permalink)  
Antiguo 01/10/2009, 08:40
 
Fecha de Ingreso: diciembre-2008
Mensajes: 129
Antigüedad: 15 años, 3 meses
Puntos: 1
Problemas con la instrucción curl_multi_getcontent

Hola a todos,

tengo un problemilla bastante complicado, o eso creo yo. Es con la instrucción CURL.

Tengo barios crones que utilizan la instrucción CURL con multisesiones, y todos funcionan perfectamente (durante un año). Menos en uno, que dejó de funcionar la semana pasada. Al realizar la instrucción curl_multi_getcontent(), no me devuelve nada. Sin errores ni nada, simplemente no devuelve nada.

Ahora os adjunto el código, pero por favor, abstenerse los que no sepáis que puede ser, porque el tema de configuración del servidor, ... está todo bién (los otros crones tienen exactamente las mismas intrucciones y funcionan bién). Y las URL a que intento acceder sí que tienen datos. Si a alguien le ha pasado lo mismo, o se le ocurre algo, por favor ...

Por cierto, una vez de cada 50 (por decir algo) funciona bién, lo que no puede ser el firewall del servidor destino.

Po lo tanto, fallos que no pueden ser :

- Direcciones bacías.
- Configuración de mi servidor.
- Firewall del servidor destino (que no acepte mis peticiones).

Ahí va el código.

-> Definición URL

$URLS[] = "http://www.url1.com";
$URLS[] = "http://www.url2.com";
$URLS[] = "http://www.url3.com";

-> Iniciación CURL

$mh = curl_multi_init();

foreach ($URLS as $i => $url) {
$conn[$i] = curl_init($url);
curl_setopt($conn[$i], CURLOPT_RETURNTRANSFER, 1);
curl_setopt($conn[$i], CURLOPT_TIMEOUT, 90);
curl_setopt($conn[$i], CURLOPT_SSL_VERIFYPEER, FALSE);
curl_multi_add_handle ($mh,$conn[$i]);
}

-> Peticiones

do {
$mrc = curl_multi_exec($mh, $active);
} while ($mrc == CURLM_CALL_MULTI_PERFORM);

-> Recepción OK

while ($active and $mrc == CURLM_OK) {

if (curl_multi_select($mh) != -1) {

do
{
$mrc = curl_multi_exec($mh, $active);
} while ($mrc == CURLM_CALL_MULTI_PERFORM);
}
}

-> Recepción de los datos

foreach ($URLS as $i => $url) {

$err = curl_error($conn[$i]);

if ($err == '')
{
$xml=curl_multi_getcontent($conn[$i]); <- Bacío
var_dump($xml);
}
else
{
var_dump("Curl error on handle $i: $err");
}

curl_multi_remove_handle($mh,$conn[$i]);
curl_close($conn[$i]);

}

Muchas gracias a todos. Si algún genio de por aquí se le ocurre algo, le estaré infinitamente agradecido.

Muchas gracias.
  #2 (permalink)  
Antiguo 01/10/2009, 09:15
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 17 años, 10 meses
Puntos: 2135
Respuesta: Problemas con la instrucción curl_multi_getcontent

Tema trasladado desde PHP Orientado a Objetos.
  #3 (permalink)  
Antiguo 01/10/2009, 09:57
Avatar de SergeMedina  
Fecha de Ingreso: septiembre-2007
Ubicación: Guadalajara, Jalisco
Mensajes: 459
Antigüedad: 16 años, 6 meses
Puntos: 20
Respuesta: Problemas con la instrucción curl_multi_getcontent

Hola, yo tambien tengo un servicio corriendo con cron. Lo hago para obtener el tipo de cambio diario y guardarlo a mi base de datos. Uso curl para eso. Y a veces me ha pasado que la petición con cURL no me retorna nada. Y mirando los logs de errores de mi aplicación, descubro que cURL no resuelve la url a la que intento acceder, y a veces me pasa que el servidor al que se le hace la petición me regresa error 503, que es un error interno del servidor. Porque no implementas manejo de errores en tu codigo, y que en cada error que exista te escriba en un log y así te das cuenta de que es exactamente lo que esta pasando.

Desgraciadamente yo no he podido resolver esto, ya que son errores de servidores externos, no del mio y probablemente pase lo mismo contigo.

Te adjunto una muestra del log:
Código:
[Sat Apr 25 10:00:02 2009] [curl] [user: ExchangeRate::setResult] There was an error with the service :http://themoneyconverter.com/CNY/rss.xml The server has returned the code 503
(
    [url] => http://themoneyconverter.com/CNY/rss.xml
    [http_code] => 503
    [header_size] => 0
    [request_size] => 71
    [filetime] => -1
    [ssl_verify_result] => 0
    [redirect_count] => 0
    [total_time] => 0.34483
    [namelookup_time] => 0.201054
    [connect_time] => 0.273311
    [pretransfer_time] => 0.273331
    [size_upload] => 0
    [size_download] => 0
    [speed_download] => 0
    [speed_upload] => 0
    [download_content_length] => 162
    [upload_content_length] => 0
    [starttransfer_time] => 0.344822
    [redirect_time] => 0
)
 Error_Curl: The requested URL returned error: 503
__________________
I see dead pixels
  #4 (permalink)  
Antiguo 01/10/2009, 10:37
 
Fecha de Ingreso: diciembre-2008
Mensajes: 129
Antigüedad: 15 años, 3 meses
Puntos: 1
Respuesta: Problemas con la instrucción curl_multi_getcontent

Hola,

SergeMedina, muchísimas gracias por tu respuesta. Pero en mi caso no hay ningún error. Si lo hay, sale en el “var_dump("Curl error on handle $i: $err")”. Y no hay log de errores. O sea que no hay error.

La ejecución de mi script es muy rápida (1 segundo), y eso que accedo a 15 URL diferentes. O sea que creo que las peticiones no llegan al servidor externo. Creo que el tema está en mi servidor, y no en el otro. Pero antes de quejarme a mi servidor, debería saber que es lo que puede estar pasando. Puede ser que bloquee algunas IP es concreto? Es ese caso, porque a veces si que funciona en script?

Dios mio no me siento las piernas ...

PD : espera, que aún me moverán (y con razón, una vez más) este post al foro de servidores ...
  #5 (permalink)  
Antiguo 01/10/2009, 15:18
Avatar de SergeMedina  
Fecha de Ingreso: septiembre-2007
Ubicación: Guadalajara, Jalisco
Mensajes: 459
Antigüedad: 16 años, 6 meses
Puntos: 20
Respuesta: Problemas con la instrucción curl_multi_getcontent

Lo has probado localmente? o en algun servidor de desarrollo? Prueba ingresando con CURL a google.com para ver si hay comunicación.

Suerte.
__________________
I see dead pixels
  #6 (permalink)  
Antiguo 02/10/2009, 02:56
 
Fecha de Ingreso: diciembre-2008
Mensajes: 129
Antigüedad: 15 años, 3 meses
Puntos: 1
Respuesta: Problemas con la instrucción curl_multi_getcontent

En local pasa lo mismo. No entiendo nada.

Y si accedo a Google si hay comunicación. El problema se reproduce solo con un servidor destino en concreto.
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 07:40.