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

Автоматическое срабатывание php-скрипта в определенное время

19.02.2017, 15:32. Показов 6686. Ответов 12

Студворк — интернет-сервис помощи студентам
Здравствуйте. Нужна помощь новичку.
Не могу разобраться как реализовать фоновое выполнения скрипта.

Для того чтобы более доступно объяснить, думаю на примере игры это лучше всего получиться.
Допустим есть браузерная онлайн игра. Где всем начисляется определенное количество золота в определенное время.
Почему в определенное время? Каждый игрок становиться на работу на 1 час, и ровно через час ему должно прийти N количества золота.

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

Прошу помочь рассказать как мне реализовать более проще данный алгоритм.

З.Ы. искал на форуме подобное, к сожалению не нашел ответов.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
19.02.2017, 15:32
Ответы с готовыми решениями:

Выполнение PHP скрипта в определенное время
Требуется в определенное время выполнять скрипт, подскажите хотя бы в каком направлении думать <?php for (;;) { $d = getdate();...

Запуск скрипта в определенное время
Добрый вечер! Есть скриптик, который каждый день в 12 часов должен удалять в базе все содержимое столбца! Но как сделать так, чтобы...

Запуск скрипта в определенное время
Подскажите по сабжу плиз... например как сделано при отправке открыток, те отправить через день, через два и тд. или какого- то числа...

12
 Аватар для N-Star
60 / 60 / 29
Регистрация: 03.11.2016
Сообщений: 292
Записей в блоге: 2
19.02.2017, 16:42
Крон не срабатывает каждую секунду. Да используй крон

Добавлено через 4 минуты
Более простой вариант это рассчитывать добавление золотых сундучков по ходу выполнения скрипта который смотрит сколько прошло времени, допустим прошло 12 часов - и игрок только зашел поиграть - скрипт смотрит сколько прошло время и отправляет игроку 12 сундучков с ромом и дублонами

Добавлено через 35 секунд
А что сервер работает от кортошины?

Добавлено через 59 секунд
https://lenta.ru/internet/2000/05/25/potato/
0
0 / 0 / 0
Регистрация: 18.02.2017
Сообщений: 7
19.02.2017, 16:51  [ТС]
Хм...по типу.
Заходит человек на свой акк и срабатывает такой скрипт каждый раз

if (прошел час с старта работы) { добавить N золота}
else{ничего не происходит а просто показывает сколько до окончания}

Где то такой логикой пользоваться?

Сервер, отличный. Просто думаю, что через крон каждую секунду проверять 100500 записей в базе будет накладно
+если в эту секунду малеха зависнит php_limit, то упустим момент начисления.
0
 Аватар для Grin640
38 / 27 / 3
Регистрация: 24.02.2015
Сообщений: 87
19.02.2017, 16:53
Добрый день!
А игра только на PHP сделана?
Как вариант, можно еще сделать скрипты, которые будут вести статистику, кому сколько золота выдано, когда кто начал работать и высчитывать, кому что давать.
CRON программируется, какой скрипт как часто запускать, можно и каждую минуту, или раз в час настроить, например.
0
 Аватар для N-Star
60 / 60 / 29
Регистрация: 03.11.2016
Сообщений: 292
Записей в блоге: 2
19.02.2017, 17:02
Цитата Сообщение от AlexKoder Посмотреть сообщение
Где то такой логикой пользоваться?
нет.... нужно отмерять время от начала игры или последнего начисления в часах и умножать на золото
0
Почетный модератор
Эксперт HTML/CSSЭксперт PHP
 Аватар для KOPOJI
16844 / 6724 / 880
Регистрация: 12.06.2012
Сообщений: 19,967
19.02.2017, 17:15
AlexKoder, если данные должны автоматом обновится у человека, то смотрите в сторону вебсокетов или sse. В ином случае просто записывайте время окончания "процедуры" (или ее начала), и в том месте, где должна выводиться сумма золота, проверяйте, истекло ли время, и, соответственно, необходимо ли изменять количество золота. То, что до момента обновления страницы юзером может пройти больше одного часа, обычно не так уж и важно.
Альтернатива - использование отложенных процедур и триггеров MySQL. Т.е., добавляете триггер на добавление записи, внутрь запихиваете event, вызывающих процедуру)
0
0 / 0 / 0
Регистрация: 18.02.2017
Сообщений: 7
19.02.2017, 18:47  [ТС]
Цитата Сообщение от Grin640 Посмотреть сообщение
Добрый день!
А игра только на PHP сделана?
Как вариант, можно еще сделать скрипты, которые будут вести статистику, кому сколько золота выдано, когда кто начал работать и высчитывать, кому что давать.
CRON программируется, какой скрипт как часто запускать, можно и каждую минуту, или раз в час настроить, например.
Мне не для игры, просто объяснить задачу на игре легче всего получается.
Если вы хотел спросить про flash, то его на сайте не будет.
Мне надо разобраться с логикой начислений. но тут в том то и беда.

Так вот и интересно, когда эти скрипты будут срабатывать, благодаря крону или заходу человека на свой акк и проверкой: if (прошел час с старта работы) { добавить N золота}
else{ничего не происходит а просто показывает сколько до окончания}
А если крону, то надо проверку каждую секунду делать.

Цитата Сообщение от N-Star
N-Star
нет.... нужно отмерять время от начала игры или последнего начисления в часах и умножать на золото
Ну или так, но процесс запускается, в момент захода на свой акк я так понимаю.

Добавлено через 7 минут
Цитата Сообщение от KOPOJI Посмотреть сообщение
если данные должны автоматом обновится у человека, то смотрите в сторону вебсокетов или sse.
С таким не сталкивался, надо будет почитать.

Цитата Сообщение от KOPOJI Посмотреть сообщение
В ином случае просто записывайте время окончания "процедуры" (или ее начала), и в том месте, где должна выводиться сумма золота, проверяйте, истекло ли время, и, соответственно, необходимо ли изменять количество золота. То, что до момента обновления страницы юзером может пройти больше одного часа, обычно не так уж и важно.
Думаю данный вариант больше всего подходит.

Цитата Сообщение от KOPOJI Посмотреть сообщение
Альтернатива - использование отложенных процедур и триггеров MySQL. Т.е., добавляете триггер на добавление записи, внутрь запихиваете event, вызывающих процедуру)
Тоже не юзал....пойду читать об этом.

Добавлено через 41 минуту
Сделаю и отпишу как получилось реализовать

Добавлено через 37 минут
И так. Сделал следующие.
Записываю в mysql точное до секунд время начала работы $job_start_data.
Каждый раз при заходе пользователя на свой акк, срабатывает скрипт такого формата:

Переводим дату записи в численный формат по секундам = strtotime($job_start_data).
Далее узнаем какое сейчас время time()
Узнаем сколько времени прошло с начала работы $прошло_время = time() - strtotime($job_start_data)
$hour = 3600 (1 час = 3600 секунд)

if($прошло_время >= $hour){Добавляем нужное количества золота и удаляем из базы данную работу}

Думаю вот так норм, может есть советы по реализации?
0
Почетный модератор
Эксперт HTML/CSSЭксперт PHP
 Аватар для KOPOJI
16844 / 6724 / 880
Регистрация: 12.06.2012
Сообщений: 19,967
19.02.2017, 19:51
ну раз вы не хотите посмотреть про триггеры и отложенные события, то все вами описанное можно сделать одним запросом, на стороне мускула.
MySQL
1
UPDATE `table` SET `gold` = `gold` + N WHERE `date` < (NOW() - INTERVAL 1 HOUR)
1
0 / 0 / 0
Регистрация: 18.02.2017
Сообщений: 7
19.02.2017, 20:23  [ТС]
Цитата Сообщение от KOPOJI Посмотреть сообщение
ну раз вы не хотите посмотреть про триггеры и отложенные события, то все вами описанное можно сделать одним запросом, на стороне мускула.
MySQL
1
UPDATE `table` SET `gold` = `gold` + N WHERE `date` < (NOW() - INTERVAL 1 HOUR)
Дааа,большое спасибо.
Но там есть нюанс в том, что этот запрос должен происходить N раз, у каждого пользователя по разному (1,2,10,30 раз.)
И прекращать работать на (1,2,10,30 раз.)
0
Почетный модератор
Эксперт HTML/CSSЭксперт PHP
 Аватар для KOPOJI
16844 / 6724 / 880
Регистрация: 12.06.2012
Сообщений: 19,967
19.02.2017, 21:58
добавьте поле-счетчик количества необходимых пополнений.
0
0 / 0 / 0
Регистрация: 18.02.2017
Сообщений: 7
19.02.2017, 22:23  [ТС]
Цитата Сообщение от KOPOJI Посмотреть сообщение
добавьте поле-счетчик количества необходимых пополнений.
Не понял где это. А можно пример?* Буду очень благодарен.
0
Почетный модератор
Эксперт HTML/CSSЭксперт PHP
 Аватар для KOPOJI
16844 / 6724 / 880
Регистрация: 12.06.2012
Сообщений: 19,967
19.02.2017, 22:35
Создаете доп поле в основной таблице с пользователями, в котором указываете сколько раз должен выполниться код для данного юзера. Либо создаете отдельную таблицу (что, возможно, будет лучше) - где записываете id юзера, количество раз для выполнения и можно доп инфу, по типу id операции.
Потом выполняете запрос наподобие такого
MySQL
1
2
3
4
5
6
UPDATE `money_table` `m`
LEFT JOIN `operation_table` `o`
    USING (`user_id`)
SET
    `m`.`gold` = `m`.`gold` + IF(`o`.`remaining_count` > 0, N, 0)
WHERE `m`.`date` < (NOW() - INTERVAL 1 HOUR);
И второй запрос, на уменьшение счетчика в таблице operation_table
MySQL
1
UPDATE `operation_table` SET `remaining_count` = IF(`remaining_count` > 0, `remaining_count` - 1, `remaining_count`);
Как-то так, в общем. Конечно, это сыровато и навскидку, может и кто получше вариант придумает
1
0 / 0 / 0
Регистрация: 18.02.2017
Сообщений: 7
19.02.2017, 22:38  [ТС]
Ого, большое спасибо, будет чем ночью заняться))
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
19.02.2017, 22:38
Помогаю со студенческими работами здесь

Запуск скрипта в определенное время.
Можно ли сделать так, чтобы мой скрипт запускался в определенное время. Т.е. мне нужно, чтобы скрипт запускался, сравнивал текущее время...

Автоматическое удаление данных из БД через определенное время
Тут вот вскочил такой вопросик,можно ли сделать что бы данные с базы данных удалялись автоматически через определённое время. Если можно,то...

Автоматическое выполнение php скрипта по времени
Добрый день. Алгоритм задачи такой: 1. Задаем время выполнения скрипта по Гринвичу (скрипт выполняется 1 раз в сутки). 2. Как только...

Срабатывание скрипта через определенное время
Подскажите как можно сделать так что бы определенный скрипт срабатывал после определенного времени как только пользователь что то сделал на...

Запуск php через определенное время
Здравствуйте. есть файлик load.php $data = file_get_contents(&quot;http://xxxxxxxxxxxx.xx&quot;); $f = fopen(&quot;xxxxx.xml&quot;,...


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

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
Новый ноутбук
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
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга, Ты же видел моря и метели. Как сменялись короны и стяги, Как эпохи стрелою летели. - Этот мир — это крылья и горы, Снег и пламя, любовь и тревоги, И бескрайние. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru