Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/7: Рейтинг темы: голосов - 7, средняя оценка - 4.86
 Аватар для lxxnutsxxl
0 / 0 / 0
Регистрация: 23.10.2012
Сообщений: 63
MySQL

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

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

Студворк — интернет-сервис помощи студентам
Друзья - 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
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
Цитата Сообщение от 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
Ответ Создать тему
Новые блоги и статьи
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru