|
0 / 0 / 0
Регистрация: 18.02.2017
Сообщений: 7
|
|
Автоматическое срабатывание php-скрипта в определенное время19.02.2017, 15:32. Показов 6686. Ответов 12
Здравствуйте. Нужна помощь новичку.
Не могу разобраться как реализовать фоновое выполнения скрипта. Для того чтобы более доступно объяснить, думаю на примере игры это лучше всего получиться. Допустим есть браузерная онлайн игра. Где всем начисляется определенное количество золота в определенное время. Почему в определенное время? Каждый игрок становиться на работу на 1 час, и ровно через час ему должно прийти N количества золота. Единственное что я придумал, так это сделать CRON который будет срабатывать каждую секунду. CRON содержит скрипт который делает выборку с базы по времени начала работы, проверять не прошел ли час и если час прошел, то начислять. Как по мне это очень будет грузить сервер, и уверен есть намного проще решение данной задачи. Прошу помочь рассказать как мне реализовать более проще данный алгоритм. З.Ы. искал на форуме подобное, к сожалению не нашел ответов.
0
|
|
| 19.02.2017, 15:32 | |
|
Ответы с готовыми решениями:
12
Выполнение PHP скрипта в определенное время Запуск скрипта в определенное время Запуск скрипта в определенное время |
|
|
|
| 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
|
|
|
38 / 27 / 3
Регистрация: 24.02.2015
Сообщений: 87
|
|
| 19.02.2017, 16:53 | |
|
Добрый день!
А игра только на PHP сделана? Как вариант, можно еще сделать скрипты, которые будут вести статистику, кому сколько золота выдано, когда кто начал работать и высчитывать, кому что давать. CRON программируется, какой скрипт как часто запускать, можно и каждую минуту, или раз в час настроить, например.
0
|
|
|
Почетный модератор
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 [ТС] | ||||||
|
Если вы хотел спросить про flash, то его на сайте не будет. Мне надо разобраться с логикой начислений. но тут в том то и беда. Так вот и интересно, когда эти скрипты будут срабатывать, благодаря крону или заходу человека на свой акк и проверкой: if (прошел час с старта работы) { добавить N золота} else{ничего не происходит а просто показывает сколько до окончания} А если крону, то надо проверку каждую секунду делать.
Добавлено через 7 минут Добавлено через 41 минуту Сделаю и отпишу как получилось реализовать Добавлено через 37 минут И так. Сделал следующие. Записываю в mysql точное до секунд время начала работы $job_start_data. Каждый раз при заходе пользователя на свой акк, срабатывает скрипт такого формата: Переводим дату записи в численный формат по секундам = strtotime($job_start_data). Далее узнаем какое сейчас время time() Узнаем сколько времени прошло с начала работы $прошло_время = time() - strtotime($job_start_data) $hour = 3600 (1 час = 3600 секунд) if($прошло_время >= $hour){Добавляем нужное количества золота и удаляем из базы данную работу} Думаю вот так норм, может есть советы по реализации?
0
|
||||||
|
Почетный модератор
16844 / 6724 / 880
Регистрация: 12.06.2012
Сообщений: 19,967
|
||||||
| 19.02.2017, 19:51 | ||||||
|
ну раз вы не хотите посмотреть про триггеры и отложенные события, то все вами описанное можно сделать одним запросом, на стороне мускула.
1
|
||||||
|
0 / 0 / 0
Регистрация: 18.02.2017
Сообщений: 7
|
||
| 19.02.2017, 20:23 [ТС] | ||
|
Но там есть нюанс в том, что этот запрос должен происходить N раз, у каждого пользователя по разному (1,2,10,30 раз.) И прекращать работать на (1,2,10,30 раз.)
0
|
||
|
Почетный модератор
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 [ТС] | |
|
0
|
|
|
Почетный модератор
16844 / 6724 / 880
Регистрация: 12.06.2012
Сообщений: 19,967
|
|||||||||||
| 19.02.2017, 22:35 | |||||||||||
|
Создаете доп поле в основной таблице с пользователями, в котором указываете сколько раз должен выполниться код для данного юзера. Либо создаете отдельную таблицу (что, возможно, будет лучше) - где записываете id юзера, количество раз для выполнения и можно доп инфу, по типу id операции.
Потом выполняете запрос наподобие такого
1
|
|||||||||||
|
0 / 0 / 0
Регистрация: 18.02.2017
Сообщений: 7
|
|
| 19.02.2017, 22:38 [ТС] | |
|
Ого, большое спасибо, будет чем ночью заняться))
0
|
|
| 19.02.2017, 22:38 | |
|
Помогаю со студенческими работами здесь
13
Запуск скрипта в определенное время. Автоматическое удаление данных из БД через определенное время Автоматическое выполнение php скрипта по времени Срабатывание скрипта через определенное время Запуск php через определенное время Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
Новый ноутбук
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
— Расскажи мне о Мире, бродяга,
Ты же видел моря и метели.
Как сменялись короны и стяги,
Как эпохи стрелою летели.
- Этот мир — это крылья и горы,
Снег и пламя, любовь и тревоги,
И бескрайние. . .
|