mongo счетчики по A/B выдаче
Например при такой схеме теста
{
"name":"test_v1",
"label_A": "var_1",
"label_B": "var_2",
"type": "type1",
"active": true,
"counter_A": 5,
"counter_B": 7,
"start_exp": {
"$date": "1999-12-31T21:00:00.000Z"
},
"end_exp": {
"$date": "1999-12-31T21:00:00.000Z"
}
}
Размеры экспериментов небольшие по количеству пользователей, поэтому хотелось бы сразу выдавать 50/50% label_A/label_B.
Если действовать по алгоритму
1. find_one({test by name})
2. update( {test by id}, inc{counter_A} )
то изменения счетчика не атомарны.
Подскажите может кто делал, как атомарно считать и изменить счетчик в mongo?
изменения счетчика через $inc атомарны
знаю, но мне ведь вначале надо получить документ с содержанием счетчиков по тесту, сравнить счетчики, и после этого изменить счетчик. Получить и изменить можно одним действием, а вот чтобы сравнить, для сохранения соотношения 50/50 приходится на два обращения к БД разбивать
а на кой вам стопроцентное соблюдение? это же А/Б и там достаточно примерного соответствия
вообще правильно сделать процентажи по лейблам и выбирать вариант по рендому
это второй вариант который у меня пока в голове 0.5 random на каждый вариант. И ребалансировка весами для rand функции раз в час
Обсуждают сегодня