|
27.01.2013, 10:56 | #1 |
Роман Долгополов (RDOL)
|
Производительность и надежность Workflow в DAX2009
Имеющие опыт практического применения workflow в DAX2009 поделитесь пжл своими мыслями по след вопросу
Требуется построить процесс утверждения некоторых документов. Выбор между стандартом и разработкой своего решения без использования стандарта и WF. 1. Одновременных экземпляров процесса десятки тысяч 2. Любые зависания, запаздывания, задвоения и прочие глюки недопустимы. Всё всегда должно просто работать и не вызывать вопросов Насколько стандарт адекватен этим условиям? Опять же просьба обсуждать задачу именно эту техническую задачу с данными условиями, а не спрашивать зачем это надо и кто будет нажимать кнопку десятки тысяч раз DAX2009 SP1 EE RU8 |
|
|
За это сообщение автора поблагодарили: sukhanchik (5). |
27.01.2013, 12:03 | #2 |
Moderator
|
У меня одни знакомые запустили workflow и теперь постоянно с ним борються. И когда не хватает знаний побороть что-то, то приглашают меня. (Эдак раз месяца в три). У меня такие впечатления сложились:
Уходя от конкретики в теорию:
Последний раз редактировалось fed; 27.01.2013 в 12:06. |
|
|
За это сообщение автора поблагодарили: db (10), sukhanchik (10), lev (11), oip (5), imir (2), Evgeniy_R (1). |
28.01.2013, 00:41 | #3 |
Модератор
|
Ну зачем же людей пугать-то. У нас работает, но не на таких объемах - порядка сотни параллельных инстансов, достаточно простые процессы одобрения из 2-5 шагов, нет сотен пользователей и групп (это все у нас пока на 4.0). Написали вэб-интерфейс для массового одобрения, вэбсервис - работает вполне нормально. По сравнению с купленным когда-то аддоном для 4.0 - так вообще сказка. Не делали инагрузочного тестирования на десятках тысяч инстансов, но если люди говорят что есть проблемы с производительностью в 2009, полагаю так оно и есть
По поводу "написать свое, с блэкджеком и шлюхами" - ну, если получится что-то универсальное - молодцы, что еще сказать. Пока все что видел - какие-то неуниверсальные стремные поделки (возможно, просто не везло) P.S. По поводу workflow в 2012 (она у нас пока в тестовой эксплуатации) - мне пока все нравится. Нагрузочное тестирование надо будет сделать кстати, хотя мы за тысячу параллельных инстансов выйти по моим ощущениям не должны P.P.S. Понимаю что задача поставлена техническая, но можно как-то сам сценарий использования обрисовать? Если эти десятки тысяч кнопок не люди нажимают, то кто - роботы ? А зачем эти автоматические нажатия через workflow пропускать - чисто ради истории ? Тогда наверное проще сбоку что-то незамысловатое прикрутить, особенно в свете проблем с производительностью в 2009
__________________
-ТСЯ или -ТЬСЯ ? |
|
28.01.2013, 11:12 | #4 |
Moderator
|
Цитата:
Ну то есть - я понимаю, когда системы workflow используют для СЛАБОФОРМАЛИЗУЕМОГО документооборота. Типа сидит у нас какая-нить проектно-исследовательская контора, обменивается служебными записками, проектной документацией, спецификациями, письмами заказчиков и тп. Мы тут прикручиваем документооборот, определяем типы документов, типы аннотационных полей для каждого документа, состояния документа и определяем цепочки утвреждений для документа. Вот тут workflow очень даже хорош и уместен. Но мы говорим о ERP-системе. ERP-система по определению работает со стандартизованными и формализованными документами и операциями. Я вообще не понимаю, зачем здесь документооборот настраиваемый ? Все равно ведь если бизнес-процесс поменяется, придется не только цепочку утверждений перепрограммировать, но и, с большой вероятностью, все остальное. А тут получается что мы угрохали на разработку модуля кучу времени (потраченного с пользой кстати) и потом еще тратим кучу времени на интеграцию всего этого с workflow (который из аксапты торчит как больной палец). И все ради того чтобы консультанты могли без программирования workflow перенастраивать ? Да не смешите меня - если что-то у заказчика поменяется то все равно программировать придется. Да и как я и говорил - иногда программирование намного быстрее и дешевле настройки. WF - это как раз наиболее яркая иллюстрация этого правила. |
|
|
За это сообщение автора поблагодарили: sukhanchik (3), Ace of Database (3), S.Kuskov (1). |
28.01.2013, 23:38 | #5 |
Модератор
|
Цитата:
Цитата:
Ну то есть - я понимаю, когда системы workflow используют для СЛАБОФОРМАЛИЗУЕМОГО документооборота. Типа сидит у нас какая-нить проектно-исследовательская контора, обменивается служебными записками, проектной документацией, спецификациями, письмами заказчиков и тп. Мы тут прикручиваем документооборот, определяем типы документов, типы аннотационных полей для каждого документа, состояния документа и определяем цепочки утвреждений для документа. Вот тут workflow очень даже хорош и уместен
- Журнал инвентаризации перед разноской должен быть одобрен warehouse manager-ом (это обязательный этап) - Журнал инвентаризации должен быть одобрен финансистом при превышении суммы приходования\списания к примеру $2000 или $100 по строке журнала - Добавь к этому работающие "из коробки" оповещения, делагацию и эскалацию - ну плохо разве? Ты бы знал, сколько "интересных" транзакций не было бы разнесено (а денег - потеряно или украдено) у нас в старой системе на 4.0 если бы имелся работающий механизм одобрений
__________________
-ТСЯ или -ТЬСЯ ? |
|
|
За это сообщение автора поблагодарили: Ivanhoe (3), gl00mie (3). |
29.01.2013, 13:57 | #6 |
Moderator
|
Понимаешь Вадик. Я раз в три месяца наблюдаю на работающей системе последствия доработки workflow неграмотными консами и разработчиками. На той же системе, я наблюдаю последствия доработки обычной X++ функциональности теми же неграмотными консами и доработчиками. Обычную функциональность диагностировать и чинить намного легче.
Если тебя окружают исключительно средние или хорошие консы и разработчики и у них есть время на то чтобы писать внятные ТЗ, программировать, тестировать, планировать релизы и тп - то могу только порадоваться за тебя. Но к сожалению, 80% проектов которые я вижу, не могут позволить себе такой роскоши. И для этих самых 80% проектов - workflow это просто еще одна замечательная возможность to shoot yourself in a foot. |
|
29.01.2013, 14:31 | #7 |
Участник
|
Цитата:
То что система одобрений полезна не ставится под сомнение, под сомнение ставится именно воркфлоу. ПС у нас работало одновременно и воркфлоу и самописка, в результате одновременной эксплуатации двух систем в течение полугода, было принято решение от форкфлоу отказаться, по причинам описанным выше в том числе. Последний раз редактировалось ice; 29.01.2013 в 15:10. |
|
28.01.2013, 12:59 | #8 |
Гость
|
Достаточно универсальный движок в стандарте 2009, надо просто взять его идею и реализовать по человечески.
|
|
27.01.2013, 12:21 | #9 |
Участник
|
Немного добавлю. В целом с большим объемом, действительно, будут проблемы. Но на паре сотен одновременных согласований работает нормально. Как плюс - настройка правил консультантом (пользователем), без программирования (в рамках реализованной модели).
Про обработку изменений - вроде как там есть что-то для отслеживания изменений конфигурации, но примеров в стандарте нет, поэтому, скорее всего, никто это не делает и возникают ошибки при серьезных изменениях. Запрет на удаление документа, контроль только одного запуска по документу нужно явно программировать, но это из серии аккуратности при разработке. Форма для отслеживания "моих документов для согласования" есть - Основное / Запросы / Журнал документооборотов. Там хитрая логика на форме, для не админов будут показываться только WF которые имеют отношение к пользователю. Знаю проектов 5 на которых в целом работает и выполняет поставленные задачи. Тяжелую проверку на права везде отключали.
__________________
Ivanhoe as is.. |
|
|
За это сообщение автора поблагодарили: db (5), sukhanchik (7). |
27.01.2013, 16:17 | #10 |
Moderator
|
Цитата:
Собственно - это я и имел в виду когда говорил о том что механизм создавался людьми далекими от ежедневной реальности внедрений. Если бы что-то подобное было бы в стандарте - механизм был бы более внедрябельным... |
|
27.01.2013, 12:47 | #11 |
Участник
|
На одном и проектов пришлось внедрять сию функциональность.
В итоге все конечно получилось, но после "обработки напильником". т.е. предстоит решить все проблемы о которых пишет fed. По поводу отладки - с помощью формы tutorial_workflowProcessor можно что-то поотлаживать, в целом этого хватало По поводу зависших сообщений - тут все просто решается модификацией. т.е. если сообщение не обрабатывается несколько раз, то просто переводим его в ошибку и в дальнейших выборках не берем. Стандартный обработчик будет его выбирать все время По поводу скорости - переход в каждый статус это 1-2 секунды 100% работы ядра процессора на IIS(что в это время происходит, это загадка) т.е. это стоит иметь в виду при планировании мощности сервера Следующая проблема - это то, что пакетный сервер работает минимум раз в минуту, а перевод из статуса в статус может состоять из 10 шагов к примеру(зависит от кол-ва настроек). Поэтому пришлось полностью переписывать обработчик, по следующему алгоритму - сделать группировку по экземплярам документооборота для обработки, по каждому экземпляру запустить свое пакетное задание, в котором выбирать сообщения данного экземпляра 10 раз, и по каждому запускать обработку. Это дало гарантированный переход со статуса в статус в пределах 1-2 минут Еще одна проблема - это отчетность по документообороту - в том дереве которое есть в стандарте намешаны системные и пользовательские события, использовать его очень сложно. т.е. пришлось еще разрабатывать отчет т.е. мое резюме - использовать все же можно, но не "из коробки". В конце мы делали нагрузочный тест, в целом все работало без сбоев Также стоит иметь ввиду архитектурное ограничение на отсутствие мгновенности в плане смены статусов(минимум это будет 1-2 минуты). если это нужно, то стандартный документооборот не ваш выбор |
|
|
За это сообщение автора поблагодарили: db (10), sukhanchik (10). |
27.01.2013, 13:16 | #12 |
Роман Долгополов (RDOL)
|
Цитата:
1. Сколько было одновременных экземпляров в нагрузочном тесте? 2. Сколько времени ушло на обработку напильником и вылавливание косяков? Не чистого времени разработки, а именно через сколько (месяцев?) оно таки более менее начало жить? |
|
27.01.2013, 15:59 | #13 |
Участник
|
ну у нас где-то 300 счетов обработалось за 15 минут. Под обработкой подразумевается шаг Начало(он самый тяжелый из всех шагов). но сам документооборот был довольно навороченным, состоял из многих subworkflow. кол-во экземпляров по сути регулировалось в параметрах АОСа - это кол-во пакетных заданий. там было что-то около 20. было вроде как по 2 ядра на АОСе и на IIS. они грузились на 100% при этом
по времени тут точно не месяца, по сути единственное что можно улучшать это обработчик, но он не очень сложный. все остальное скрыто в недрах .net. т.е. тут все днями измерялось |
|
29.01.2013, 18:07 | #14 |
Участник
|
Цитата:
Сообщение от trud
ну у нас где-то 300 счетов обработалось за 15 минут. Под обработкой подразумевается шаг Начало(он самый тяжелый из всех шагов). но сам документооборот был довольно навороченным, состоял из многих subworkflow. кол-во экземпляров по сути регулировалось в параметрах АОСа - это кол-во пакетных заданий. там было что-то около 20. было вроде как по 2 ядра на АОСе и на IIS. они грузились на 100% при этом
по времени тут точно не месяца, по сути единственное что можно улучшать это обработчик, но он не очень сложный. все остальное скрыто в недрах .net. т.е. тут все днями измерялось Так вот, WF присылало изменённый статус по документу где-то раз в минуту. Ускорить удалось до ~5 сек, поковырявшись в настройках IIS, в оснастке открыть "Пул приложений", найти свой экземпляр WF, и далее, меняя в настройках дополнительных параметров в группе полей "Модель процесса" период времени между проверками связи, если не ошибаюсь - там несколько полей, связанных с откликом, уже не помню конкретно, что менял, можно попробовать поиграться с параметрами. Опять же, я не спец по IIS и не программист, ковырял чисто интуитивно, и что там на что ещё может повлиять - не знаю . Но вот за что купил в своё время, за то и продаю.
__________________
Если машина не заводится с пятого раза - читай инструкцию. |
|
27.01.2013, 19:09 | #15 |
Гость
|
Стандарт неадекватен сам по себе
Из практического опыта был год использования стандартного workflow с допилами. Масса негатива от пользователей была. Запоздалая реакция на действия пользователя, периодические зависания с пожиранием всей памяти на машине с IIS, трудоемкость поиска источников проблем. В итоге реализовали workflow средствами только Аксапты. IIS не нужен, пакетник для общения с ним не нужен, данные хранятся по человечески, а не в десяти таблицах, в каждой из которых пара значащих полей и десяток GUID-ов, система мгновенно реагирует на выбор пользователя, а не размышляет пару минут над тем, какую же он нажал кнопку. После этого негатив от пользователей и консультантов в отношении workflow закончился. Вобщем, пилите сами, но перед этим некоторое время в тестовом режиме повозитесь со стандартом, чтобы понять, какой функционал вам нужен и как вы его будете использовать. По задумке стандарт вполне нормален, реализация только мутная. |
|
27.01.2013, 21:52 | #16 |
Участник
|
А как обстоят дела в Ax 2012?
Только собрался это внедрять и тут такой заряд "позитива"... ) |
|
28.01.2013, 09:30 | #17 |
Участник
|
В 2012 используется WF4, где, как говорят, существенно увеличили производительность. К тому же теперь не нужен IIS - он встроен, прямо в АОС. Но у меня реального опыта с ним нет - поэтому не скажу насколько он лучше 2009
|
|
28.01.2013, 09:37 | #18 |
Модератор
|
Не скажу за производительность, но помню пляски с настройкой нескольких инстансов WF на одном хосте в 2009 - и как же хорошо стало с 2012
__________________
-ТСЯ или -ТЬСЯ ? |
|
28.01.2013, 11:15 | #19 |
Moderator
|
В догонку: Вообще задачи цепочек утверждения имеют наименьший по пользе для бизнеса приоритет по сравнению с задачами бюджетирования, производственного планирования, финансового учета и аналитиза и тп.
То есть - если вы до задач workflow и утверждения добрались не на третьем году жизни проекта, а на первом, то, с большой вероятностью, у вас что-то не так с целями проекта.... |
|
28.01.2013, 13:40 | #20 |
Участник
|
Цитата:
Сообщение от fed
В догонку: Вообще задачи цепочек утверждения имеют наименьший по пользе для бизнеса приоритет по сравнению с задачами бюджетирования, производственного планирования, финансового учета и аналитиза и тп.
То есть - если вы до задач workflow и утверждения добрались не на третьем году жизни проекта, а на первом, то, с большой вероятностью, у вас что-то не так с целями проекта.... Согласен, что тот WF который сделан в стандарте по заявкам на покупку слишком глубоко интегрирован с самим процессом. В итоге или приходится 1:1 использовать стандарт, либо все переделывать. Тот же Travel expenses - тоже странный процесс с _обязательным_ использованием портала. Но есть же другие примеры - те же журналы ГК. Просто из коробки чуть более развитая система утверждения - чем плохо? Из того, что обычно требуется в РФ на проектах: 1. Согласование платежей. Это либо стандартный журнал либо чье-нить решение а-ля "Казначейство" и заявка на оплату. 2. Согласование договоров. 3. Согласование бюджетов. 4. Согласование заказов на покупку, согласование заказов на продажу. 5. Реже - согласование карточек контрагентов, номенклатур, доверенностей и т.п. Как правило в этих WF нужно провести документ по нужным сотрудникам для дозаполнения и/или контроля / одобрения. В итоге нужно получить один статус - "Утверждено", который позволяет далее использовать документ по стандартному назначению Dynamics AX. C учетом встроенной же возможности прикреплять скан-копии, получаем вполне удобную систему простого документооборота. Практически из коробки. P.S. В 2012 стало еще больше стандартных документооборотов (документов-оснований). P.P.S. Просто добавить возможность согласовать документ (поменять один статус по аналогии с написанным выше) занимает у опытного разработчика день-два (AX 2009). После этого оно работает "как в стандарте".
__________________
Ivanhoe as is.. |
|