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

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

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

44
Предлагается простая для внедрения в любую конфигурацию методика ускорения выполнения запросов в файловых базах 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.

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

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

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

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

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

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

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

44

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

Наименование Файл Версия Размер
down.zip
.zip 9,83Kb
24.05.12
106
.zip 9,83Kb 106 Скачать

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

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

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

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

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

в 8.2, по-моему, уже не работает.
13. q_i 381 26.05.12 00:33 Сейчас в теме
64. madmpro 08.06.12 12:59 Сейчас в теме
(8) q_i,
ОГО! Полезная инфа, я уже готовил бабло :)...
65. fixin 3882 08.06.12 13:20 Сейчас в теме
66. cool.vlad4 45 08.06.12 13:26 Сейчас в теме
(64) с юридич. точки зрения не имеет значения используете вы вариант, описанный в 8, или поставили взломанный сервер, вы одинаково нарушаете закон
TravkinSV; +1 Ответить
67. q_i 381 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 430 26.05.12 15:49 Сейчас в теме
(0)
Все гениальное - просто! ;-)
P.S. Жаль, что так и не удалось посадить файловую версию "восьмерки" на простую клиент-серверную СУБД. :-(
Было бы дешево и сердито... ;-)
17. fixin 3882 28.05.12 11:15 Сейчас в теме
(14) как то стремно, что между мелким и крупным нет среднего варианта и шаг между ними - 42 штуки...

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

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

(22) ха, ничего себе проще, внешнюю компоненту написать. И ксати, насколько я понимаю у товарища http://infostart.ru/public/93643/ речь о поддержании ком-соединения на одном и том же компьютере. А для ускорения нужно создавать ком-объект на компьютере с базой, а не на компьютере-клиенте. Возможно, но из-за идиотизма мелкомягких с правами нереально.
25. hogik 430 28.05.12 18:24 Сейчас в теме
27. fixin 3882 28.05.12 18:27 Сейчас в теме
(25) все равно не понял, что вы имеете ввиду, там про 1с77 как бе. а там был ДБФ а не 1СД.
(26) создавать ком-объект на текущем и удаленном компе - это две большие разницы как бе... гыгыгы...
30. hogik 430 28.05.12 18:44 Сейчас в теме
(27)
Нет никакой разницы "ДБФ а не 1СД"(с).
Подмена "движка" полностью, а не доступ к существующему формату данных.
Кроме всего, еще и снимается ограничение на размер БД.
Да. Есть разница в 7.7 или 8.х в сложности "вскрытия" интерфейса. И только - в этом.
Но, после появления http://infostart.ru/public/102065/ у меня прибавилось надежды на возможность такого решения. ;-)
26. comol 4142 28.05.12 18:25 Сейчас в теме
(23) Да не... там пул соединений COM+ о поддержании соединения сам позаботится. В статье просто общая методика описана, вцелом задачу создать и поддерживать COM соединение на одном компьютере это решит.
Там не совсем внешняя компонента - просто маленькая библиотечка со стандартным шаблоном. По факту - "3 строчки кода". С правами есть заморочки... но ещё когда сервер 8.0 настраивали все привыкли вроде...
33. comol 4142 28.05.12 21:45 Сейчас в теме
(26) comol, После настройки разница в 1 параметре функции :)
39. DMSDeveloper 29.05.12 11:51 Сейчас в теме
(23)
Все реально. Com+ Он же DCom. Настраивается все очень просто. Если сеть доменная нужно только настроить доступ к компоненте для групп, в которых пользователи напиханы. если не домен, то просто продублировать пользователей, хотя скорее всего они и так продублированы. Ну или настроить доступ для гостевой учетки.
40. fixin 3882 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 3882 29.05.12 14:41 Сейчас в теме
(41) почитаю, конечно. Идея использовать удаленный COM-сервер присутствовала изначально. Но в бездоменной сети до сих пор у меня не получилось создать COM-объект 1С удаленно. Это говорит не столько о моих кривых руках, сколько о том, что задача не тривиальна, т.е. нужно ковыряться в тонкостях доступа винды, а они могут быть в каждой версии ОС свои. Как-то так. Поэтому мне больше нравится моё нативное решение.
43. MRAK 710 29.05.12 16:38 Сейчас в теме
(21) это уже есть в УФ. Можно файловую базу поднять на вебсервере
44. fixin 3882 29.05.12 16:55 Сейчас в теме
(43) я в курсе про 82 (можно и через тонкого клиента быстро гонять), но не забудьте еще переписать все формы на управляемые, если чо...
Слишком велики затраты для случая базы 1с81. А тут дешево и сердито как бе.
45. hogik 430 29.05.12 17:23 Сейчас в теме
(43)
Роман (MRAK).
Я не понял ЧТО есть в УФ? Или Вы ошиблись номером сообщения?
46. fixin 3882 29.05.12 17:31 Сейчас в теме
(45) в управляемых формах есть возможность выполнять весь код на сервере, оттого и название - тонкий клиент.
то бишь там задача ускорения выполнения для файловых баз данных не стоит - все выполняется на сервере и так.
47. hogik 430 29.05.12 18:00 Сейчас в теме
(46)
Сергей (fixin).
Спасибо за разъяснения. Теперь я буду знать что такое тонкий клиент. Всегда хотел об этом узнать. Но боялся спросить... :-)
Попробуйте вникнуть в то, что я выше написал. Мне интересно Ваше мнение и Ваше "понимание" моего предложения.
48. fixin 3882 29.05.12 18:22 Сейчас в теме
(47) а, вы всё буквоедствуете?
Просто товарищ мрак сказал, что вместо набора файловая база + терминальный доступ можно использовать файловая база + тонкие клиенты.
Конечно же, Мрак не имел ввиду, что есть двухуровневая система СУБД + клиенты, всегда есть СУБД + сервер 1С + клиенты, к сожалению.
49. hogik 430 29.05.12 18:36 Сейчас в теме
(48)
Сергей (fixin).
О чем Вы? Какое "всё буквоедствуете" ?
Вопрос был поднят конкретный. Про возможность наличия двухуровневой архитектуры. Чтобы не писать: "к сожалению"(с).
51. MRAK 710 29.05.12 19:36 Сейчас в теме
(49) ну да, я несколько неточно ответил.
Ибо двухуровневка 1С - это просто фантастика. Вы хотите весь серверный код 1С переписать в хранимки DB/SQL/Oracle? Слишком уж трудозатратной поддержка окажется, не находите? На порядок, а то и в 100 раз трудозатратнее, чем на данный момент.
Поправьте, если ошибаюсь.

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

Вот у меня грыжа, например. Можно лечить оперативно, но это долго, нудно, с неизвестными последствиями. А можно мануалкой и иголками периодически подлечивать. И ниче, терпимо. Так и здесь.
15. khaoos 239 28.05.12 05:44 Сейчас в теме
Поддерживаю разработку и автора. В регионах особенно не любят платить за клиент-серверный вариант. Думаю, в скором времени не пригодится, так как ухожу в крупную организацию, где такой проблемы стоять не будет. Но на заметку возьму.
18. DMSDeveloper 28.05.12 11:28 Сейчас в теме
(0)Как говорится - Все гениальное - Просто!
Взял на заметку. Мне как раз нужно что то подобное реализовать, только не с запросами.
19. comol 4142 28.05.12 15:23 Сейчас в теме
По-моему задача средствами COM+ проще решается. Без обёртки не зарегистрируется, но обёртка это 5 мин, да и была вроде уже на инфостарте. Будет 1С запущенная на другом компьютере - по сути "сервер".. как в 8.0 если кто помнит...
20. fixin 3882 28.05.12 17:17 Сейчас в теме
(19) что вы подразумеваете под оберткой? тут болтается без ответа мой вопрос, как создать Ком-объект 1с на другом компьютере. Есть заморочка с правами доступа для этого. А так конечно, проще было бы через КОМ создавать, управлять и не городить менеджеров запросов. ;-)
22. comol 4142 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 3882 28.05.12 20:08 Сейчас в теме
(28) там усложненная схема. нужно брандмауэр настраивать и прочее, из-ха ХТТП протокола. теоретически можно и результат запроса возвращать, сериализовав, но это надо докручивать. Хотя может и эффективнее выйдет, не знаю.
Я реализовал просто и дубово - бери и пользуйся.. ускоряйся.. ;-)


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


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

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

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

А менять во всех запросах структуру подключения и выполнения - ну уж очень стремно :)
54. fixin 3882 29.05.12 20:32 Сейчас в теме
(50) вы хотите сказать, что я продлил их агонию? Возможно, возможно. Но это оперативное и быстрое лечение. Если у клиента нет 42 000, это означает, что ему нужны быстрые и дешевые решения. ;-)
Подрастет - и базу обрежет и сервер купит и период закроет. ;-)
57. bulpi 159 30.05.12 12:39 Сейчас в теме
И все таки непонятно. Почему не использовать терминал-сервер, зачем изобретать велосипед? Какие деньги за терминальные подключения ? Если куплена система Windows 2003 сервер, я что, еще отдельно за терминальные лицензии должен платить ? Они же регистрируются бесплатно, с использованием ключа системы. Или я просто не в курсе ?
61. fixin 3882 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 3882 30.05.12 13:10 Сейчас в теме
(58) ничто не ново под лун(с)ой. Главное, заметить новое применение имеющимся старым вещам. Не смотрел вдумчиво обработку по ссылке, показалась не интересной, извини.

Ну почему дорого? берем готовый ускоритель, 2 часа на изучение, 2 часа на внедрение затычек во все места кода (обычно не очень много тяжелых запросов). 1 час на обучение.
5 часов * 1500 = 8500 рублей. Сравни в 42 тыщами. И то, это максимальная оценка, если через франчей, а не фрилансов.
62. luns 30.05.12 13:26 Сейчас в теме
(60) внимательно смотрим на фразу "совокупная стоимость владения"
помимо запросов есть еще и участки тяжелого кода (расчет себестоимости например, разузлование), а есть еще скд.
со временем конфигурации имеют свойство меняться.
так что, гораздо проще купить один раз софт который сведет на нет проблемы со скоростью.
тем более что очень часто в файловых тормоза из-за взаимоблокировок, а эту проблему обходными путями не решить.
63. fixin 3882 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 3882 18.06.12 14:47 Сейчас в теме
(70) вряд ли поможет. переключите конфу в режим управляемых блокировок и настраивайте блокировки. или создайте очередь проведения в центре..
73. WKBAPKA 215 01.07.12 14:28 Сейчас в теме
а зачем? имел удовольствие наблюдать "надежность" работы файловой версии, скажу откровенно, ну ее в баню...
74. fixin 3882 01.07.12 17:18 Сейчас в теме
(73) потому что дешево и сердито
75. webester 29 08.08.12 02:57 Сейчас в теме
Честно сказать не понятно, если этот метод решает вопрос с самым узким местом в системе, почему я про него не слышал? Надо надо, срочно посмотреть.
76. webester 29 08.08.12 07:26 Сейчас в теме
А все понял, невнимательно читал, такой метод, нам не очень подходит, сразу читать надо было и про файлы и про пимменеджер
Оставьте свое сообщение

См. также

Полезные процедуры и функции для программиста 161

Статья Программист Нет файла v8 1cv8.cf Россия Абонемент ($m) Практика программирования Универсальные функции

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

1 стартмани

07.10.2019    12747    HostHost    23       

Подборка программ для взаимодействия с ЕГАИС Промо

ЕГАИС (Единая государственная автоматизированная информационная система) - автоматизированная система, предназначенная для государственного контроля за объёмом производства и оборота этилового спирта, алкогольной и спиртосодержащей продукции. Инфостарт рекомендует подборку проверенных решений для взаимодействия с системой.

Описание формата внутреннего представления данных 1С в контексте обмена данными 154

Статья Программист Внешняя обработка (ert,epf) v8 v8::УФ 1cv8.cf Абонемент ($m) Практика программирования Внешние источники данных Разработка

Фирма 1С не рекомендует использовать внутреннее представление данных для любых целей, которые отличны от обмена с 1С:Предприятием 7.7. Но сама возможность заглянуть на "внутреннюю кухню" платформы с помощью функций ЗначениеВСтрокуВнутр(), ЗначениеВФайл(), ЗначениеИзСтрокиВнутр() и ЗначениеИзФайла(), дала возможность сообществу программистов 1С разработать новые приемы разработки и анализа. Так, именно на использовании внутреннего представления был построен алгоритм "быстрого массива", который позволяет практически мгновенно создать массив в памяти на основании строки с разделителями. С помощью разбора внутреннего представления можно "на лету" программным кодом выполнить анализ обычной формы и даже сделать редактор графической схемы. Во внутреннем формате сохраняют свои данные между сеансами различные популярные внешние обработки. А еще это возможность сделать быстрый обмен с внешними системами.

1 стартмани

06.09.2019    6959    6    Dementor    27       

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

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

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

1 стартмани

03.07.2019    11471    1    m-rv    79       

Очный семинар по регулярному менеджменту Александра Фридмана "Вы или Хаос", 12 декабря 2019 г. , Санкт-Петербург Промо

Семинар по регулярному менеджменту от Александра Фридмана для собственников, первых лиц и топов. Технология управленческого планирования, комплексного управления временем и другими ресурсами, выполнением поручений, делами, информацией, контактами (встречи-звонки-почта).

от 11000 до 29000 рублей

1С:Ассемблер. Немного летнего веселья! 314

Статья Программист Внешняя обработка (ert,epf) v8 1cv8.cf Абонемент ($m) Практика программирования Разработка

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

1 стартмани

21.06.2019    16088    50    Evil Beaver    116       

Простые примеры сложных отчетов на СКД 271

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

Подписи в отчете. Особенности соединения наборов: как соединить несоединяемое. Остатки на дату и обороты по месяцам в одном отчете. Курс валюты на каждую дату без группировок и соединений в запросе. Отчет с произвольными колонками и с произвольной последовательностью. "Неадекватный отчет".

1 стартмани

12.06.2019    15903    12    Hatson    22       

Перенос данных БП 3.0 => УТ 11 / КА 2 / ERP 2 (ЕРП) (перенос остатков, документов и справочной информации из "1С:Бухгалтерия предприятия 8", ред.3.0). Обновлено до БП 3.0.73.х, УТ 11.4.10.х, КА 2.4.10.х., ERP 2.4.10.х! Промо

Переносятся документы за выбранный период, справочная информация и остатки по счетам бух. учета в программу УТ 11 / КА 2 / ЕРП 2 (ERP). Переносятся все возможные виды операций ввода остатков на нужную дату. Есть отбор по периоду переноса документов и фильтр по организации, доступен выбор даты ввода остатков. Если нужно переносить что-то дополнительно, то обычно бесплатно добавляем это в перенос . Смотрите видеодемонстрацию со звуком - советами по переносу и рекомендациями настройки программ.

29700 руб.

Безопасная работа с транзакциями во встроенном языке 190

Статья Программист Конфигурация (md, cf) v8 1cv8.cf Абонемент ($m) Практика программирования

Разбираемся с опасностями использования транзакций во встроенном языке 1С. Познаем ошибку "В данной транзакции уже происходили ошибки". Учимся защищаться от них.

1 стартмани

25.03.2019    17872    8    tormozit    44       

Баг или фича? Неожиданное поведение платформы 172

Статья Системный администратор Программист Конфигурация (md, cf) v8 1cv8.cf Абонемент ($m) Практика программирования Тестирование и исправление Разработка

Рассмотрим несколько случаев неожиданного поведения платформы 1С, а также что с этим можно cделать.

18.02.2019    14025    32    YPermitin    88       

Онлайн-курс "Технология выполнения проектов ERP-класса – процессный подход". Третий поток. Курс проходит с 21 января по 18 марта 2020 года. Промо

Курс разработан Внедренческим центром «Раздолье». Курс предназначен для подготовки аналитиков, архитекторов и руководителей проектов автоматизации процессов управления с использованием комплексных ИТ-систем (1С:ERP, 1С:УХ, 1С:КА, 1С:УТ). В основе курса лежит методика применения процессного подхода.

9000 рублей

Коннектор: удобный HTTP-клиент для 1С:Предприятие 8 563

Инструменты и обработки Программист Конфигурация (md, cf) v8 1cv8.cf Абонемент ($m) Практика программирования Внешние источники данных WEB Универсальные функции Инструментарий разработчика Универсальные обработки

Коннектор - библиотека для работы с HTTP запросами. Библиотека берет на себя всю рутину работы с HTTP запросами. Буквально в одну строку можно получать данные, отправлять, не заботясь о необходимости конструирования URL, кодирования данных и т.п.

1 стартмани

31.01.2019    31491    283    bonv    117       

HTML в новой версии 8.3.14 на примере 3-х JavaScript библиотек: AmCharts, HighCharts, DHTMLX 172

Статья Программист Внешняя обработка (ert,epf) v8 1cv8.cf Абонемент ($m) Универсальные обработки Практика программирования Разработка

Тестируем возможности HTML в новой версии 8.3.14 платформы на примере 3-х JavaScript библиотек: AmCharts, HighCharts, DHTMLX.

1 стартмани

29.01.2019    16055    66    Synoecium    37       

1C:Предприятие для программистов: Запросы и отчеты. Второй поток. Онлайн-интенсив с 17 марта по 16 апреля 2020 г. Промо

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

6500 рублей

Отладка сложных отчетов на СКД 140

Отчеты и формы Программист Расширение (cfe) v8 v8::СКД 1cv8.cf Россия Абонемент ($m) Практика программирования

Расширение для отладки сложных отчетов на СКД (в т.ч. для собираемых программно "на лету") и быстрого перехода к отладке таких отчетов в консоли запросов и отчетов на СКД.

1 стартмани

28.12.2018    15845    61    maxx    56       

Реализация простого http-сервиса "Просмотр карточки номенклатуры(товара) в браузере" 144

Статья Программист Конфигурация (md, cf) v8 1cv8.cf Абонемент ($m) Практика программирования

Практический пример реализации простого http-сервиса средствами 1С Предприятие 8.3. Обеспечивает просмотр списка товаров и просмотр данных товара в браузере.

1 стартмани

07.12.2018    14916    10    dmitry1975    31       

Перенос данных КА 1.1 / УПП 1.3 => БП 3.0 (перенос остатков, документов и справочников из "1С:Комплексная автоматизация 1.1" / УПП 1.3 в "1С:Бухгалтерия 3.0"). Обновлен до версий КА 1.1.115.х, УПП 1.3.127.х! Промо

Разработка позволяет перенести остатки по всем счетам бух.учета в программу "1С:Бухгалтерия предприятия 8", ред. 3.0 на выбранную дату начала ведения учета. Также переносятся документы за период и вся необходимая справочная информация. Правила оперативно обновляю при выходе новых релизов. Рассылка обновлений правил бесплатно в течение 12 месяцев. Есть видеодемонстрация проведения переноса данных. Конфигурации при использовании обмена остаются полностью типовыми. Перенос данных возможен в Бухгалтерию 3.0 версии ПРОФ, КОРП или базовую.

24700 руб.

Использование подсистемы БСП "Заполнение объектов" 135

Статья Программист Расширение (cfe) v8 v8::УФ 1cv8.cf Россия Абонемент ($m) Практика программирования Универсальные функции БСП (Библиотека стандартных подсистем)

Применение механизмов БСП для добавления новых команд заполнения к формам различных объектов. Использование расширений конфигурации для доработки. Шаблоны для реализации собственных команд заполнения.

1 стартмани

23.11.2018    15230    8    ids79    22       

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

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

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

1 стартмани

13.09.2018    10821    10    RocKeR_13    16       

Перенос документов, остатков и справочников КА 1.1 => КА 2 / УТ 11. Обновлено до КА 2.4.10.х и УТ 11.4.10.х! Промо

Более 130 компаний выполнили переход на КА 2 или УТ 11 с помощью нашей разработки! Позволяет перенести не только остатки и справочники (как типовая обработка), но и документы за нужный период времени. Предоставляем техподдержку, оперативно исправляем замечания, выпускаем обновления при выходе новых релизов программ 1С. Вы можете проверить разработку до покупки: сделаем бесплатный тестовый перенос из вашей базы КА 1.1 и предоставим доступ к базе-результату через веб-клиент!

29700 руб.

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

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

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

1 стартмани

27.08.2018    18615    32    dsdred    13       

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

Инструменты и обработки Программист Бизнес-аналитик Приложение (apk) v8 Windows Абонемент ($m) Инструментарий разработчика Практика программирования

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

5 стартмани

09.08.2018    17475    23    informa1555    26       

С 2020 года сервис «Продление поддержки конфигурации 1С:УПП» подорожает вдвое Промо

Успейте продлить поддержку УПП до повышения цен! Фирма «1С» предупредила об изменении цен на сервис «Продление поддержки конфигурации "1С:Управление производственным предприятием"». С 1 января 2020 года сервис подорожает в два раза.

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

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

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

1 стартмани

17.07.2018    24566    14    kalyaka    15       

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

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

Уже много было написано про http-сервисы, но то и дело всплывают «Новые» статьи по обмену между базами V8 по COM, что «Немножко» удивляет. Решил внести свои 5 копеек, поработаем с http-сервисом.

1 стартмани

15.07.2018    43485    17    dsdred    22       

Базовый курс для начинающих 1С-программистов. Пятый поток. Онлайн-курс с 12 февраля по 15 апреля 2020 г. Промо

Данный онлайн-курс является начальной ступенью по изучению базовых принципов программирования в системе “1С:Предприятие” и предназначен для обучения 1С-программированию “с нуля”.

4500/9500 рублей

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

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

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

1 стартмани

01.06.2018    21056    86    m-rv    57       

Программы для исполнения 488-ФЗ: Маркировка товаров Промо

1 января 2019 года вступил в силу ФЗ от 25.12.2018 № 488-ФЗ о единой информационной системе маркировки товаров с использованием контрольных (идентификационных) знаков, который позволяет проследить движение товара от производителя до конечного потребителя. Инфостарт предлагает подборку программ, связанных с применением 488-ФЗ и маркировкой товаров.

БСП: Дополнительная обработка (Регламенты), примеры от простого к сложному 242

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

Очень много попадается странных решений, которые можно решить через БСП:Дополнительные отчеты и обработки. Я бы вообще БСП из-за этой подсистемы переименовал в «Большое Спасибо Программистам». Поработаем с подсистемой в части написания регламентных заданий.

1 стартмани

10.05.2018    29722    28    dsdred    34       

Как выполнить отчет на СКД через COM и получить данные отчета? 86

Статья Программист Архив с данными v8 УПП1 Россия Windows Абонемент ($m) Практика программирования

Для чего это нужно. Например, нужно в одной базе получить какой-либо показатель из другой базы. Этот показатель вычисляется в каком-либо сложном отчете, который написан на СКД. Можно, конечно, "скопипастить" текст запроса из другой базы, немного подправить его и выполнять в том же COM подключении. Но с этим теряется гибкость: если отчет изменился, то нужно помнить о том, что где-то есть его "немного модифицированная" копия. В статье будет рассмотрен пример получения данных из базы ЗУП.

2 стартмани

08.05.2018    19185    10    wowik    3       

Новый раздел на Инфостарте - Electronic Software Distribution Промо

Инфостарт напоминает: на нашем сайте можно купить не только ПО, связанное с 1С. В нашем арсенале – ESD-лицензии на ПО от ведущих вендоров: Microsoft, Kaspersky, ESET, Dr.Web, Аскон и другие.

  • Низкие цены, без скрытых платежей и наценок
  • Оперативная отгрузка
  • Возможность оплаты с личного счета (кешбек, обмен стартмани на рубли и т.п.)
  • Покупки идут в накопления для получения скидочных карт лояльности Silver (5%) и Gold (10%)

Работа со схемой запроса 176

Статья Программист Конфигурация (md, cf) v8 v8::Запросы Абонемент ($m) Инструментарий разработчика Практика программирования

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

1 стартмани

24.04.2018    30485    75    kalyaka    34       

Асинхронная запись и чтение файла без использования модальных методов и временных файлов 134

Статья Программист Внешняя обработка (ert,epf) v8 1cv8.cf Абонемент ($m) Практика программирования

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

1 стартмани

10.04.2018    20190    18    Alxby    23       

Подборка решений для взаимодействия со ФГИС «Меркурий» Промо

С 1 июля 2019 года все компании, участвующие в обороте товаров животного происхождения, должны перейти на электронную ветеринарную сертификацию (ЭВС) через ФГИС «Меркурий». Инфостарт предлагает подборку программ, связанных с этим изменением.

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

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

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

1 стартмани

08.02.2018    18946    20    mvxyz    17       

Бесплатная проверка контрагентов в ФНС (общий модуль с алгоритмом). На примере выводим статус в список справочника контрагентов 124

Статья Программист Конфигурация (md, cf) v8 1cv8.cf Абонемент ($m) Практика программирования

Если вам интересно проверить контрагенте в ФНС, вам поможет данная публикация. Весь алгоритм работы строится на основе данных, полученных с сервиса http://npchk.nalog.ru совершенно бесплатно.

1 стартмани

01.02.2018    26639    62    rpgshnik    46