2014-11-14 1 views
0

У меня проблема, которую я пытался решить за последние пару дней. У меня есть сайт, где я сканирую новости, и это отлично работает. Недавно, однако, я столкнулся с проблемой с моим анализатором_скриптом, поскольку он, по-видимому, превышает ограничение, установленное моим веб-хостом. По-видимому, время max_execution составляет около 1 минуты, а мой сценарий занимает больше времени. И я не могу настроить это в скрипте php.ini, так как я размещаю свой сайт на общедоступном сервере. Что мне делать? Нужно ли переписывать мой сценарий?max_execution time php

Я ценю вашу помощь! Мой сценарий ниже:

<?php 
    $array = array(); 
    $sub_array = array(); 
    $analyzer_ids = array(); 

$res5 = mysqli_query($con,"SELECT id,status FROM statuz ORDER BY id DESC LIMIT 1"); 
$row5 = mysqli_fetch_array($res5); 

$status = $row5['status']; 
$status_id = $row5['id']; 

if($status == 2) { 

    $res1 = mysqli_query($con,"SELECT tag, id FROM tags"); 
    while($row1 = mysqli_fetch_array($res1)) { 
     $tag = $row1['tag']; 
     $id = $row1['id']; 

     $res2 = mysqli_query($con,"SELECT sub_tag FROM sub_tags WHERE tag_id = '$id'"); 
     while($row2 = mysqli_fetch_array($res2)) { 
      $sub_tag = $row2['sub_tag']; 
      $sub_tag = strtolower($sub_tag); 
      $sub_array[] = $sub_tag; 
     } 

     $array[] = array('tag_id' => $id, 'tag' => $tag, 'sub_tag' => $sub_array); 
     $sub_array = array(); 
    } 

    mysqli_query($con,"INSERT INTO analyzer_queue (crawler_id, status) 
    (SELECT id,0 FROM crawlers)"); 

    $initial_res = mysqli_query($con,"SELECT crawler_id,id FROM analyzer_queue WHERE status = '0'"); 
    while($initial_row = mysqli_fetch_array($initial_res)) { 

     $analyzer_id = $initial_row['id']; 
     $start_crawler_id = $initial_row['crawler_id']; 
     mysqli_query($con,"UPDATE analyzer_queue SET status = '1' WHERE crawler_id = '$start_crawler_id' ORDER BY id DESC LIMIT 1"); 
     $analyzer_ids[] = $analyzer_id; 

       $res = mysqli_query($con,"SELECT cr.title, cr.content, cr.id 
       FROM crawler_results cr 
       INNER JOIN crawlers c 
       ON c.newspaper_id = cr.newspaper_id 
       WHERE c.id = '$start_crawler_id' 
       AND status = '3' 
       LIMIT 10"); 
       while($row = mysqli_fetch_array($res)) { 

        $article_id = $row['id']; 
        $title = $row['title']; 
        $content = $row['content']; 

        $content = strip_tags($content); 
        $content = strtolower($content); 
        $title = strtolower($title); 


        $count = array(); 
        foreach ($array as $tag) { 
         $regex = '/(?:\b' . preg_quote($tag['tag'], '/'); 
         foreach ($tag['sub_tag'] as $sub) { 
          $regex .= '\b)|(?:\b' . preg_quote($sub, '/'); 
         } 
         $regex .= '\b)/i'; 
         $count_content = preg_match_all($regex, $content, $count_content); 
         $count_title = preg_match_all($regex, $title, $count_title); 
         $count_total[$tag['tag']] = $count_content + $count_title; 
         $total_count = $count_total[$tag['tag']]; 

         $tag_name = $tag['tag']; 

         $res5 = mysqli_query($con,"SELECT id FROM tags WHERE tag = '$tag_name'"); 
         $row5 = mysqli_fetch_array($res5); 

         $tag_id = $row5['id']; 


         if($total_count != 0) { 
          mysqli_query($con,"INSERT INTO article_tags (article_id,tag_id,count_tags) VALUES('$article_id','$tag_id','$total_count')"); 
         } 

         echo$count_total[$tag['tag']]; 
         echo"<br /><br />"; 
        } 

        echo"<pre>"; 
        print_r($count_total); 
        echo"</pre>"; 

        mysqli_query($con,"UPDATE crawler_results SET status = '2', analyzer_id = '$analyzer_id' WHERE id = '$article_id'"); 
       } 
       mysqli_query($con,"UPDATE analyzer_queue SET status = '2' WHERE crawler_id = '$start_crawler_id' ORDER BY id DESC LIMIT 1"); 

     } 
     mysqli_query($con,"UPDATE crawler_results SET status = '4' WHERE analyzer_id NOT IN (".implode(',',$analyzer_ids).")"); 
     mysqli_query($con,"UPDATE statuz SET status = '3' WHERE id = '$status_id'"); 
     print_r($analyzer_ids); 

} else { 
    echo"Not ready yet"; 
} 




?> 
+0

При использовании 'mysqli' вы должны использовать параметризованные запросы и [' bind_param'] (http://php.net/manual/en/mysqli- stmt.bind-param.php), чтобы добавить данные пользователя в ваш запрос. ** НЕ используйте ** интерполирование строк, чтобы выполнить это, потому что вы создадите серьезные [SQL-инъекции ошибок] (http://bobby-tables.com/). – tadman

ответ

0

Попробуйте это:

ini_set('max_execution_time', 0); 

The original Post

+0

Perfect KrustyBox! Это было впечатляюще быстро! Чей ответ я принимаю? oliakaoil предоставил более подробную информацию, но вы были на 3 минуты быстрее. –

+0

Мой код был всем, что вам нужно. У меня меньше очков, чем @oliakaoil ... :) – KrustyBox

1

Вы можете использовать ini_set в верхней части сценария, как это:

ini_set('max_execution_time' , 300); 

выше вызов будет установить максимальное время выполнения сценария до пяти минут. Вот страница документа:

http://php.net/manual/en/function.ini-set.php

Если ваш хост позволяет, вы можете также рассмотреть вопрос о выполнении этого сценария через хроны или какой-либо другие планирования демона. PHP-скрипты, запущенные в контексте cli, обычно не имеют ограничения по времени выполнения или намного выше.

+0

Большое вам спасибо за ответ на мой вопрос, что быстро oliakaoil! К сожалению, KrustyBox был на 3 минуты быстрее вас, но вы предоставили более подробную информацию в своем ответе. Что я делаю? –

+0

Добро пожаловать. Я менее всего объективен в ответе на вопрос «Что мне делать» :-), поэтому я воздержусь. – oliakaoil