Ускоритель запросов в файловых базах 1с8

Публикация № 137311

Разработка - Практика программирования

Предлагается простая для внедрения в любую конфигурацию методика ускорения выполнения запросов в файловых базах 1с8. Суть идеи – выполнять запросы в специально запущенном клиенте на том же компьютере, где находится база. За счет этого удается существенно, в 5-10 раз ускорить выполнение запросов.
Предыстория: Ко мне обратились складские работники. Т.к. количество пользователей базы 1с8 было небольшое, то им поставили файловую базу. Но запросы выполнялись очень тяжелые, а база весила около 20 Гб. Поэтому запросы работали очень медленно. Причем на центральном компьютере типичный запрос выполнялся 1 минуту, а на компьютерах сети – 5 минут. Нужно было как-то ускорять запросы. И тогда я придумал способ, при котором запросы выполняются на центральном компьютере. Скорость работы нормализовалась до той самой одной минуты.

Запуск сервера

На компьютере, где находится база, запускается сервер менеджера запросов:

Путь – это путь к базе данных, определяется автоматически.

Один менджер может обрабатывать несколько клиентов, формирующих запросы, при этом запросы ставятся в очередь.

Если требуется параллельное выполнение запросов, нужно запустить несколько экземпляров 1с на компьютере с базой, в каждом указать свой номер соединения.

Для запуска менеджера запросов нужно нажать кнопку «Запустить».

При запуске сервера удаляются все предыдущие, старые, запросы по этому номеру соединения, если не установлена Галочка «При запуске не удалять запросы».

Работу сервера можно прервать кнопкой CTRL+Pause.

Запуск клиента

На компьютере в локальной сети нужно запустить менеджер запросов на закладке «Клиент». Включить/ выключить использование менеджера запросов, указать желаемый номер соединения. Затем нажать кнопку «Установить».

Эти настройки запоминаются в настройках базы данных (СохранитьЗначение). Повторно их можно не настраивать.

 

 

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

Пока клиент ожидает обработки запроса сервером, выдается сообщение «Ждем ответ от менеджера запросов…», выполнение в этом месте можно прервать по CTRL+PAUSE.

Взаимодействие клиента и сервера

Для проверки взаимодействия клиента и сервера:

  1. Запустим сервер на соединении 1.
  2. Установим на клиенте номер соединения 1.
  3. Нажмем на клиенте кнопку «Проверить». При этом будет выполнен тестовый запрос «ВЫБРАТЬ * ИЗ Константы» и выведен его результат:
  4. На сервере можно увидеть протокол обработки запроса:

Особенности работы

Для обмена файлами используется каталог «Queries» в каталоге базы данных. При необходимости он создается.

Запрос передается как сериализированная в файл структура. Ответ выдается как сериализированный результат выполнения запроса.

Файлы запросов и ответов имеют префиксы query и answer соответственно, за которыми следует номер соединения и уникальный GUID запроса. Расширение txt.

Обработка хорошо оттестирована на практике. Были проблемы с блокировкой файлов при редких стечениях обстоятельств, они были выявлены и изолированы специальными условиями. Так что можно смело применять! Они были выявлены и изолированы специальными условиями. Так что можно смело применять!

Методика внедрения

Помимо обработки, добавьте в конфигурацию клиентский не глобальный модуль пимМенеджерЗапросов  (текст прилагается в архиве).

Все вызовы запросов, которые вы хотите ускорить нужно заменить с кода вида:

Результат = З.Выполнить();

На следующий код:

Результат = пимМенеджерЗапросов.ВыполнитьЗапрос(З);

Скачать файлы

Наименование Файл Версия Размер
down.zip

.zip 9,83Kb
24.05.12
106
.zip 9,83Kb 106 Скачать

Специальные предложения

Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. Kom-off 25.05.12 08:51 Сейчас в теме
они были выявлены и изолированы специальными условиями. Так что можно смело применять!

В тексте публикации эта фраза присутствует два раза. Я бы подредактировал. Плюс за идею.
2. alexk-is 6485 25.05.12 10:22 Сейчас в теме
(0) Прикольно. Старые технологии возвращаются. Я такую штуку сделал в 1995. Но у меня в таком режиме выполнялись не только операции чтения, но и операции записи.
3. fishca 1185 25.05.12 11:42 Сейчас в теме
я вот одного не пойму, не проще ли было использовать терминальные подключения?
4. ogursoft 25.05.12 11:59 Сейчас в теме
Если есть отдельный компьютер на котором стоит база, то почему бы и не развернуть на нем и Sql сервер и сервер приложений? Он как раз для этого и нужен. Вы изобретаете, то, что 1С уже сразу сделало.
5. fixin 4013 25.05.12 13:22 Сейчас в теме
(4) про 42 тысячи на ключ для сервера 1с и про цену SQL сервера (ладно, пусть будет IBM бесплатный, не будем считать) вы забыли? Я изобретаю, потому что не все готовы платить 42 тысячи за удовольствие.
(3) терминальные подключения также стоят денюжок... Примерно тех же самых.
6. q_i 419 25.05.12 18:29 Сейчас в теме
про 42 тысячи на ключ для сервера 1с и про цену SQL сервера (ладно, пусть будет IBM бесплатный, не будем считать) вы забыли?

(5) а разве Linux уже отменили? ;)
7. fixin 4013 25.05.12 21:32 Сейчас в теме
(6) мдя, советнички...
А что, сервер 1С:Предприятия под линукс бесплатный? Те же 42 тыщ. А без сервера 1С:Предприятия 1С с SQL работать не умеет.
8. q_i 419 25.05.12 22:15 Сейчас в теме
(7) насколько я в курсе - до 12 пользователей в Linux-версии серверный ключ не требуется. требуется только наличие клиентских лицензий. к сожалению, не могу никак найти инф.письмо на этот счёт. (( если кто знает где это прописано - подскажите, плз.
9. GreyJoJo 25.05.12 22:22 Сейчас в теме
(8) q_i,
Это "недокументированная возможность" :)
Ключ не требует, но юридически это нельзя делать :)
Дмитрий74Чел; +1 Ответить
10. fixin 4013 25.05.12 23:32 Сейчас в теме
11. q_i 419 26.05.12 00:03 Сейчас в теме
12. GreyJoJo 26.05.12 00:24 Сейчас в теме
(11) q_i,
100%

Этот вариант был потенциально зарезервирован для более дешевых лицензий.

в 8.2, по-моему, уже не работает.
13. q_i 419 26.05.12 00:33 Сейчас в теме
64. madmpro 08.06.12 12:59 Сейчас в теме
(8) q_i,
ОГО! Полезная инфа, я уже готовил бабло :)...
65. fixin 4013 08.06.12 13:20 Сейчас в теме
66. cool.vlad4 45 08.06.12 13:26 Сейчас в теме
(64) с юридич. точки зрения не имеет значения используете вы вариант, описанный в 8, или поставили взломанный сервер, вы одинаково нарушаете закон
TravkinSV; +1 Ответить
67. q_i 419 08.06.12 19:17 Сейчас в теме
(64) gorodok11, мы отправляли по этому поводу запрос в 1С, но там нас послали ... читать FAQ по лицензированию, в котором (конечно же) данный вопрос не рассмотрен. в общем на текущий момент у меня нет 100% инфы что использование сервера подобным образом легально. впрочем у меня также нет и 100% инфы что оно нелегально, хотя многие в этой ветке утверждают, что это так (причём утверждают с такой уверенностью, что я даже уже начинаю им немного верить).
69. madmpro 14.06.12 13:58 Сейчас в теме
(67) q_i, (66) cool.vlad4, (65) Вы меня окончательно запутали ;). Сейчас в базе работают 10 ю-зверей, но скоро будут около 30-и. "Пузо" стремительно растет, поэтому рассматриваю вариант установки сервера на DB2. Так что лавэ, зелень, и прочая трава деньги будем наскребать на серверную лицензию по любому :).
14. hogik 435 26.05.12 15:49 Сейчас в теме
(0)
Все гениальное - просто! ;-)
P.S. Жаль, что так и не удалось посадить файловую версию "восьмерки" на простую клиент-серверную СУБД. :-(
Было бы дешево и сердито... ;-)
17. fixin 4013 28.05.12 11:15 Сейчас в теме
(14) как то стремно, что между мелким и крупным нет среднего варианта и шаг между ними - 42 штуки...

(15) дык идея вознила из практики. не знал только, можно ли сериализовать РезультатЗапроса. Оказалось, можно, и это клево...

(16) деньги можно у автора поспрашивать, в отдельной специальной ветке для этого... ;-)
21. hogik 435 28.05.12 17:27 Сейчас в теме
(17)
Сергей (fixin).
Думаю, на самом деле больше чем "42 штуки"(с). Учитывая железо, ОС-ы, квалификацию поддержки и т.д. А средний вариант "существует" по смыслу. Разработчикам 1С-а ОНО совсем не надо - и так успешно продаётся.
Я всё ношусь с идеей сделать двухуровневую схему. Для этого существует подходящая простая клиент-серверная СУБД под интерфейс взаимодействия 1С-а со своей файловой СУБД-ой. Но, я один уже не смогу эту задачу поднять... :-( А супер-спецы нашего сообщества не проявляют интереса к подобным задачам. Печально и странно... :-(
23. fixin 4013 28.05.12 17:57 Сейчас в теме
(21) че то не понимаю, как вы это хотите сделать? формат то 1с файловый закрытый и раскрывать они его не собираются... Да, жаль, что в 1с есть только бюджетно и плохо (файловый) или скульно и дорого (сервер 1с)

(22) ха, ничего себе проще, внешнюю компоненту написать. И ксати, насколько я понимаю у товарища http://infostart.ru/public/93643/ речь о поддержании ком-соединения на одном и том же компьютере. А для ускорения нужно создавать ком-объект на компьютере с базой, а не на компьютере-клиенте. Возможно, но из-за идиотизма мелкомягких с правами нереально.
25. hogik 435 28.05.12 18:24 Сейчас в теме
27. fixin 4013 28.05.12 18:27 Сейчас в теме
(25) все равно не понял, что вы имеете ввиду, там про 1с77 как бе. а там был ДБФ а не 1СД.
(26) создавать ком-объект на текущем и удаленном компе - это две большие разницы как бе... гыгыгы...
30. hogik 435 28.05.12 18:44 Сейчас в теме
(27)
Нет никакой разницы "ДБФ а не 1СД"(с).
Подмена "движка" полностью, а не доступ к существующему формату данных.
Кроме всего, еще и снимается ограничение на размер БД.
Да. Есть разница в 7.7 или 8.х в сложности "вскрытия" интерфейса. И только - в этом.
Но, после появления http://infostart.ru/public/102065/ у меня прибавилось надежды на возможность такого решения. ;-)
26. comol 4382 28.05.12 18:25 Сейчас в теме
(23) Да не... там пул соединений COM+ о поддержании соединения сам позаботится. В статье просто общая методика описана, вцелом задачу создать и поддерживать COM соединение на одном компьютере это решит.
Там не совсем внешняя компонента - просто маленькая библиотечка со стандартным шаблоном. По факту - "3 строчки кода". С правами есть заморочки... но ещё когда сервер 8.0 настраивали все привыкли вроде...
33. comol 4382 28.05.12 21:45 Сейчас в теме
(26) comol, После настройки разница в 1 параметре функции :)
39. DMSDeveloper 29.05.12 11:51 Сейчас в теме
(23)
Все реально. Com+ Он же DCom. Настраивается все очень просто. Если сеть доменная нужно только настроить доступ к компоненте для групп, в которых пользователи напиханы. если не домен, то просто продублировать пользователей, хотя скорее всего они и так продублированы. Ну или настроить доступ для гостевой учетки.
40. fixin 4013 29.05.12 12:14 Сейчас в теме
(39) у нас сеть не доменная, ничё? Было бы логично настроить доступ к созданию конкретного объекта по логину-паролю (не пользователя, а именно для этой операции), но мелкомягкие до этого не догнали...
41. DMSDeveloper 29.05.12 14:11 Сейчас в теме
(40) В том то и дело, что по логину и паролю не совсем удобно, по крайней мере мне,
Настроил один раз гостевой доступ и все - все работают (всё работает).
Я подобным образом использую автоматизацию с системой traffic inspector.
Кстати у них на сайте тоже есть информация как настроить Com+. Не рекламы ради - http://www.smart-soft.ru/ru/support/documentation/dcom7/ Настройка доступа по DCom можно почитать до 4 пункта включительно. Далее идет уже конкретика.

В своем коде просто пишем следующее
ComУдаленный = Новый ComОбъект("ИмяОбъекта", "СерверНаКоторомОбъектЖивет");

А если сделать для своего объекта инсталятор прокси, то адрес сервера можно не использовать.
Как сделать инсталятор написано в публикации http://infostart.ru/public/93643/
42. fixin 4013 29.05.12 14:41 Сейчас в теме
(41) почитаю, конечно. Идея использовать удаленный COM-сервер присутствовала изначально. Но в бездоменной сети до сих пор у меня не получилось создать COM-объект 1С удаленно. Это говорит не столько о моих кривых руках, сколько о том, что задача не тривиальна, т.е. нужно ковыряться в тонкостях доступа винды, а они могут быть в каждой версии ОС свои. Как-то так. Поэтому мне больше нравится моё нативное решение.
43. MRAK 716 29.05.12 16:38 Сейчас в теме
(21) это уже есть в УФ. Можно файловую базу поднять на вебсервере
44. fixin 4013 29.05.12 16:55 Сейчас в теме
(43) я в курсе про 82 (можно и через тонкого клиента быстро гонять), но не забудьте еще переписать все формы на управляемые, если чо...
Слишком велики затраты для случая базы 1с81. А тут дешево и сердито как бе.
45. hogik 435 29.05.12 17:23 Сейчас в теме
(43)
Роман (MRAK).
Я не понял ЧТО есть в УФ? Или Вы ошиблись номером сообщения?
46. fixin 4013 29.05.12 17:31 Сейчас в теме
(45) в управляемых формах есть возможность выполнять весь код на сервере, оттого и название - тонкий клиент.
то бишь там задача ускорения выполнения для файловых баз данных не стоит - все выполняется на сервере и так.
47. hogik 435 29.05.12 18:00 Сейчас в теме
(46)
Сергей (fixin).
Спасибо за разъяснения. Теперь я буду знать что такое тонкий клиент. Всегда хотел об этом узнать. Но боялся спросить... :-)
Попробуйте вникнуть в то, что я выше написал. Мне интересно Ваше мнение и Ваше "понимание" моего предложения.
48. fixin 4013 29.05.12 18:22 Сейчас в теме
(47) а, вы всё буквоедствуете?
Просто товарищ мрак сказал, что вместо набора файловая база + терминальный доступ можно использовать файловая база + тонкие клиенты.
Конечно же, Мрак не имел ввиду, что есть двухуровневая система СУБД + клиенты, всегда есть СУБД + сервер 1С + клиенты, к сожалению.
49. hogik 435 29.05.12 18:36 Сейчас в теме
(48)
Сергей (fixin).
О чем Вы? Какое "всё буквоедствуете" ?
Вопрос был поднят конкретный. Про возможность наличия двухуровневой архитектуры. Чтобы не писать: "к сожалению"(с).
51. MRAK 716 29.05.12 19:36 Сейчас в теме
(49) ну да, я несколько неточно ответил.
Ибо двухуровневка 1С - это просто фантастика. Вы хотите весь серверный код 1С переписать в хранимки DB/SQL/Oracle? Слишком уж трудозатратной поддержка окажется, не находите? На порядок, а то и в 100 раз трудозатратнее, чем на данный момент.
Поправьте, если ошибаюсь.

P.S. Сам пару лет поддерживал и дорабатывал учетные системы на Oracle/PL SQL...
52. hogik 435 29.05.12 19:50 Сейчас в теме
(51)
Роман (MRAK).
В (25) и (30) сообщениях есть ссылки. Ничего переписывать не требуется. Есть такой термин - "подмена движка". Т.е. файловая версия "будет" работать с другой СУБД в клиент-серверном режиме. Два уровня...
53. fixin 4013 29.05.12 20:30 Сейчас в теме
(52) подменить движок еще нужно, этого счас нет. Это раз. Во-вторых это противоречит лицензии 1с, а следовательно нелегально. Это два. Безперспективно.
55. hogik 435 29.05.12 21:15 Сейчас в теме
(53)
Сергей (fixin).
Спасибо за Ваше мнение. Хотя, у меня складывается впечатление, что Вы на мои вопросы-интересы посмотрели в контексте "оперативное и быстрое лечение .... нужны быстрые и дешевые решения"(с). Т.е. слишком узко-конкретно... :-(
56. fixin 4013 30.05.12 10:47 Сейчас в теме
(55) именно. свертка базы - процедура дорогая и длительная. А вот ускоритель запросов - если он уже написан - берешь и пользуешься. Ну даже если не написан, написать то было недолго...

Вот у меня грыжа, например. Можно лечить оперативно, но это долго, нудно, с неизвестными последствиями. А можно мануалкой и иголками периодически подлечивать. И ниче, терпимо. Так и здесь.
15. khaoos 239 28.05.12 05:44 Сейчас в теме
Поддерживаю разработку и автора. В регионах особенно не любят платить за клиент-серверный вариант. Думаю, в скором времени не пригодится, так как ухожу в крупную организацию, где такой проблемы стоять не будет. Но на заметку возьму.
18. DMSDeveloper 28.05.12 11:28 Сейчас в теме
(0)Как говорится - Все гениальное - Просто!
Взял на заметку. Мне как раз нужно что то подобное реализовать, только не с запросами.
19. comol 4382 28.05.12 15:23 Сейчас в теме
По-моему задача средствами COM+ проще решается. Без обёртки не зарегистрируется, но обёртка это 5 мин, да и была вроде уже на инфостарте. Будет 1С запущенная на другом компьютере - по сути "сервер".. как в 8.0 если кто помнит...
20. fixin 4013 28.05.12 17:17 Сейчас в теме
(19) что вы подразумеваете под оберткой? тут болтается без ответа мой вопрос, как создать Ком-объект 1с на другом компьютере. Есть заморочка с правами доступа для этого. А так конечно, проще было бы через КОМ создавать, управлять и не городить менеджеров запросов. ;-)
22. comol 4382 28.05.12 17:35 Сейчас в теме
(20) "на птичьем" обёртка это ещё одна компонента, которая просто возвращает "нашу" компоненту, нужна только для поддержки интерфейсов COM+... ну или проще .net.
COM+ собственно и нужен для создания объектов на удаленном компьютере.
Вот тут http://infostart.ru/public/93643/ человек вроде всё сделал и описал даже как и что работает...
24. mirsant 28.05.12 18:01 Сейчас в теме
про 42 тысячи на ключ для сервера 1с и про цену SQL сервера (ладно, пусть будет IBM бесплатный, не будем считать) вы забыли? Я изобретаю, потому что не все готовы платить 42 тысячи за удовольствие.
28. Necytij 28.05.12 18:30 Сейчас в теме
Доброго дня. А разве вот эта публикация не описывает тот же функционал, но двумя годами ранее? 1CHServer
29. dagroma 114 28.05.12 18:40 Сейчас в теме
(28) Там возвращается только текст, а тут результат запроса. Две большие разницы.
34. Necytij 28.05.12 22:21 Сейчас в теме
(29) dagroma, (31) fixin
Ммда, слона-то я и не заметил. Обвинения сняты ))
31. fixin 4013 28.05.12 20:08 Сейчас в теме
(28) там усложненная схема. нужно брандмауэр настраивать и прочее, из-ха ХТТП протокола. теоретически можно и результат запроса возвращать, сериализовав, но это надо докручивать. Хотя может и эффективнее выйдет, не знаю.
Я реализовал просто и дубово - бери и пользуйся.. ускоряйся.. ;-)


(30) все эти препарирования с точки зрения закона незаконны и по сути выглядят аналогом использования эмулятора 1с.. так что не катит. Проще свою 1с написать.
32. hogik 435 28.05.12 21:20 Сейчас в теме
(31)
По поводу законности - вопрос открытый. Я привел ссылку выше. Та разработка не нарушает никаких законов. Возможно она нарушает лицензионные соглашения. Которые как раз и нарушают законы. ;-)
По поводу "эмулятора 1с"(с) и "Проще свою 1с написать"(с) теперь я ничего не понял. Ваше текущая разработка больше напоминает эмулятор, чем подмена "движка". Для подмены "движка" пользователь изменяет в своей системе ОДИН символ. :-)
35. salexdv 1896 29.05.12 09:40 Сейчас в теме
(31) Схема там может и усложненная, но более гибкая. Сериализацию ответа можно легко реализовать. Плюс 1CHServer не вешает сеанс 1C:Предприятия с процессором и дает возможность запускать "сервер" на компьютере, расположенном на другом конце света.
Хотя, конечно, согласен он более ориентирован на разработчиков, чем на... бери и пользуйся... :-)
36. fixin 4013 29.05.12 11:21 Сейчас в теме
(35) у вас цель другая - моя цель ускорить выполнение запросов. Поэтому запрос должен выполняться на центральном сервере, там, где база данных находится. По сути это аналог терминального доступа. Ваша сентенция про "другой конец света" тут неуместна. Не для этой задачи.
Не спорю, вашу приблуду можно заюзать для ускорения. МОЖНО а у меня уже ГОТОВО. Сделаете ускорение, по аналогичной моей схеме - не вопрос, пусть пользователи выбирают. Пока же у вас ускорение еще не готово. Но потенциально может быть сделано, не спорю. Только смысл ковыряться с настройками брандмауэра, установкой чужих внешних компонент, если то же самое может быть сделано и нативными (встроенными) средствами, как это сделал я?
37. salexdv 1896 29.05.12 11:27 Сейчас в теме
(36) Смысл есть, если задача стоит по другому. Про похожесть диспут вы начали, а не я :-)
38. fixin 4013 29.05.12 11:40 Сейчас в теме
(37) ну тогда замнем, раз всё понятно.
50. DitriX 1829 29.05.12 19:05 Сейчас в теме
А вообще возник вопрос - а нельзя ли сделать свертку базы?
Т.е. я сомневаюсь что им нужна развернутая история за последние 100лет :)


Ну и к тому же - лицензии на рдп не такие уж и дорогие...

Согласитесь, что и когда то ваш механизм им не поможет, и таким образом они просто один раз заплатили вам, и все равно через год или два - им нужен будет сервер 1С. Т.е. вы не решили проблему, а вылечили последствия.

+ никто не отменял распределенную базу, опять таки с выгруженными данными за последний период...
Решений много.

А менять во всех запросах структуру подключения и выполнения - ну уж очень стремно :)
54. fixin 4013 29.05.12 20:32 Сейчас в теме
(50) вы хотите сказать, что я продлил их агонию? Возможно, возможно. Но это оперативное и быстрое лечение. Если у клиента нет 42 000, это означает, что ему нужны быстрые и дешевые решения. ;-)
Подрастет - и базу обрежет и сервер купит и период закроет. ;-)
57. bulpi 178 30.05.12 12:39 Сейчас в теме
И все таки непонятно. Почему не использовать терминал-сервер, зачем изобретать велосипед? Какие деньги за терминальные подключения ? Если куплена система Windows 2003 сервер, я что, еще отдельно за терминальные лицензии должен платить ? Они же регистрируются бесплатно, с использованием ключа системы. Или я просто не в курсе ?
61. fixin 4013 30.05.12 13:12 Сейчас в теме
(57) похоже ты все же не в курсе. К тому же с чего ты взял, что куплен MS Server? Конкретно в моем случае было 5 машин на Вынь-ХР и 5 пользователей соответственно. На одной из машин лежала база. Вот и все.
(59) бугога. Заменить вызов одного метода Выполнить на другой - офигенно тяжелая работа. Добавления модуля в конфу с поддержки не снимает...
58. luns 30.05.12 12:49 Сейчас в теме
работа программиста по переписке отчетов на подобную схему дороже чем покупка сервера 1с по совокупной стоимости владения. этот факт.
но идея норм.
хотя и очень старая: http://infostart.ru/public/16486/
vvr908; JohnyDeath; +2 Ответить
60. fixin 4013 30.05.12 13:10 Сейчас в теме
(58) ничто не ново под лун(с)ой. Главное, заметить новое применение имеющимся старым вещам. Не смотрел вдумчиво обработку по ссылке, показалась не интересной, извини.

Ну почему дорого? берем готовый ускоритель, 2 часа на изучение, 2 часа на внедрение затычек во все места кода (обычно не очень много тяжелых запросов). 1 час на обучение.
5 часов * 1500 = 8500 рублей. Сравни в 42 тыщами. И то, это максимальная оценка, если через франчей, а не фрилансов.
62. luns 30.05.12 13:26 Сейчас в теме
(60) внимательно смотрим на фразу "совокупная стоимость владения"
помимо запросов есть еще и участки тяжелого кода (расчет себестоимости например, разузлование), а есть еще скд.
со временем конфигурации имеют свойство меняться.
так что, гораздо проще купить один раз софт который сведет на нет проблемы со скоростью.
тем более что очень часто в файловых тормоза из-за взаимоблокировок, а эту проблему обходными путями не решить.
63. fixin 4013 30.05.12 14:09 Сейчас в теме
(62) лунс не усложняй. в моем случае тормозило всего 2-3 запроса, но существенно. Это были запросы на чтение. Запись там была эпизодической и редкой.
Работы по написанию и отладке менеджера заняли часов пять, внедрение в код - меньше часа.
Эти шесть часов обошлись по абонентке клиенту намного дешевле, чем 42 тыщи.

Так что как говорится случай бывает разный. Не надо из пушки да по воробьям.
59. redgoll 30.05.12 12:55 Сейчас в теме
Соглашусь с предыдущим комментарием. Ладно, если самописные отчеты. А если типовая конфигурация нуждается в ускорении. Придется снимать с поддержки, на что не всегда пойдут клиенты, и куча работы, потом еще все переносить... Ой не знаю, хотя как выход в отдельных случаях может пригодиться.
70. e][tend 18.06.12 14:24 Сейчас в теме
Друзья, прошу подсказать... "пробег" по комментариям ответа не дал. Поможет ли эта обработка в следующей ситуации...
Файловая база обьем под 16 гигов. Пользователей 10-15. Поползли взаимоблокировки при проведении Расходных/приходных накладных.
Конфигурашка УТ 10.3 с доп. Модулем Агент+ для выгрузки для торговых агентов.
Замер производительности показывает, что блокировки возникают при запросах при проведении вышеуказанных документов.
71. fixin 4013 18.06.12 14:47 Сейчас в теме
(70) вряд ли поможет. переключите конфу в режим управляемых блокировок и настраивайте блокировки. или создайте очередь проведения в центре..
73. WKBAPKA 222 01.07.12 14:28 Сейчас в теме
а зачем? имел удовольствие наблюдать "надежность" работы файловой версии, скажу откровенно, ну ее в баню...
74. fixin 4013 01.07.12 17:18 Сейчас в теме
(73) потому что дешево и сердито
75. webester 34 08.08.12 02:57 Сейчас в теме
Честно сказать не понятно, если этот метод решает вопрос с самым узким местом в системе, почему я про него не слышал? Надо надо, срочно посмотреть.
76. webester 34 08.08.12 07:26 Сейчас в теме
А все понял, невнимательно читал, такой метод, нам не очень подходит, сразу читать надо было и про файлы и про пимменеджер
Оставьте свое сообщение

См. также

Вам нравятся запросы в 1С? Промо

Практика программирования Разработка v8 v8::Запросы 1cv8.cf Абонемент ($m)

Речь не только о том, что простейший запрос с "легальным" оформлением растянется на пол-экрана, речь еще обо всем, что нужно написать "в нагрузку" к тексту запроса. Все эти "Новый Запрос", "УстановитьПараметр" и последующие пляски с обработкой результата... Пора с этим заканчивать!

1 стартмани

03.07.2019    21074    5    m-rv    88    

Интерактивная справка по объектам 1С (автономное расширение)

Практика программирования Работа с интерфейсом v8 ERP2 Абонемент ($m)

База знаний, подключаемая к объектам основной базы. Ведётся интерактивно, формируется в виде статей прямо в 1С (текст, картинки, таблицы, ссылки). Есть возможность прикрепления файлов, привязки к объектам 1С, возможности рейтинга и комментирования пользователями.

3 стартмани

29.09.2020    6484    30    sapervodichka    33    

Конвейер проверки качества кода

Инструментарий разработчика Практика программирования Математика и алгоритмы v8 1cv8.cf Абонемент ($m)

Jenkinsfile для выполнения проверки качества кода. Собирает информацию с АПК, EDT и BSL-LS. Сопоставляет ошибки с гит-репозиторием, выгруженным ГитКонвертором. Отправляет в Сонар.

3 стартмани

04.09.2019    25421    22    Stepa86    46    

Алгоритмы поиска пути в графе

Практика программирования Разработка v8 1cv8.cf Абонемент ($m)

Реализуем алгоритмы поиска пути в графе на платформе 1С 8.3, такие как алгоритм А*, поиск в ширину, жадный поиск, алгоритм Дейкстры и вконце волновой.

1 стартмани

09.07.2019    17887    11    RonX01    10    

ВСТАВИТЬ В Справочник.Номенклатура (Код, Наименование) ЗНАЧЕНИЯ ("001", "Новый товар") Промо

Практика программирования v8 v8::Запросы 1cv8.cf Абонемент ($m)

Вас не обманывают ваши глаза, это запрос на изменение данных! И это работает без прямого доступа к БД, регистрации и смс.

1 стартмани

01.06.2018    30814    86    m-rv    57    

Работа с публикациями "Инфостарт"

Практика программирования О сообществе WEB v8 УУ Абонемент ($m)

Работа с рублевыми публикациями на сайте "Инфостарт": ведение клиентов, заказов, обновление файлов публикации, рассылка обновлений.

1 стартмани

13.09.2018    22057    13    RocKeR_13    16    

HTTP Сервисы: Путь к своему сервису. Часть 3

Инструментарий разработчика Практика программирования v8 1cv8.cf Абонемент ($m)

Продолжение статьи «HTTP Сервисы: Путь к своему сервису. Часть 2». В предыдущих частях мы использовали только Get, в этой части поговорим о других методах и длительных операциях.

1 стартмани

27.08.2018    38525    56    dsdred    17    

Позиционирование в помещении с помощью нейросети по сигналу Wi-Fi. Интерактивная карта склада в 1С с показом позиции

Инструментарий разработчика Практика программирования v8 Абонемент ($m)

Данная публикация содержит в себе редактор и интерактивную карту склада или иного помещения, на которой в реальном времени отображается позиция устройства, координаты которого вычисляются по уровням сигнала нескольких роутеров Wi-Fi. В статье и приложенным к ней разработкам предлагаются инструменты и методика для реализации вычисления точной геопозиции внутри помещений с помощью нейронной сети. Конфигурация написана на релизе 1С:Предприятие 8.3.12.1412, клиентское приложение имеет минимальный уровень совместимости SDK -16.

5 стартмани

09.08.2018    28554    26    informa1555    26    

Заполняем по шаблону (по умолчанию) Промо

Практика программирования v8 v8::УФ 1cv8.cf Абонемент ($m)

Простой в подключении, универсальный и достаточно удобный механизм заполнения реквизитов произвольных документов/справочников значениями по умолчанию. Реализован в расширении, но может быть и непосредственно включен практически в любую конфигурацию на управляемых формах простым копированием одной формы и двух команд. Весь код в статье.

1 стартмани

08.02.2018    28648    19    mvxyz    17    

Работа с данными выбора

Практика программирования Работа с интерфейсом v8 Россия Абонемент ($m)

В управляемом интерфейсе заложена мощная возможность описывать связи реквизитов формы через параметры. Установка параметров связей позволяет ограничить выбор данных так, чтобы целостность данных была обеспечена на этапе ввода. Однако без дополнительного программирования задать можно только самые простые связи. Такие условия связи, как зависимость от реквизита через точку или зависимость через дополнительное отношение, заданное в регистре сведений - уже задать без программирования не получится.

1 стартмани

17.07.2018    48736    17    kalyaka    16    

Полезные примеры составления схемы компоновки данных #2

Практика программирования v8 v8::СКД 1cv8.cf Абонемент ($m)

Еще один набор примеров как решить частные задачи в СКД

1 стартмани

22.05.2018    31551    11    SITR-utyos    13    

Печатная форма, сделанная как расширение конфигурации для БП 3.0. Новые возможности БСП

Практика программирования Универсальные печатные формы v8 БП3.0 Абонемент ($m)

Печатные формы на внешних обработках скоро канут в лету. На смену им приходят ПФ, реализованные в виде расширений конфигурации. Не нашел на сайте примеров таких расширений. Привожу пример подобного расширения для БП 3.0.

1 стартмани

06.12.2017    27359    54    kwazi    6    

Нечеткий поиск одним запросом Промо

Практика программирования v8 1cv8.cf Абонемент ($m)

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

1 стартмани

28.12.2015    28143    71    vasvl123    9    

Паузы при исполнении кода (Sleep для 1С)

Практика программирования v8 v8::УФ 1cv8.cf Абонемент ($m)

Решил проверить все найденные варианты паузы для 1С. В результате получилась обработка для тестирования и небольшая статья с итогом.

1 стартмани

28.11.2017    46765    12    swimdog    42    

Макет в СКД - пример всех возможных типовых вариантов

Практика программирования Инструментарий разработчика v8 v8::СКД 1cv8.cf Абонемент ($m)

Макет СКД: наглядное представление того, что, как и куда выводится при типовых настройках.

1 стартмани

09.11.2017    22216    76    freelancer    4    

Telegram-боты

Практика программирования v8 Абонемент ($m)

Описание теории, разбор архитектуры и пример реализации telegram-ботов. Сразу скажу, со структурированием изложения мало что могу поделать. :) редакция от 18.07.2018 Правки последней редакции выделены жирным.

1 стартмани

01.09.2017    33124    132    PLAstic    59    

1С: Предприятие + корпоративный чат, как наладить оперативные уведомления за 10 минут Промо

Практика программирования v8 Абонемент ($m)

Как сделать автоматические уведомления о разных событиях из 1С в корпоративный чат MyChat для сотрудников компании

1 стартмани

14.08.2016    48506    36    Demanoidos    60    

Умный дом на 1С + ардуино

Практика программирования v8 Абонемент ($m)

Конфигурация для автоматизации быта программиста 1C и не только. В данной статье будет рассказано, как можно использовать 1С для задач, не входящих в стандартные рамки этой платформы. Например, управление домом. В качестве периферии для подключения будет использован микроконтроллер (МК) Ардуино, но на нём не будет никакой логической нагрузки, весь процесс будет проходить на сервере 1С. Работа с пинами ввода/вывода происходит напрямую из 1С.

1 стартмани

07.08.2017    23106    21    sasha777666    63    

Расширения конфигураций 1С: учимся перехватывать методы

Практика программирования v8 v8::УФ 1cv8.cf Абонемент ($m)

В этой статье я на примерах разберу некоторые механизмы расширений конфигураций 1С. А именно «перехваты» методов модуля объекта и «перехваты» событий формы и элементов формы. Данная статья написана с учебными целями, чтобы показать, как при помощи расширений конфигурации можно делать такие доработки, ради которых раньше приходилось снимать конфигурацию с поддержки.

1 стартмани

30.05.2017    132012    13    signum2009    48    

Регулярные выражения – это просто. Построитель и отладчик регулярных выражений

Инструментарий разработчика Практика программирования v8 1cv8.cf Абонемент ($m)

Предлагается к использованию построитель регулярных выражений. Выполненный в виде внешней обработки, он позволит строить сложно-структурированные выражения на основе параметрического описания, тестировать их, и в результате получить программный код 1С.

1 стартмани

13.03.2017    31835    113    romasna    49    

Быстрое определение интервалов в запросе Промо

Практика программирования v8 Абонемент ($m)

В статье описывается новый метод определения интервалов между данными различных записей в запросе. В отличие от общеизвестного метода, время работы предлагаемого метода зависит от объема данных ЛИНЕЙНО. Это обеспечивает ему значительный выигрыш по быстродействию на больших объемах данных. В качестве иллюстрации возможностей метода приведен отчет, показывающий гистограмму распределения времени между продажами.

1 стартмани

01.10.2015    52060    35    ildarovich    41    

Распознавание текста с помощью нейросетей Google Cloud Vision и 1С

Практика программирования v8 1cv8.cf Абонемент ($m)

Возможности Google Cloud Vision в распознавании текста.

1 стартмани

08.02.2017    29725    127    kiv1c    18    

Графическая схема. Управление при помощи XDTO.

Практика программирования v8 Абонемент ($m)

В статье описывается методика программного управления элементами графической схемы при помощи механизма XDTO. Приложена готовая к использованию библиотека функций для создания и удаления графических объектов, а также для связи элементов схемы соединительными линиями.

2 стартмани

16.01.2017    22703    105    Alxby    23    

Простой редактор плана помещения JavaScript

Практика программирования Работа с интерфейсом v8 1cv8.cf Абонемент ($m)

На ресурсе сейчас очень много решений, которые позволяют редактировать карты, используя географические схемы. Так же много решений, которые позволяют редактировать объекты онлайн веб-карт. Мне же нужно было простое решение, для того чтобы расставить квадратные объекты на плане, показать их пользователю. Ну и распечатать, опять же. Я решил написать простенький редактор на JavaScript с использованием библиотеки Raphael.

1 стартмани

23.11.2016    21392    96    igel9780    22    

Хранение файлов в томах на диске (для УПП 1.3) Промо

Практика программирования v8 УПП1 Абонемент ($m)

Доработка типовой УПП 1.3 в плане хранения присоединенных файлов вне базы данных

2 стартмани

05.06.2016    58086    10    wowik    32    

Работа с двоичными данными на примере чтения файлов изображений. Новые возможности 8.3.9

Практика программирования WEB v8 1cv8.cf Россия Абонемент ($m)

В статье приводятся новые функции по работе с двоичными данными, появившимися в версии платформы 8.3.9 , на примере анализа формата и размера изображений. А также пример отправки изображения через API ВКонтакте с помощью новых объектов (без использования ОбъединитьФайлы())

1 стартмани

14.11.2016    26473    16    Anton64    22    

Загрузка файлов на сервер с прогрессом и докачкой

Практика программирования v8 1cv8.cf Россия Абонемент ($m)

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

1 стартмани

04.10.2016    13554    53    mrstomak    21    

Несколько шаблонов для доработки типовых конфигураций

Практика программирования Инструментарий разработчика v8 v8::УФ Абонемент ($m)

Предлагаю несколько каркасов для создания новых объектов в типовых конфигурациях. Это выжимка из кода нескольких конфигураций, которая позволит быстро и красиво создавать и дорабатывать объекты метаданных с соблюдением идеологии исходной системы

1 стартмани

03.10.2016    36984    95    json    25    

HTTP-сервис: отчеты [Расширение]

Практика программирования Работа с интерфейсом v8 1cv8.cf Абонемент ($m)

Это HTTP-сервис, который возвращает почти любой отчет в HTML, XLSX или в JSON. Сохраните вариант отчета, получите на него ссылку и можно получить данные без захода в 1С. Работает в конфигурациях на основе БСП 2.3.3+, для отчетов на СКД и в 1С 8.3.8+

2 стартмани

30.08.2016    27187    137    Stepa86    15    

Недокументированное использование стандартных форм Upd.

Практика программирования v8 v8::УФ 1cv8.cf Абонемент ($m)

Вам не хватает возможностей в платформе 1С или у Вас нет времени на углубленное изучение платформы 1С? Рассмотрены возможности использования стандартных форм, вызываемых из платформы.

1 стартмани

26.07.2016    28608    77    ZhokhovM    60    

БСП 2.3 и БСП 3.0: Просто про выполнение внешней обработки в фоне (c индикацией прогресса выполнения)

Инструментарий разработчика Практика программирования БСП (Библиотека стандартных подсистем) v8 1cv8.cf Абонемент ($m)

Простое пояснение о том, как сделать внешнюю обработку с фоновым выполнением и индикацией процесса для любой конфигурации на основе БСП 2.3.2. UPDATE 20/09/19: добавлен вариант обработки с индикацией процента выполнения и статусом выполнения для БСП 3.0.

1 стартмани

18.05.2016    62459    184    rozer    65    

Остатки на каждый день в запросе

Практика программирования Учет ТМЦ Учет ТМЦ v8 1cv8.cf УУ Абонемент ($m)

Запрос формирует остатки товаров на каждый день в пределах выбранного периода.

1 стартмани

26.04.2016    59632    19    arakelyan    19    

Еще один способ расчета остатков на каждый день в запросе

Математика и алгоритмы Практика программирования v8 Абонемент ($m)

Предлагается новый способ расчета остатков на каждый день (час, минуту, секунду) в запросе. Способ не требует предварительного формирования таблицы дат и также подходит для расчета курсов валют, цен номенклатуры и других периодических сведений на каждую дату периода. На больших объемах данных предлагаемый способ может превосходить по быстродействию ранее известные методы из-за линейной (в лучшем случае) зависимости трудоемкости от длины периода.

1 стартмани

24.04.2016    34941    49    ildarovich    23    

Вывод печатных форм с запросом данных в форму "Печать документов" из подсистемы БСП "Печать".

Практика программирования БСП (Библиотека стандартных подсистем) v8 1cv8.cf Абонемент ($m)

Все не раз видели, как в типовых конфигурациях, построенных на основе БСП (Библиотека стандартных подсистем), печатные формы, построенные на основе Табличного документа, выводятся в специальную форму "ПечатьДокументов". Эта форма входит в состав подсистемы "Печать" из БСП. При разработке своих печатных форм, иногда необходимо запросить у пользователя дополнительные данные необходимые для печати. Тут встает вопрос, как в этом случае вывести печатную форму в форму "Печать документа". В этой статье я рассмотрю, как реализовать вывод печатной формы в упомянутую форму из подсистемы "Печать", в случае если мы хотим перед выводом печатной формы запросить у пользователя дополнительные данные. Здесь будут рассмотрены два случая: когда реализуется печатная форма с использованием подсистемы "Дополнительные отчеты и обработки" и когда печатная форма добавляется в конфигурацию в режиме конфигуратора, т.е. вносятся изменения в типовую конфигурацию.

1 стартмани

29.03.2016    91237    181    lopatin    14    

Выполнение JavaScript кода из 1С в объекте Поле HTML Документа (HTML 5) и вызов события в 1С ПриНажатии

Практика программирования v8 1cv8.cf Россия Абонемент ($m)

Пример выполнения JS кода из 1С в Поле HTML Документа под управляемыми формами, с удобным получением результата в 1С(С помощью вызова привязанного события ПриНажатии к элементу ПолеHTMLДокумента)

1 стартмани

22.03.2016    81965    160    igo1    54    

Количество дней недели (понедельников/вторников/...) в заданном диапазоне одним запросом

Практика программирования v8 Абонемент ($m)

При реализации периодического авто-заполнения маршрутных листов по графику (недельному) необходимо было просчитать стоимость всего периода, с условием выездов только по определенным дням. Заморачиваться с обходом результата не хотелось. Пришлось написать "Небольшой" запрос.

1 стартмани

03.03.2016    18531    1    Alexander.Shvets    5    

Простые радости жизни программиста 1С: выбор типа значения

Работа с интерфейсом Практика программирования v8 1cv8.cf Абонемент ($m)

Предлагаемая в работе обработка включает обычную и управляемую формы, которые максимально точно реализуют функциональность системного диалога выбора типа в толстом клиенте обычное приложение (включая оформление диалога). Эти формы имеют дополнительные интерфейсные удобства и могут быть использованы в качестве альтернативных диалогов выбора типа.

1 стартмани

17.02.2016    50529    53    yuraos    17    

Отображение прогресса выполнения длительных операций в БСП и их отладка в текущем сеансе.

Практика программирования БСП (Библиотека стандартных подсистем) v8 1cv8.cf Абонемент ($m)

В статье описан способ исполнения длительных операций в конфигурациях, в которых используется библиотека стандартных подсистем, с визуализацией прогресса исполнения и отображения хода обработки данных. Также дается краткое описание процесса отладки длительных операций в текущем сеансе.

1 стартмани

17.02.2016    55939    179    balanton    23    

Яндекс.Деньги "Благотворительность"

Инструментарий разработчика Практика программирования v8 1cv8.cf Абонемент ($m)

Яндекс.Деньги теперь в 1С. Форма для приема благотворительных взносов. Форму легко сделать и вставить на любую страницу сайта или блога. Платежи будут приходить на ваш кошелек. На форме есть три способа платежа: из кошелька, с банковской карты, с баланса мобильного.

1 стартмани

16.02.2016    23584    8    Tatitutu    5    

Мастер рассылки e-mail 2.2 для управляемых форм

Практика программирования Email v8 v8::УФ ERP2 БП3.0 УТ11 Абонемент ($m)

Для пользователей: переделанный из старый разработки под 8.2 с использованием библиотеки Мастер рассылки e-mail 2.2 (ERP, УТ, БП) (Только управляемые формы), который теперь может запускаться под любой версией платформы с разрешенными или запрещенными модальными/синхронными вызовами в конфигурации. Также удобный выбор e-mail и их владельцев с помощью отбора динамического списка по любым критериям и галочки исключения.

1 стартмани

29.12.2015    37276    20    milkers    4    

Передача больших пакетов через веб-сервисы

Практика программирования Администрирование данных 1С Внешние источники данных v8 Абонемент ($m)

Реализация механизма передачи больших пакетов через веб-сервисы. С его помощью передать файл размером в несколько гигабайт не составит проблем.

1 стартмани

06.12.2015    57479    48    YPermitin    19