Аватар для lxxnutsxxl
0 / 0 / 0
Регистрация: 23.10.2012
Сообщений: 63
1
MySQL

ускорить работу скрипта

07.06.2014, 04:27. Показов 1448. Ответов 1
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Друзья - php скрипт выполняется более 400 секунд!
Подскажите что можно подправить - что бы ускорить работу!

PHP/HTML
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
<?php  
 
$dbh = mysql_connect($dbhost, $dbuser, $dbpswd) or die("Не могу соединиться с MySQL.");
mysql_select_db($database) or die("Не могу подключиться к базе.");
 
$query = "SELECT * FROM streams_new ORDER BY obs DESC";
$result = mysql_query($query); 
 
while  ( ($stream = mysql_fetch_array($result))) 
    {
            $ident = $stream['code'];
            $service = $stream['service'];
 
            if ($service == "1")
            {
                $link = "http://api.justin.tv/api/stream/list.json?channel=".$ident;
                $json = file_get_contents($link);
                $exist = strpos($json, 'name');
                $json_file = @file_get_contents("http://api.justin.tv/api/stream/list.json?channel=".$ident, 0, null, null);
                $json_array = json_decode($json_file, true);
                $obs        = $json_array[0]['channel_count'];      
                if ($exist)
                {
                    $query = "UPDATE streams_new SET state = 'ONLINE', last_start=now(), obs = '$obs' WHERE id = '".$stream['id']."'";
                    mysql_query($query);  
                    echo ($stream['player']." | $link | $obs <br>");            
                }
                else
                {
                    $query = "UPDATE streams_new SET state = 'OFFLINE', obs = '0' WHERE id = '".$stream['id']."'";
                    mysql_query($query);
                    echo ($stream['player']." | OFFLINE<br>");          
                }       
            }
            
            if ($service == "2")
            {
                $link = "http://api.cybergame.tv/w/streams2.php?channel=".$ident;
                $json = file_get_contents($link);
                $exist = strpos($json, 'online');
                $json_file = @file_get_contents("http://api.cybergame.tv/w/streams2.php?channel=".$ident, 0, null, null);
                $json_array = json_decode($json_file, true);
                $obs        = $json_array['viewers'];   
                     
                if ($obs > 0)
                {
                    $query = "UPDATE streams_new SET state = 'ONLINE', last_start=now(), obs = '$obs' WHERE id = '".$stream['id']."'";
                    mysql_query($query);  
                    echo ($stream['player']." | $link | $obs <br>");            
                }
                else
                {
                    $query = "UPDATE streams_new SET state = 'OFFLINE', obs = '0' WHERE id = '".$stream['id']."'";
                    mysql_query($query);
                    echo ($stream['player']." | OFFLINE<br>");          
                }       
            }
            
            if ($service == "3")
            {   
            
            $link = 'http://goodgame.ru/api/getggchannelstatus?id='.$ident;
            $xml = simplexml_load_file($link) or die("Плеер не загружен");
            $status = $xml->stream->status; 
            $obs = $xml->stream->viewers; 
                
                if ($status == Live)
                {
                    $query = "UPDATE streams_new SET state = 'ONLINE', last_start=now(), obs = '$obs' WHERE id = '".$stream['id']."'";
                    mysql_query($query);  
                    echo ($stream['player']." | $link | $obs <br>");            
                }
                else
                {
                    $query = "UPDATE streams_new SET state = 'OFFLINE', obs = '0' WHERE id = '".$stream['id']."'";
                    mysql_query($query);
                    echo ($stream['player']." | OFFLINE<br>");          
                }       
            }
    }
 
    
mysql_close($dbh); 
?>
0
07.06.2014, 04:27
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
07.06.2014, 04:27
Ответы с готовыми решениями:

Ускорить работу интерпретатора
Очень тяжелый скрипт на 2 часа при работе загружает проц только на 10-15%. Есть ли какие-то настройки для apache или php чтобы отдать...

Как ускорить работу вебсайта
Основнок время при работе вебсайта это запрос к базе данный.Как работает жесткий диск: ...

Объсните работу скрипта
&lt;?php ## Использование PREG_OFFSET_CAPTURE. $st = '&lt;b&gt;жирный текст&lt;/b&gt;'; $re = '|&lt;(\w+).*?&gt;(.*?)&lt;/\1&gt;|s'; preg_match($re, $st,...

1
601 / 569 / 104
Регистрация: 07.11.2010
Сообщений: 2,004
08.06.2014, 11:01 2
Цитата Сообщение от lxxnutsxxl Посмотреть сообщение
Друзья - php скрипт выполняется более 400 секунд!
перед и после file_get_contents, simplexml_load_file посмотрите время.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
08.06.2014, 11:01
Помогаю со студенческими работами здесь

Количество выделенной памяти на работу скрипта
Добрый день. В интернете полно примеров, как измерить количество памяти, которое было выделено для одного php скрипта. Пример: ...

Запрос к БД не выполняется из php-скрипта в зависимости от длительности работы скрипта
Не так давно переехал к другому провайдеру со своим VDS-ом. Все настройки идентичны предыдущему. Но перестал работать php-скрипт,...

Вызов php скрипта из другого скрипта
Есть такой код echo ('&lt;img src=&quot;d.php?q='.$f.'&amp;s='.$z0.'&quot; width=&quot;50%&quot;&gt;'); Т.е. передаем скрипту d.php переменные q со значением $f, s...

Передача данных со скрипта на др страницу скрипта
Помогите дописать скрипт Проблема в том что после того как скрипт перенаправляет на другую страницу скрипта с помощью: ...

Как можно связать работу скрипта из балуна с работой скрипта на странице?
Первый раз задаю вопрос, извините если не в тот раздел. В общем, делаю метку через Яндекс карты и в балунКонтент записываю кнопку с...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему

Редактор формул (кликните на картинку в правом углу, чтобы закрыть)
Опции темы

Новые блоги и статьи
Обнаружение аномалий в машинном обучении на Python
stackOverflow 19.02.2025
Аномалии — это отклонения от ожидаемого поведения системы, которые могут указывать как на потенциальные проблемы, так и на интересные возможности для исследования. В контексте машинного обучения. . .
Введение в представления (views) Django
stackOverflow 19.02.2025
Представления (views) - ключевой элемент веб-фреймворка Django, который отвечает за обработку HTTP-запросов и формирование ответов. Они действуют как посредники между данными приложения и шаблонами,. . .
Что такое шаблоны Django и как с ними работать
stackOverflow 19.02.2025
Шаблоны Django - основополагающий компонент фреймворка Django, который позволяет эффективно разделять логику приложения и его визуальное представление. Это очень важный инструмент для. . .
Какой Python Web-фреймворк лучший: Django, Flask или FastAPI?
stackOverflow 19.02.2025
В разработке под веб Python занимает особое место благодаря своей универсальности и богатой экосистеме. При создании веб-приложений разработчики сталкиваются с важным выбором - какой фреймворк. . .
Использование кэша Laravel - полный гайд
bytestream 18.02.2025
Кэширование - один из наиболее эффективных способов повышения производительности веб-приложений. В современном мире, где скорость загрузки страниц напрямую влияет на удержание пользователей и. . .
Создаем REST API в Laravel с аутентификацией и Passport
bytestream 18.02.2025
Разработка современных веб-приложений все чаще требует создания надежного и хорошо структурированного API. REST API стал стандартом де-факто для построения взаимодействия между клиентской и серверной. . .
Пайплайны в Laravel - полный гайд
bytestream 18.02.2025
Разработка современных веб-приложений часто требует обработки сложных процессов, состоящих из множества последовательных шагов. Например, при создании системы комментариев может потребоваться. . .
Как правильно использовать @required в Symfony
bytestream 18.02.2025
При разработке приложений на Symfony мы часто сталкиваемся с необходимостью внедрения зависимостей. Фреймворк предоставляет несколько способов управления этим процессом, и одним из таких инструментов. . .
Система безопасности в Laravel: возможности и примеры
Wired 18.02.2025
Каждый день появляются новые виды атак и уязвимостей, которые могут поставить под угрозу конфиденциальные данные пользователей и функционирование всей системы. В этом контексте выбор надежного. . .
Давайте сравним Django и Laravel
Wired 18.02.2025
Django и Laravel - два мощных инструмента, которые часто сравнивают между собой. Оба фреймворка предлагают разработчикам богатый набор возможностей для создания масштабируемых веб-приложений, но. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru