gifts2017

Metadata.js для построения дешевых высоконагруженных сервисов

Опубликовал Евгений Маляров (unpete) в раздел Программирование - Инструментарий

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

Что такое Metadata.js?

  • Движок ссылочной типизации для браузера и nodejs
  • Библиотека для разработки бизнес-ориентированных и учетных offline-first браузерных приложений

Если коротко, то метадата предоставляет веб-программисту высокоуровневые объекты данных, аналогичные тем, которыми пользуются программисты 1С (перечисления, справочники, документы, регистры и т.д.)

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

Еще, metadata.js можно рассматривать, как "БСП для веб", предлагающую готовые решения для:

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

Если у кого-то возник вопрос «а не очередной ли это велосипед», вынужден возразить: я достаточно ленивый человек, чтобы повторять функциональность, реализованную другими. Если бы нужную математику можно было купить, сделал бы это без долгих размышлений – это всегда дешевле и быстрее. Я старался не дублировать работу, проделанную уважаемым javascript-сообществом и по возможности использовать стандартные библиотеки. Вот список основных зависимостей:

Серверная часть

  • couchDB, NoSQL база данных с поддержкой master-master репликации
  • nginx, высокопроизводительный HTTP-сервер

Управление данными в памяти браузера

  • metadata.js, движок ссылочной типизации для браузера и Node.js
  • pouchDB, клиентская NoSQL база данных с поддержкой автономной работы и репликации с CouchDB
  • alaSQL, SQL-интерфейс к массивам javascript в памяти браузера и Node.js
  • aes, библиотека шифрования/дешифрования строк
  • xlsx, библиотека для чтения и записи XLSX / XLSM / XLSB / XLS / ODS в браузере

UI библиотеки и компоненты интерфейса

  • dhtmlx, кроссбраузерная библиотека javascript для построения современных веб и мобильных приложений
  • handsontable, компонент для отображения и редактирования табличных данных
  • daterangepicker, компонент визуализации и редактирования диапазона дат
  • filesaver.js, HTML5 реализация метода saveAs
  • moment.js, библиотека форматирования интервалов и дат
  • numbro, библиотека форматирования чисел
  • rubles.js, библиотека форматирования чисел - сумма прописью

Зачем это нужно и что даёт?

  • Масштабируемость и надёжность. Сервер средней мощности может обслуживать тысячи клиентов и эти клиенты сохранят работоспособность при перебоях связи
  • Неограниченная свобода в дизайне отзывчивого интерфейса
  • Новое качество веб-приложений, сочетающее мощь бизнес-объектов 1С с эффективностью и открытостью веб-технологий

Предыстория

Список заказов

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

Графический редактор

Система должна рассчитать геометрию элементов, спецификацию, стоимость и отправить эту информацию в план завода.
Типичный оконный завод производит до 1000 изделий в день, сотрудничает с большим количеством дилеров (от 200 до 500).

Из задачи вытекали спецтребования:

  • Редактору геометрии требовалась интенсивная работа с данными в браузере в реальном времени – по каждому смещению мыши на сервер не набегаешься
  • Должно работать при плохой связи и в автономном режиме
  • Нужен гибкий отзывчивый интерфейс с поддержкой, в том числе, мобильных устройств
  • Нужно нулевое администрирование на клиентах
  • Хотелось сэкономить на лицензиях и серверном оборудовании

Имелся 1С-ный прототип для управления позаказным производством. В нём были подсистемы расчета спецификации, сложного ценообразования, диспетчеризации и учета - надстройка над 1С:КА 1.1. Повторить такой проект "в лоб", на языке программирования общего назначения - задача нереальная даже в теории. Решил разделить эту задачу на части:

  • Делаем платформу, которая позволит использовать структуру объектов и синтаксис ala-1С
  • Транслируем 1С-ный прототип в термины этой платформы
  • Бинго! Имеем дешевый функциональный отказоустойчивый сервис

Преемственность синтаксиса

Свойства и методы объектов metadata схожи, но не повторяют и не ограничиваются возможностями 1С.
Например, у нашей табличной части (TabularSection) есть метод НайтиСтроки (find_rows). Кроме стандартного поиска по равенству полей, добавлен синтаксический сахар:

// поиск в 1С
Результат = ТабЧасть.НайтиСтроки(Новый Структура("Поле1", Значение1));
// поиск, "как в 1С"
res = ts.find_rows({Поле1: Значение1});
// поиск на неравенство
res = ts.find_rows({Поле1: {not: Значение1}});
// поиск по списку значений
res = ts.find_rows({Поле1: {in: [Значение1, Значение2]}});
// логическое ИЛИ
res = ts.find_rows({or: [{Поле1: Поле1}, {Поле2: Поле2}]});
// поиск с произвольным условием
res = ts.find_rows({Поле1: function(v, key){if v[key] > 3 return true;}});
// поиск с условием SQL выполняется на клиенте, без обращения к серверу
res = alasql("select * from ? where `Поле1` > 3", ts._obj);

Сравнение производительности

В offline-режиме, приложение metadata подобно локальной файловой базе 1С. Оба движка работают в этом режиме весьма шустро.
При работе с длинными списками, в metadata чуть больше свободы:

  • Можно построить сложные, составные или фасетные индексы
  • Если позволяет железо, можно работать с таблицами в памяти
  • Можно наоборот, пожертвовать производительностью в пользу экономии памяти - всё зависит от задачи

Если metadata используется, как альтернативный лёгкий клиент к серверу 1С, получаем значительное ускорение даже на типовых конфигурациях. В эксперименте использованы:

  • Один и тот же сервер – физически он расположен в Германии
  • Она и та же информационная база
  • Один и тот же канал в интернет ping ~ 90ms
  • И даже документ мы один и тот же открываем

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

В metadata та же операция выполняется за 400 мс.

Теперь посмотрим сетевой трафик. В metadata json прочитанного заказа занимает порядка 7 Кб.

В 1С, только передача пакета отъела 700 мс, и этот пакет занимает 180 Кб.

Таблица объединяет данные результаты измерений:

Операция Metadata Веб клиент 1С Выигрыш
времени, раз
Выигрыш
трафика, раз
Мин. время реакции сервера 150мс 150мс - -
Загрузка и вход в программу 4сек/4Mb 20сек/6Mb 5 1,5
Открытие формы "Заказа" 400mc/8Kb 2200mc/180Kb 5 20
Открытие формы выбора справочника 300мс/0Kb 600мс/10Kb 2 >>
Поиск в динсписке кешируемых объектов 200мс/0Kb 300мс/10Kb 1,5 >>
Поиск в динсписке с обращением к серверу 300мс/10Kb 300мс/10Kb - -

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

Я не критикую платформу 1С. Технологии веб-клиента 1С и легкого клиента отличаются очень сильно.
Наш лёгкий клиент не предназначен для замены традиционного веб-клиента в тех задачах, с которыми платформа 1С справляется хорошо.
Конкурировать с 1С на её поле - глупо и бесперспективно. Зато, с metadata.js можно сделать бизнесу выгодное предложение в тех областях, куда 1С вообще не заглядывает. Появляется возможность добавить в дешевые веб-приложения такие функции, которые ранее были доступными только в тяжелых учетных системах.

Совмещаем сильные стороны 1С и современного web для решения бизнес-задач

Есть встречное движение:

  • 1С в глобальную сеть
  • Традиционный web – в область задач автоматизации бизнеса

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

  • Веб-технологии содержат фантастические по изяществу и выразительности инструменты, но, к сожалению, там нет необходимого для бизнес-задач уровня абстракции. Посмотрите на сайты платежных систем, заказа билетов на самолет, поезд, личные кабинеты операторов сотовой связи – функциональность скудная, так как в языке, на котором думают постановщик и разработчик, нет слов для описания решаемой задачи.
  • Платформа 1С - это очень мощный инструмент для построения учетных систем, но он сильно отстал от современного веб. Дело в том, что в 2008-2009 годах, когда проектировалась архитектура управляемого приложения,  Javascript был другим. В браузерах не было автономной работы, в языке отсутствовали инструменты для управления свойствами объектов. В результате тонкий и веб-клиент 1С умеют лишь показывать данные и принимать ввод пользователя. В конце нулевых годов, такому подходу, наверное альтернативы не было. Но сегодня, когда любой телефон содержит несколько вычислительных ядер и несколько гигабайт ОЗУ, использование только серверного рендеринга и отказ от данных на клиенте – это непозволительная роскошь.
  • В metadata.js
    • Задействованы возможности современных браузеров
    • Реализован уровень абстракции, доступный ранее только в платформе 1С
    • Часть вычислительной работы и хранение коротких списков - справочников и перечислений перенесена на клиента.
      Это позволило значительно улучшить производительность, снизить нагрузку на сервер, повысить скорость и качество разработки

Инструменты metadata.js могут украсить жизнь как разработчикам 1С, так и веб-программистам. Но и те, и другие пока не проявляют интереса к нашей математике.
Рассчитывают отсидеться на освоенных технологиях. Конкуренция пока небольшая, «пирога» всем хватает.

Есть устоявшиеся стереотипы:

  • Для работы браузера нужно подключение к Интернет
  • Настольная программа работает быстро, а браузерная - тормозит
  • 1С-ный синтаксис есть только внутри 1С
  • Система на 1000 пользователей - это очень дорого
  • Из браузера трудно достучаться до COM и USB портов и прочего внешнего оборудования
  • Автономное веб-приложение - это очень сложно

Metadata.js пытается эти стереотипы пошатнуть.

  • Браузер прекрасно работает offline
  • Нативному приложению, чтобы приблизиться к качеству веб-интерфейса, сначала нужно реализовать внутри себя браузер
  • Синтаксис, подобный 1С-ному, теперь доступен в javascript
  • Система на 1000 пользователей - это реально дешево
  • Из javascript легко управлять COM, USB и сетевыми устройствами
  • Автономное веб-приложение - это очень просто

Пользуйтесь и зарабатывайте на внедрениях.

*****************

Данная статья написана по итогам доклада, прочитанного на конференции INFOSTART EVENT 2015 CONNECTION 15-17 октября 2015 года.

Приглашаем вас на новую конференцию INFOSTART EVENT 2016 DEVELOPER.

См. также

Подписаться Добавить вознаграждение

Комментарии

1. Игорь Steelvan (Steelvan) 08.08.16 10:28
Что бы оно автономно работало, надо локально устанавливать apach или что-то подобное ?
2. Евгений Маляров (unpete) 08.08.16 10:36
(1) Steelvan,
Что бы оно автономно работало, надо локально устанавливать apach или что-то подобное
Клиенту для автономной работы ничего устанавливать не надо.
Конфигурация сервера зависит от задачи. Если нужно совсем автономное рабочее место (например, учет личных финансов), работать может вообще без сервера - по аналогии с локальной файловой 1С.
3. Игорь Steelvan (Steelvan) 08.08.16 11:02
куда браузер будет локально обращаться ? По какому адресу ?
4. Игорь Steelvan (Steelvan) 08.08.16 11:03
Без сервера ? Подключение сразу к файлу 1CD ?
5. Евгений Маляров (unpete) 08.08.16 11:15
(4) Steelvan,
Подключение сразу к файлу 1CD
При чем здесь 1CD? Metadata это не надстройка над 1С, а самостоятельный движок данных, который умеет бесшовно интегрироваться с 1С, если этого требует прикладная задача.
куда браузер будет локально обращаться ? По какому адресу ?
За данными, браузер у нас не "обращается адресу" а читает и пишет их в indexedDB
6. Сергей (Che) Коцюра (CheBurator) 08.08.16 12:28
осталось расписать что такое nodejs
7. Евгений Маляров (unpete) 08.08.16 12:58
(6) CheBurator,
осталось расписать что такое nodejs
Это вопрос, сарказм или предложение?
Через неделю планирую опубликовать статью "Helloworld на metadata.js" с пошаговыми инструкциями и примерами кода. Надеюсь, статья ответит на базовые вопросы.
TreeDogNight; z86; dlebedev8; ZLENKO; pablo_escobar; Alien_job; Makushimo; kare; EliasShy; +9 Ответить
8. Роберт В е р т и н с к и й (v3rter) 08.08.16 13:37
Гуглим:

http://www.oknosoft.ru/metadata/codex/#obj=0100&ref=&frm=&view=content
Штатно, решения на metadata.js работают по протоколу https. При использовании нешифрованного http, становятся недоступны функции serviceWorkers, но в остальной части, приложение остается работоспособным. В codex предприняты специальные усилия, чтобы примеры работали даже по протоколу file. Скопируйте и разархивируйте файлы https://github.com/oknosoft/metadata.js/archive/master.zip в любую папку на локальном компьютере и откройте файл index.html из корневого каталога.


Примеры https://github.com/oknosoft/metadata.js/tree/master/examples/unf

Особенности: http://www.oknosoft.ru/metadata/
Для некоммерческих Open Source проектов доступна лицензия AGPL-3.0
Коммерческая лицензия на разработчика стоит €300 и позволяет использовать и распространять ПО в любом количестве неконкурирующих продуктов, без ограничений на количество копий


9. игорь Никик (igo1) 08.08.16 14:15
Не очень понятно, но зерно интереса есть.
10. Евгений Маляров (unpete) 08.08.16 14:20
(8) v3rter,
Штатно, решения на metadata.js работают по протоколу https
Имеется в виду транспорт для синхронизации с сервером. Понятно, что в автономном режиме https не используется, т.к. сервер недоступен
Посмотреть примеры полезно, но они для движка версии v0.9 - конец 2015 года. Полноценная автономная работа появилась в v0.10 - март 2016. Актуальная версия v0.11.
Для некоммерческих Open Source проектов доступна лицензия AGPL-3.0
Если ваш проект с открытым кодом - покупать лицензии не требуется.
Для коммерческих проектов нужны наши лицензии плюс лицензии задействованных библиотек: dhtmlx и handsontable
Важно: все лицензии на разработчика. Их можно использовать для неограниченного числа автоматизируемых рабочих мест на неограниченном количестве серверов.
11. Михаил (MishaD) 08.08.16 19:29
Посмотрел Демо на https://jsfiddle.net . Слева структура метаданных, справа отображение. А между ними огромный пустой кусок. Причем если потянуть разделитель влево, то метаданные скрываются, а пустого места меньше не становится. Сверху предположительно есть кнопочки, но их не видно. Использую Яндекс браузер.
Прикрепленные файлы:
12. Евгений Маляров (unpete) 08.08.16 19:58
(11) MishaD, Фрейм jsfiddle, действительно, портит разметку. Пример там опубликован, чтобы показать лаконичность клиентского кода. Его там всего 10-20 строчек.
Если открыть то же самое без jsfiddle-обёртки, разметка нормальная.
13. Юрий Пермитин (YPermitin) 08.08.16 20:06
(0) unpete,
Еще год назад примерно смотрел ваш продукт Metadata.js, интересная реализация, даже для экспериментов делал у себя некоторые доработки. Но вопрос - какая лицензия? На каких условиях распространяется продукт?

Этот вопрос меня останавливал использовать его в продакшене у клиентов.
14. Капитан Немо (capitan) 08.08.16 21:47
Есть много проектов, которым я неистово аплодирую за их оригинальность..
Но противопоставлять себя грандам... да еще на сайте сообщества 1С :)
Сколько не занижай приору, ламборджини из нее не выйдет.
Кроме метаданных, под капотом 1С достаточно серьезные решения.
Команда программистов, постановщиков задач и т.п.
И до вас и после будут проекты пытающиеся оперировать бизнес-объектами.
Тырить логику конфигурации у 1С дело не хитрое.
Собственно в этом и все совмещение вашей платформы и 1С ?
15. Капитан Немо (capitan) 08.08.16 21:57
(13) YPermitin,
18000 рублей
Но!
в состав Metadata.js входит dhtmlx цена на который для проектов больше 1 - от 1000 у.е.
К тому же в лицензии написано :Распространение ПО в составе продуктов, являющихся конкурентами metadata.js, или обладающих схожей с функциональностью - запрещено
То есть вместе с 1С ее нельзя использовать.
16. Oleg Solovyeff (Solovyeff) 09.08.16 00:10
Задумка очень интересная, давно присматриваюсь к JS (особенно Node.JS), но если capitan прав с суммарной стоимостью лицензии, то продукт совсем не дешев и вместе с разработкой для заказчика выйдет в очень круглую сумму, что в нынешнее время резко сужает круг заинтересованных лиц, опять же, вряд ли этот фактор может поспособствовать "голубому океану":).
P.S. Интересно было бы услышать комментарии автора насчет лицензии и конечно побольше примеров работы с metadata.js
17. Александр Гордеев (goldencity178) 09.08.16 06:03
В яндекс браузере дофига корявостей с отображением страниц, С гугла его содрали быстро, но не доработали с полем HTML поэтому скорее всего и есть глюк самого яндекс браузера.
18. Александр Гордеев (goldencity178) 09.08.16 06:05
подходит скорее для групп объединенных компаний и холдингов, инвесторов и даже крупных Российских банков
19. Александр Гордеев (goldencity178) 09.08.16 06:18
"К тому же в лицензии написано :Распространение ПО в составе продуктов, являющихся конкурентами metadata.js, или обладающих схожей с функциональностью - запрещено
То есть вместе с 1С ее нельзя использовать. "
Распространение - это продажа и реализация, а не эксплуатация. Использовать можно так как в предложении : "Распространение ПО в составе продуктов, являющихся конкурентами metadata.js, или обладающих схожей с функциональностью - запрещено" - здесь идет запрет о совместной продаже и с юридической точки зрения запрет совместного распространения и запрет эксплуатации - НЕ ОДНО И ТОЖЕ
20. Александр Гордеев (goldencity178) 09.08.16 06:29
Продавать на сайте или в интернет магазине можно как различные и отличающиеся друг от друга продукты и в коммерческом предложении прописывать как рекомендуемый для совместной работы продукт. но в одном программном продукте не распространять, как и прописано в лицензии.
В 1С Сделайте документ "Коммерческое предложение" состоящее из 2 различных частей.
1. Товары и услуги.
2. Рекомендуемые дополнения.

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

Ситуация довольно примитивная, но позволяет обойти условия не нарушая при этом таковые вышеизложенные условия лицензии.
21. Александр Гордеев (goldencity178) 09.08.16 06:36
Если у вас есть в движке сайта возможность добавлять к продаваемым сопутки, сделайте их как рекомендуемые, условия "Распространение ПО в составе продуктов, являющихся конкурентами metadata.js, или обладающих схожей с функциональностью - запрещено" вы не нарушаете, если в языковом файле движка магазина вместо сопутки написать рекомендую дополнение, то это хороший вариант. все условия соблюдены и юридически довольно граммотно.

Юристы верят бумажкам и доказательствам, а не словам
22. Юрий Былинкин (ardn) 09.08.16 08:15
metadata.js можно оформить в виде приложения для смартфонов (android)?
23. Евгений Маляров (unpete) 09.08.16 08:58
(22) ardn, Конечно.
Если по каким-то причинам не устраивает исполнение программы внутри браузера, приложение можно скомпилировать с помощью cordovaв нативное для ios и android, а с помощью electron - в нативное для windows, linux и osx
24. Евгений Маляров (unpete) 09.08.16 09:10
(14) capitan,
противопоставлять себя грандам
В чем противопоставление?
Я в каждом абзаце подчеркиваю, что если некая задача хорошо решается в 1С, не надо тратить время на метадату.
Я не предлагаю заменить метадатой настольную 1С. Напротив, предлагаю распространить подходы 1С в большой веб и мобильные приложения.
Там реально непаханое поле и сообщество 1С могло бы эффективно на этом поле поиграть.
Тырить логику конфигурации у 1С
Такую предъяву неплохо бы обосновать. Что именно я стырил?
Собственно в этом и все совмещение вашей платформы и 1С
Бесшовная интеграция - одна из, но не единственная и не главная функция 1С.
Если бы Вы дали себе труд посмотреть в исходники, Вам бы тоже очень понравилось, как эта интеграция устроена изнутри
25. Юрий Былинкин (ardn) 09.08.16 09:11
Отлично
На гитхабе актуальные примеры? Хочу освоить ваш движок.
26. Евгений Маляров (unpete) 09.08.16 09:19
(15) capitan,
входит dhtmlx цена на который для проектов больше 1 - от 1000 у.е.

  • В коммерческую лицензию метадата не входят лицензии dhtmlx и handsontable
  • metadata умеет работать на сервере или в браузере без визуализации. В этом случае, dhtmlx и handsontable не нужны. Вы можете манипулировать объектами данных с помощью metadata, а показывать их пользователю с помощью своего кода
  • для opensource проектов работает agpl, по которой ничего покупать не надо


27. Евгений Маляров (unpete) 09.08.16 09:21
(25) ardn,
На гитхабе актуальные примеры

Примеры драматически старые. В ближайшие недели запланирована публикация новых примеров + статья с пошаговыми инструкциями для быстрого старта
peterg; z86; chek.e.l@mail.ru; ardn; +4 Ответить 1
28. Евгений Маляров (unpete) 09.08.16 10:03
(13) YPermitin,
Но вопрос - какая лицензия? На каких условиях распространяется продукт?

Приложения на metadata.js умеют работать в разных режимах:
  • Распределенная система - в этом режиме, CouchDB реализует шину данных, к которой подключены веб-клиенты и одна или несколько ИБ 1С. Базы могут быть разной структуры и располагаться в разных датацентрах. Репликация с 1С выполняется в фоновых заданиях
  • Клиент-серверный режим без 1С - в этом режиме, используем ту же шину данных, но 1С к ней не подключена рантайм. Обмен с 1С может выполняться отдельными обработками
  • Локальный однопользовательский режим без 1С - отдельный компьютер или мобильное устройство без доступа к сети. Обмен с внешним миром через дискету или флешку
  • Лёгкий клиент 1С - должны быть опубликованы http-сервисы 1С. Веб-приложение обращается напрямую к серверу 1С. В этом (и только в этом) режиме, требуются клиентские лицензии 1С по числу одновременно выполняющихся запросов. Не путать с количеством клиентов, в браузерах которых открыто веб-приложение. Технически, лицензии не нужны. Сервер 1С из пула лицензий при работе http-сессии ничего не откусывает. Юридически, в разных документах у 1С на этот счет разные толкования. Я вёл переписку с отделом лицензирования 1С. Внятного официального ответа так и не получил. Думаю, если возникла потребность именно в лёгком клиенте, проще эти 1С-ные лицензии просто купить. Не такая уж это большая сумма на фоне общей стоимости проекта
Теперь, про лицензии на разработчика:
  • AGPLv3 - имеете право ничего никому не платить, но обязаны предоставить по первому требованию исходные тексты всего вашего проекта, плюс, обязаны упомянуть в титрах все использованные библиотеки. Проект может быть коммерческим, Вы можете брать деньги за лицензии и сопровождение. Главное, соблюсти два условия: открытый код + упоминания авторов
  • Коммерческая лицензия - наша лицензия стоит 18 тыс. руб. на разработчика и позволяет выпускать и тиражировать прикладные решения с закрытым кодом. Решения не должны конкурировать с самим движком metadata. Например, будет незаконно переименовать метадату в ala1c, изменить стили оформления и выдавать за свою разработку. Кроме нашей коммерческой лицензии, потребуются коммерческие лицензии всех остальных, задействованных в вашем проекте библиотек (их состав зависит от вашего проекта)
29. Евгений Маляров (unpete) 09.08.16 10:10
(18) goldencity178,
холдингов, инвесторов и даже крупных Российских банков
Представители СБ РФ вели со мной переговоры про фронт на metadata, но потом соскочили - якобы их служба безопасности не одобрила
30. Евгений Маляров (unpete) 09.08.16 10:25
(16) Solovyeff,
продукт совсем не дешев
Там 2 человекогода работы - примерно 4000 человекочасов. Вы какую цену порекоменудете?
побольше примеров
спасибо, учту
31. Капитан Немо (capitan) 09.08.16 12:22
(26) unpete,
В коммерческую лицензию метадата не входят лицензии dhtmlx и handsontable
metadata умеет работать на сервере или в браузере без визуализации. В этом случае, dhtmlx и handsontable не нужны.

Если я буду работать на сервере без визуализации, я просто из 1С впишу/прочитаю данные в БД.
Это будет по крайней мере безопаснее, нежели использовать такую прослойку как у вас. И абсолютно точно не съест лицензий, кроме серверной.
А отобразит их веб программист с помощью своего кода.
Народ то возбуждается как раз на отображение в виде аля 1С, а оно стоит как серверная лицензия 1С.
для opensource проектов работает agpl, по которой ничего покупать не надо

Приведите пожалуйста пример opensource проекта на 1С.
Кстати. Прошел год с вашего доклада и насколько я вижу на всех значимых форумах по 1С вы тогда отписались.
Есть Success Stories успешных внедрений?
Дилеры оконных заводов не в счет, им то я понимаю в добровольно/приказном порядке систему внедрили.
depresnjak; 33lab; Solovyeff; +3 Ответить 2
32. Юрий Пермитин (YPermitin) 09.08.16 12:28
(28) unpete, спасибо за развернутый ответ.

Думаю продукт стоит внимания.
Не знаю как у других, но для решения моих задач его использовать можно даже с учетом лицензирования по AGPL.

Если правильно понимаю, то pull-request'ы на GitHub разрешены и приветствуются? =)
33. Евгений Маляров (unpete) 09.08.16 12:49
(31) capitan,
просто из 1С впишу/прочитаю данные в БД
Если вы предпочитаете вместо документов, регистров и справочников оперировать сырыми записями БД, metadata в этом, конечно, не поможет.
Программист в metadata не использует XHR и не работает с DOM. Он пишет обработчики событий "при создании", "при изменении реквизита", "перед записью" и т.д. в модулях объектов и менеджеров
Народ то возбуждается как раз на отображение в виде аля 1С
Давайте не будем фантазировать, от чего возбуждается народ и предоставим возможность использовать в работе те инструменты, которые он сочтет удобными для своих задач.
В заголовке написано: "Движок ссылочной типизации" - ни слова про "отображение"
Метадата умеет рисовать интерфейс, но в этом она не оригинальна. Есть сотни библиотек про рисование интерфейсов.
Зато, библиотек про оффлайн/онлайн данные с методами и свойствами, как в 1с, я в интернете не нашел.
34. Евгений Маляров (unpete) 09.08.16 12:51
(32) YPermitin, Конечно, приветствуются с благодарностью.
35. Oleg Solovyeff (Solovyeff) 09.08.16 14:23
(30) unpete,
Там 2 человекогода работы - примерно 4000 человекочасов. Вы какую цену порекомендуете?

1С знаете сколько человекочасов потратило на свой продукт, а хотя бы ты же microsoft на Visual Studio Code оооо.. Только вряд ли они пели про стратегию голубого океана и прочее, при этом забывая о такой сущей мелочи как сторонняя лицензия в тысячу баксов, ага.

P.S. Я однозначно не за халяву, сам программист., но очень любопытно узнать как человек/компания собирается создавать рынок, с таким отношением и стратегией)) Часто у вас потенциальные клиенты спрашивают сколько ваш труд стоит человекочасов и как они счастливые готовы за это платить? Опять же, 18 000 это копейки, я про "скрытые" лицензии. Насчет безопасности само собой вопрос открытый.. Но все равно, задумка хорошая и однозначно стоит наблюдать за эволюцией, кто знает может будет Angular в мире 1C)
36. Евгений Маляров (unpete) 09.08.16 15:56
(35) Solovyeff,
может будет Angular в мире 1C
Аналогии не понял. Angular - он про манипуляции с DOM. Metadata - про ссылочные данные на клиенте, обработку событий объектов данных и прозрачную их синхронизацию с сервером и другими клиентами. Вроде, совсем разные задачи.
37. Евгений Маляров (unpete) 09.08.16 15:59
(35) Solovyeff,
Насчет безопасности само собой вопрос открытый
А что не так с безопасностью? Для транспорта используем только шифрованный https. Или Вы какую-то другую безопасность имеете в виду?
38. Евгений Маляров (unpete) 09.08.16 19:11
(35) Solovyeff,
1С знаете сколько человекочасов потратило на свой продукт
Про часы не знаю, но сравним для примера метод Итог() в 1С и нашей табличной части.
Цитата из синтакс-помощника:
Итог (Total)
Синтаксис:
Итог(<Колонка>)
Параметры:
<Колонка> (обязательный)
Тип: Число; Строка.
Индекс либо имя колонки, по которой подсчитывается итог.
Возвращаемое значение:
Тип: Число; Неопределено.
Описание:
Суммирует значения всех строк в указанной колонке.

Цитата из API metadata:
aggregate ( [dimensions] [resources] [aggr] [ret_array] ) Number | Array
Вычисляет агрегатную функцию по табличной части
Не изменяет исходный объект. Если пропущен аргумент aggr - вычисляет сумму.
Стандартные агрегаторы: SUM, COUNT, MIN, MAX, FIRST, LAST, AVG, AGGR, ARRAY, REDUCE
AGGR - позволяет задать собственный агрегатор (функцию) для нестандартного расчета итогов
Параметры:
[dimensions] Array | String optional - список измерений
[resources] Array | String optional - список ресурсов
[aggr] String optional - агрегатная функция
[ret_array] Boolran optional - указывает возвращать массив значений
Возвращает:
Number | Array:
Значение агрегатной фукнции или массив значений
39. Андрей Д. (detec) 10.08.16 09:42
Идея хорошая, примеры выглядят прилично. Думаю, это может взлететь на зарубежных рынках.
40. Евгений Маляров (unpete) 10.08.16 10:12
(31) capitan,
Success Stories успешных внедрений?
https://www.npmjs.com/ устроит? Обрабатывает 500 млн. запросов в сутки, до 10 тыс. запросов в секунду. Каталог 380 тыс. записей. Наверняка, вы и сами использовали npm в работе. На сервере они используют примерно ту же математику, что и в metadata. Или эта story недостаточно success?
41. Капитан Немо (capitan) 10.08.16 12:48
На сервере они используют примерно ту же математику, что и в metadata

Угу.
Я распечатываю список контрагентов и в газпроме распечатывают список контрагентов.
Значит я работаю в газпроме.
На вашей системе кроме вас кто то еще создал коммерческие решения или год пиару прошел зря ?
42. Denis Lebedev (dlebedev8) 10.08.16 13:40
(29) unpete, ай-яй-яй, как нехорошо вы поступаете, что разглашаете тайну коммерческих переговоров. Правильно они сделали, что соскочили.
43. Евгений Маляров (unpete) 10.08.16 15:44
(42) dlebedev8,
Правильно они сделали, что соскочили
Правильно для кого? Для акционеров, которые получат меньше прибыли, для работников, которые остались без эффективных рабочих мест или для клиентов, которые будут дольше стоять в очереди?
44. Сергей Филькин (FSerg) 10.08.16 16:15
Больше года назад перед конференцией инфостарта - я смотрел ваш продукт.
Я не понимаю, почему так много скептических комментариев или придирок к цене.
Классный высоко-технологичный проект!
И есть множество задач, когда нужно дать пользователю простой интерфейс со связью с 1С и в идеале чтобы просто в браузере работало на чем угодно.
45. Евгений Маляров (unpete) 10.08.16 16:23
(44) FSerg,
в идеале чтобы просто в браузере работало на чем угодно
Завтра опубликую статью с пошаговой инструкцией helloworld с автономной работой в браузере.
Пишу этот ответ, чтобы подстегнуть работы по демо-примеру. Заставить себя работать трудно, но обещание придется исполнять
почему так много скептических комментариев
Мне это тоже интересно. И еще, хочется инженерной критики по существу. Например, "у тебя здесь утечки памяти" или "тут лишний цикл" или "это разыменование можно сделать проще и красивее"
46. Капитан Немо (capitan) 10.08.16 18:00
И есть множество задач, когда нужно дать пользователю простой интерфейс со связью с 1С и в идеале чтобы просто в браузере работало на чем угодно.

Где эти задачи ?
Вы отделяйте мух от котлет.
Есть веб программисты, они привыкли к своим языкам программирования и своей среде исполнения.
Есть программисты 1С у них свой язык программирования и своя среда исполнения.
Стыковка происходит элементарным обменом, формат стандартизован.
А вы почему то считаете, что сайты должен делать 1С ник ?
Это так же непросто, там есть свои тонкости, не говоря уже об элементарной безопасности.
Этот проект никто не ломает потому лишь, что на нем никто не работает.
Это если говорить о "простой интерфейс со связью с 1С"
А если говорить о проекте как об учетной системе, то уверяю вас их сотни и большая часть тоже имеет встроенный конфигуратор.
Откройте любой каталог ПО
И все они стыкуются или будут стыковаться с 1С. И многие из них хотели бы здесь рассказать какие они классные.
47. Капитан Немо (capitan) 10.08.16 18:07
(43) unpete,
Правильно для кого?

Для клиентов, деньги которых они хранят.
В курсе сколько access incident у сбера в день ?
У меня есть по Kiwi данные например.
И сколько их у вас, если такая статистика ведется.
48. Евгений Маляров (unpete) 10.08.16 18:27
(46) capitan,
уверяю вас их сотни
Приведите, пожалуйста одну ссылку на систему, где есть автономная работа в браузере и ссылочная типизация.
Я с удовольствием сверну работы по метадата и приму участие в развитии более грамотного движка.
49. Евгений Маляров (unpete) 10.08.16 18:40
(46) capitan,
Есть веб программисты, они привыкли к своим языкам программирования и своей среде исполнения
Вы сути моего предложения не услышали. У веб-программистов не получается сделать ни одного приличного сайта по двум причинам:
  • Они не понимают и не хотят понимать бизнес-процессов учета и управления
  • Они каждый раз изобретают велосипед на языке низкого уровня вместо того, чтобы воспользоваться такими бизнес-объектами, как документ и регистр
Вы исходите из предположения, что сложившиеся подходы к веб-разработке - удовлетворительны.
Что вебщики рисуют нормальные интернет-магазины и личные кабинеты.
Я утверждаю, что сегодняшние веб-решения изнутри - это Ад и Израиль.
Почитайте исходники хоть вордпресса, хоть битрикса, или, например, opencart.
Читать предлагаю недалеко от туалета - вас обязательно вырвет.
50. Сергей Филькин (FSerg) 10.08.16 21:45
(46) capitan,

Где эти задачи?

Их множество, то что сразу приходит на ум:
Вы оптовая компания и вам нужно дать своим партнерам доступ типа в личный кабинет (акт сверки, заказы) - будете делать это на 1С? Купите лицензий по числу партнеров?
Вам нужно дать кладовщику простой интерфейс для подтверждения факта отгрузки товара по накладной - будете ставить ему 1С? ему хватит простого web'чика с одним полем ввода и кнопкой.

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

В том то и дело, что с каждым днем эта грань стирается! Есть крутые 1C-инженеры, которые знают/изучают Python, JavaScript, Docker и вот это вот все и есть посредственные, которых не интересует ничего дальше границ 1С.

Стыковка происходит элементарным обменом, формат стандартизован.

Обмен и реалтайм работа - сильно разная работа.

А вы почему то считаете, что сайты должен делать 1С ник?

ИМХО, речь в публикации вообще не о сайтах. Речь о решении, которое предлагает классный способ дать удобные web-интерфейсы к 1C.

Это так же непросто, там есть свои тонкости, не говоря уже об элементарной безопасности.

Ок, если страшно, начните использовать это в интранете, т.е. там где вы полностью контролируете инфраструктуру и периметр.
51. Евгений Маляров (unpete) 11.08.16 08:57
(50) FSerg,
Купите лицензий по числу партнеров?

Стоимость лицензий, конечно, имеет значение, но позиционирование у меня другое:
  • Metadata жрёт в 20 раз меньше трафика. Это инженерный факт. Оспаривать его бессмысленно. Как следствие, работает при плохой связи и даже в автономном режиме
  • У нас намного проще и надежнее серверная инфраструктура. Для обслуживания 1000 клиентов, CouchDB использует меньше ОЗУ и процессорного времени
  • Metadata предоставляет веб-программисту высокоуровневые объекты данных, прямого аналога которым просто нет в других фреймворках
Напомню лозунг: "если ваша задача хорошо решается в стандартной 1С - не надо тратить время на метадату"
52. Евгений Маляров (unpete) 11.08.16 09:16
(46) capitan,
Где эти задачи ?
Таких задач, действительно, много.

Например, рабочее место контролера ОТК, где требуется регистрировать готовность изделия + наличие и характер дефектов. Обычные ТСД и сканер не годятся, т.к. дефекты надо привязать к элементу изделия. Решено использовать смартфон + bluetooth сканер. При сканировании этикетки, выводим на экран смартфона чертёж изделия с возможностью выделить любые элементы и указать в контекстном меню маршрут исправления.

Еще, есть цеховая безбумажка, где для отображения данных использованы бытовые телевизоры. Метадата прекрасно справляется с задачей, работая внутри встроенного в телевизор браузера.
Понятно, что этой реализации, предшествовали безуспешные попытки сделать то же самое в веб-клиенте 1С. Возможно, проблема в моей низкой квалификации, а может быть и в чем-то другом.
53. Denis Lebedev (dlebedev8) 11.08.16 10:10
(52) unpete, да много есть разных задач, глупо об этом спорить. Кому надо, сами свяжутся и договорятся. Остальные будут и дальше критиковать и искать недостатки.

Не могли бы вы пояснить по лицензированию AGPL? Что именно вы причисляете к проекту, исходники которого должны быть открыты? Например, если делать личный кабинет дилера к конфигурации 1С: Управление торговлей (10 или 11)?
54. Евгений Маляров (unpete) 11.08.16 10:38
(53) dlebedev8,
пояснить по лицензированию AGPL
Вот текст с сайта gnu.org на русском языке: https://www.gnu.org/licenses/why-affero-gpl.html
55. Евгений Маляров (unpete) 11.08.16 10:44
(53) dlebedev8,
Например, если делать личный кабинет дилера
IMHO, будет достаточно открыть код клиентского приложения + код design-документов CouchDB
56. Евгений Маляров (unpete) 11.08.16 13:35
(27) unpete,
Примеры драматически старые
Опубликовано новое описание Hello world на metadata.js
TreeDogNight; ardn; +2 Ответить
57. Евгений Маляров (unpete) 11.08.16 15:45
(53) dlebedev8,
личный кабинет дилера к конфигурации 1С
По заказам онлайн/оффлайн для типовых УТ, КА, УПП, ERP - можем поработать совместно.
У меня есть заготовка https://github.com/oknosoft/order-online и живой демо-пример https://light.oknosoft.ru/orders/
Личные кабинены - это самое типовое и самое понятное назначение метадаты.
Еще, напрашиваются проекты "Розница" и "Мобильное рабочее место торгового представителя". По ним, так же, готов предложить совместную работу.
58. Игорь Steelvan (Steelvan) 12.08.16 08:16
(49) unpete,

Это Ад и Америка.
Американцы хуже евреев.

Интересно, как сейчас возбудятся те, кто там ни разу не бывал, но кто верит в сказочки что там рай :)
И заплачут, что я наступаю на их сказочные фантазии ;)
sev@snail.ru; +1 1 Ответить 2
59. Евгений Маляров (unpete) 12.08.16 09:36
(58) Steelvan, Выражение Ад и Израиль возникло еще во времена Иисуса и означает "просто ад"
60. Евгений Маляров (unpete) 12.08.16 09:44
(58)(58) Steelvan, Мне кается, для обсуждения рассовых и политических вопросов есть специальные интернет-ресурсы. Зачем это на Инфостарте?
61. Геннадий Николаев (genayo) 12.08.16 10:32
(60) Не обращайте внимания, это местный дурачёк.
dour-dead; +1 Ответить
62. max zubrik (kodermax) 12.08.16 11:14
Идеи этого продукта мне очень понравились, сейчас идёт активное внедрение его в процесс заявок на закупку.
Технологии используемые в Metadata.js(NodeJs, CouchDB,...) это просто сказка, наконец-то современные технологии добрались до 1с)
Единственное, требуется активное сообщество для этого продукта, которое выстроит современную архитектуру, будет писать тесты, исправлять ошибки оперативно и добавлять красоту и новые функции.
TreeDogNight; unpete; +2 Ответить
63. Александр Ермолаев (user637563_alex) 10.11.16 14:13
Очень интересная работа! Желаю вам успехов!
Подскажите, для чего используется AlaSQL на стороне клиента? Ведь есть уже PouchDB..
64. Евгений Маляров (unpete) 10.11.16 14:53
(63) user637563_alex,
для чего используется AlaSQL
AlaSQL выполняет две функции:
  • Хранение структурированных данных в озу браузера (быстрый синхронный кеш)
  • SQL интерфейс к этим данным
PouchDB отвечает за:
  • Хранение данных в indexeddb
  • Синхронизацию этих данных с CouchDB
65. Игорь Полосков (ipoloskov) 10.11.16 15:06
Для написания сообщения необходимо авторизоваться
Прикрепить файл
Дополнительные параметры ответа