Вход
|
Регистрация
|
Восстановить пароль
Главная
О проекте
Правила
Сообщество
Форум
Чат
Для новичков
Игроков: 13241
[
+0
]
, онлайн:
49
Персонажей: 80448
[
+36
]
Игр: 8746
[
+3
]
Игровых сообщений: 2813307
[
+265
]
Активные игры
-
[18+] Торжество зла
(
3
/
0
)
-
Backseat Driver: No One Rides Alone
(
31
/
0
)
-
Темные дни впереди
(
91
/
451
)
-
Страсти по Интаре
(
30
/
0
)
-
[LS] Гильдия Восходящих Героев II
(
33
/
16
)
-
[Lancer] Operation SOLSTICE RAIN/WINTER SCAR
(
10
/
195
)
-
День, когда лето остановилось
(
20
/
16
)
-
Жил-был кролик
(
4
/
0
)
-
Три истории о семи учениках мастера Сатоши
(
46
/
140
)
-
Ксар
(
50
/
0
)
-
Все активные игры
Набор игроков
-
[Conan 2d20] Завет Восьми Вдов
(
2
/
6
)
-
Тот мир, что звался домом...
(
10
/
156
)
-
Петля трагедии
(
0
/
4
)
-
[Мафия]Приватная мафия-1
(
0
/
4
)
-
[IK] Waragatari
(
4
/
16
)
-
How to run a tavern
(
5
/
27
)
-
[GURPS] Invasion Inc
(
0
/
20
)
-
Fate/Cataclysmic Variable
(
12
/
37
)
-
𝒢𝑅: Прыгай в Ог♨︎нь
(
127
/
95
)
-
[Call of Cthulhu] Пепельный Лотос
(
1
/
15
)
-
Рыцари Мортис
(
52
/
293
)
-
Wars of Cerilia
(
22
/
21
)
-
Титания: Большая Земля [Стратегия]
(
113
/
111
)
-
[D&D 5e] Единственный выход - бежать
(
39
/
207
)
-
[PF2e] Sunburn
(
7
/
18
)
-
Все игры с открытым набором
Завершенные игры
-
Все завершенные игры
Новые блоги
-
[Блог] Гегемония. Управление государством
(
58
/
21
)
-
DM2 на прокачку
(
16
/
230
)
-
Пишем DM, не привлекая внимания санитаров
(
24
/
33
)
-
>> feedback
(
10
/
42
)
-
🪃 Let me solo that 💀
(
93
/
19
)
-
Все активные блоги
Форум
-
Для новичков
(3955)
-
Общий
(18656)
-
Игровые системы
(6558)
-
Набор игроков/поиск мастера
(43161)
-
Котёл идей
(5593)
-
Конкурсы
(19219)
-
Под столом
(21650)
-
Улучшение сайта
(11585)
-
Ошибки
(4565)
-
Новости проекта
(15854)
-
Неролевые игры
(11949)
Опрос об урезании счетчика новых сообщений
Вниз
Вернуться в раздел "Улучшение сайта"
1
2
C-C-C-COMBO BREAKER!
А так, двачую, конечно.
Автор:
victorprice
[
offline
]
, 01.11.2013 23:59
21
Алиса вообще была бы не против, если бы счетчик остался только в активных/наблюдаемых играх+форум.
+1
Автор:
Irene Howlett
[
offline
]
, 03.11.2013 03:56
22
Алиса вообще была бы не против, если бы счетчик остался только в активных/наблюдаемых играх+форум.
Очень годное и логичное предложение, зачет! Сделаю, посмотрим.
Автор:
rakot
[
offline
]
, 04.11.2013 23:57
23
я смотрю мои рассказы в чятике не прошли даром.
Автор:
ScareCrow
[
offline
]
, 09.12.2013 18:20
24
в таком случае пару оптимизаций.
в
"есть таблица в БД, в ней для каждой пары "пользователь - комната в игре/тема на форуме"
хранить надо два счетчика. счетчик сообщений ВСЕГО видимых пользователю и счетчик просмотренных сообщений. Счетчик ВСЕГО сообщений обновлять триггером или в процедуре создания нового сообщения. ввиду "счетчик остался только в активных/наблюдаемых играх+форум" это один достаточно простой запрос.
это уберет запрос подсчета всего сообщений.
счетчик просмотренных сообщений обновлять как "счетчик просмотренных сообщений = Счетчик ВСЕГО" в процедуре показа.
это уберет запрос на "эти последние посты и считает, сколько сообщений появилось с тех пор."
Автор:
ScareCrow
[
offline
]
, 09.12.2013 18:32
|
Отредактировано 09.12.2013 в 18:33
25
оффтоп
Комментарий
от
Fiona El Tor
, 20.08.2012 20:29
хранить надо два счетчика. счетчик сообщений ВСЕГО видимых пользователю и счетчик просмотренных сообщений. Счетчик ВСЕГО сообщений обновлять триггером или в процедуре создания нового сообщения. ввиду "счетчик остался только в активных/наблюдаемых играх+форум" это один достаточно простой запрос.
это уберет запрос подсчета всего сообщений.
счетчик просмотренных сообщений обновлять как "счетчик просмотренных сообщений = Счетчик ВСЕГО" в процедуре показа.
это уберет запрос на "эти последние посты и считает, сколько сообщений появилось с тех пор."
Пост будет отправляться 15 минут - пока алгоритм обойдет всех пользователей и инкрементирует. И скорость работы алгоритма будет снижаться пропорционально количеству юзверей.
Мб прикрутить каждому юзверю поле с датой последнего поста? Если дата последнего поста в поле/теме не соответствует тому, что у юзера прописана, считать нечитанные посты? (Мы все еще храним переменные со счетчиками, как и предложено, но обновляем их только когда юзверь вползает на форум и только в том случае, если дата последнего поста с момента последнего посещения поменялась.)
Я считаю, это позволит сократить количество изменений базы до минимума, плюс не будет нагружать сервер скачкообразно, а распределит нагрузку по времени. Конечно, от моментов, когда 100500 юзеров сидит одновременно и нервно обновляет форум не спасет (при условии, что новые сообщения появляются), но уже ничего.
Но если чего - я диванный теоретик. вполне возможно что примерно так и реализовано.
Автор:
LedoCool
[
offline
]
, 09.12.2013 19:24
26
Пост будет отправляться 15 минут - пока алгоритм обойдет всех пользователей и инкрементирует. И скорость работы алгоритма будет снижаться пропорционально количеству юзверей.
ввиду "счетчик остался только в активных/наблюдаемых играх+форум" это
один
достаточно простой запрос.
Автор:
ScareCrow
[
offline
]
, 10.12.2013 15:39
27
Если дата последнего поста в поле/теме не соответствует тому, что у юзера прописана, считать нечитанные посты?
нечитанные посты это тупо разница между счетчиком ВСЕГО и счетчиком ПРОЧИТАННЫЕ.
обновлять можно да, если только эта разница больше нуля.
Автор:
ScareCrow
[
offline
]
, 10.12.2013 15:41
28
ввиду "счетчик остался только в активных/наблюдаемых играх+форум" это один достаточно простой запрос.
Вот с такой фразы и начались тормоза в windows. :D
Но я на всякий случай напомню, что я диванный теоретик без реального опыта в реализации подобных баз. Поэтому мои посты тут можно считать оффтопом.
Автор:
LedoCool
[
offline
]
, 11.12.2013 14:22
29
1
2
Вверх
Вернуться в раздел "Улучшение сайта"
Зеркала
-
Основной сайт
-
Зеркало в России
Опросы
Нет активных опросов.
Жалобы и предложения
-
Оставить жалобу или предложение
-
Сообщить об ошибке
Загрузка данных...
Помочь проекту
Средства на покрытие расходов и
развитие проекта в 2026:
17367/115000 ₽
Социальные сети
-
Группа во Вконтакте
Партнеры
↑
вверх