• Codeby web-security - Курс "Тестирование Веб-Приложений на проникновение с нуля" от команды codeby. Общая теория, подготовка рабочего окружения, пассивный фазинг и фингерпринт, Активный фаззинг, Уязвимости, Пост-эксплуатация, Инструментальные средства, Social Engeneering и многое другое. Подробнее ...

  • Мобильный клиент нашего форума для Android гаджетов доступен в Google Play Market по этой ссылке. Клиент можно скачать с нашего форума по этой ссылке. Последняя версия МК в нашем телеграм канале вот здесь

Нюансы Getdocumentsbykey

  • Автор темы Eugenus
  • Дата начала
E

Eugenus

#1
Добрый день, товарищи лотусники и лотусисты..
Второй раз возникла такая проблема:
Есть агент, который периодически (раз в пять минут по 120 циклов за один запуск) колбасит представление XXX, отбирая из него n-е количество документов через NotesView.GetDocumentsByKey по первому отсортированному столбцу. Так вот, вдруг внезапно, без видимых причин, в отобранной коллекции оказывается 0 документов, при том, что на самом деле их там должно быть больше ста. То есть метод GetDocumentsByKey не возвращает ни одного документа. При пересоздании вида (и соответственно его индекса) все налаживается. Вот собственно вопрос - может ли как-то самопроизвольно сбиться или убиться индекс для какого-либо представления ? На сервере запущены две задачи Update, не думаю, что они могут конфликтовать или причина в этом, но на всяй случай уточню..
 

lmike

нет, пердело совершенство
Lotus team
27.08.2008
6 689
305
#2
может ли как-то самопроизвольно сбиться или убиться индекс
может, причины разные
замечал - если ключ юнид, такое происходит (например)
ставьте регулярной задачей апдейт вьюшки (индекса)
 

ToxaRat

Чёрный маг
Lotus team
06.11.2007
3 240
18
#3
сервер устал ^_^
используется однопроходный алгоритм, проверте возможно быстрее и проще будет всосать весь вид в самодельную структуру и там уже колбаситься
 
E

Eugenus

#4
Хм, ключ не унид, но учту. Спасибо. ToxaRat: Насчет самодельной структуры - можно попробовать, но проблема не носит регулярный характер и обычно все колбасится быстро, без натуги. Да и там переписывать придется половину движка.

Добавлено: Кстати, а как запустить дополнительную задачу на апдейт одного представления ? Можно например агент создать, который будет регулярно рефрешить его, а административнми средствами сделать это можно ?
 

lmike

нет, пердело совершенство
Lotus team
27.08.2008
6 689
305
#5
это и нужно сделать
административнми средствами
создать документ программс в АК (хэлп админа)
команда в консоли:load updall dbname -R -T viewname
в программс её разделить надо и убрать load
 

rinsk

Lotus team
12.11.2009
904
44
#6
Хм, ключ не унид, но учту. Спасибо. ToxaRat: Насчет самодельной структуры - можно попробовать, но проблема не носит регулярный характер и обычно все колбасится быстро, без натуги. Да и там переписывать придется половину движка.
Попробуйте юзать конструкцию вместе с view.refresh. Т.е.

collection=view.GetDocumentsByKey(..)
if collection.Count=0 then
call view.Refresh()
collection=view.GetDocumentsByKey(..)
end if
 
E

Eugenus

#7
Imake:Спасибо. А что значит разделить ? Убрал load и прописал в Command Line
rinsk: Рефреш не прокатывает. Я это представление и обновлял и пересохранял, все равно в коллекции пусто, помогает только пересоздание, видимо, индекс не просто "неполный", а вообще отсутствует...
 

rinsk

Lotus team
12.11.2009
904
44
#8
rinsk: Рефреш не прокатывает. Я это представление и обновлял и пересохранял, все равно в коллекции пусто, помогает только пересоздание, видимо, индекс не просто "неполный", а вообще отсутствует...
Надо провести полный ремонт базы - Fixup\Compac -c -D + все последние фиксы.
Такого рода глюки были при проблемах с диском\контроллером и с самим Домино, когда странным образом летели индексы на нагруженной системе. Щас 852FP1 - врод все стабильно...
 
Вверх Снизу