|
0 / 0 / 0
Регистрация: 03.10.2007
Сообщений: 76
|
|
Ограничение выполнения скрипта по времени06.07.2006, 22:00. Показов 4747. Ответов 10
Метки нет (Все метки)
Добрый день.
Как известно, по умолчанию время работы скрипта max_execution_time на сервере равно 30 сек. Мой скрипт подсчета статистики за день на сайте обрабатывает очень много инфо и поэтому время занимает более 30 сек, о чем выдается ошибка и работа прерывается. Как сделать так, чтобы обрабатывать информацию порциями, чтобы не попадать под 30 сек? Спасибо.<FONT size=4></P>
0
|
|
| 06.07.2006, 22:00 | |
|
Ответы с готовыми решениями:
10
Ограничение выполнения скрипта Ограничение времени загрузки скрипта Планирование времени выполнения скрипта JS |
|
86 / 62 / 69
Регистрация: 15.03.2007
Сообщений: 6,903
|
|
| 06.07.2006, 23:26 | |
|
Если есть возможность сделай запуск скрипта через cron.
0
|
|
|
0 / 0 / 0
Регистрация: 03.10.2007
Сообщений: 76
|
|
| 07.07.2006, 14:48 [ТС] | |
|
К сожалению, я не понимаю, как это можно сделать. Если есть другие варианты средствами php, то буду признателен.
Либо я опишу сейчас проблему, может я неправильно код скрипта написал, поэтому он долго работает. Есть статистика сайта за день. В частности посещаемость страниц. За день в файл записываются все посещаемые страницы (несколько тыс.). Есть второй файл, в котором аккумулируется итог посещаемости за месяц этих страниц. Т.е. есть 2 файла со строками данных. Нужно подсчитать кол-во одинаковых страниц в файле, сравнить с итоговым файлом, приплюсовать кол-во (счетчик)..и так с каждой строкой. Первый файл: Строка1, Строка2, Строка3....Строка 2000. Второй файл: 10-Строка 1, 15-Строка 2.....5-Строка 3000. Где 10, 15, 5 - счетчик посещаемости страниц, который приплюсовывается из Первого файла к цифре во втором файле и туда записывается. MySQL еще не проходил, поэтому только с файлами работаю, надо сделать, чтобы работало, а потом изучать базу данных. Алгоритм: заношу в массивы данные из 2 файлов. Построчно сравниваю строки, если совпадение, то плюсую цифры, заношу в массив, сохраняю файлы. В 30 сек. скрипт не укладывается. Как решить проблему? Спасибо.
0
|
|
|
86 / 62 / 69
Регистрация: 15.03.2007
Сообщений: 6,903
|
|
| 07.07.2006, 19:18 | |
|
Возможно код неэффективно написан. Приведи его здесь, попробуем оптимизировать.
0
|
|
|
0 / 0 / 0
Регистрация: 03.10.2007
Сообщений: 76
|
||||||
| 07.07.2006, 19:44 [ТС] | ||||||
|
Хорошо. $sitestat - первый файл,из него читаем построчно и сравниваем со строками во втором файле $sitestat5. Если совпадение,тосчетчик увеличиваем на 1 и записываем в массив второго файла.
Но хочется посмотреть, можно ли оптимизировать код действительно...
0
|
||||||
|
86 / 62 / 69
Регистрация: 15.03.2007
Сообщений: 6,903
|
||||||
| 07.07.2006, 20:45 | ||||||
|
По моему здесь просто просятся к использованию хеш-массивы. Я переименовал твои переменные $pathroot в $pathToday, $pathroot1 в $pathTotal.
Кроме того не советую тебе в одном скрипте смешивать несколько разных синтаксисов PHP - с использованием { ... } и :, endwhile, endif и т.п. Такой код тяжело читать и сопровождать. Имена переменных тоже аккуратней надо выбирать иначе получается нечитаемый ужас, который ты сам через неделю не сможешь разобрать.
0
|
||||||
|
0 / 0 / 0
Регистрация: 03.10.2007
Сообщений: 76
|
|
| 10.07.2006, 21:26 [ТС] | |
|
Ага, идею начинаю понимать...
Кстати, в 7-й строке у тебя баг, только я не понял, какой именно. Выдается ошибка unexpected '[' on line.... Исправь плз.
0
|
|
|
86 / 62 / 69
Регистрация: 15.03.2007
Сообщений: 6,903
|
||||||
| 10.07.2006, 21:33 | ||||||
|
Замени ее на такой вариант
0
|
||||||
|
86 / 62 / 69
Регистрация: 15.03.2007
Сообщений: 6,903
|
|
| 10.07.2006, 21:34 | |
|
И, кстати, такую простую ошибку мог бы и сам исправить ...
0
|
|
|
0 / 0 / 0
Регистрация: 03.10.2007
Сообщений: 76
|
|
| 13.07.2006, 18:29 [ТС] | |
|
Согласен, только я не понимал смысл, думал, там нечто трудное вычисляется...
Кстати, вот заметил, что в коде "$today[i]", надо ставить $i а не просто i. А так - все работает супер. Заодно разобрался с хешами. Буду использовать. Спасибо <STRONG>bazile</STRONG>!
0
|
|
|
86 / 62 / 69
Регистрация: 15.03.2007
Сообщений: 6,903
|
|
| 13.07.2006, 18:36 | |
|
С $i опечатка вкралась. У себя в примере тоже исправил.
Насколько я понимаю теперь скрипт в 30 секунд успевает выполниться. Сколько именно секунд он тратит на исполнение?
0
|
|
| 13.07.2006, 18:36 | |
|
Помогаю со студенческими работами здесь
11
Засечка времени выполнения скрипта
Результат выполнения программы в консоли пропадает после выполнения скрипта Ограничение доступа php скрипта Ограничение количества выполнений скрипта Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Налог на собак: https:/ / **********/ gallery/ V06K53e
Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf
Пост отсюда. . .
|
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop?
Ниже её машинный перевод.
После долгих разбирательств я наконец-то вернула себе. . .
|
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод
Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод.
Thinkpad X220 Tablet —. . .
|
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта
Симптом:
После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
|
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
|
|
Новый ноутбук
volvo 07.12.2025
Всем привет.
По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне:
Ryzen 5 7533HS
64 Gb DDR5
1Tb NVMe
16" Full HD Display
Win11 Pro
|
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
|
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
|
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов
На странице:
https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/
нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
|
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов.
. . .
|