1c + kafka.apache

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

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

архитектура python kafka микросервисы backend TCP HTTP

Пример построения микросервисов с использованием apache kafka. Данная статья будет полезна интеграторам, программистам. Версия и релиз технологической платформы не имеет значения.

Пример построения микросервисов с использованием apache kafka.

Задача:

Построить событийную архитектуру между приложениями(микросервисы)(не только 1с).

Общая логика решения задачи():

1. Приложение А генерирует событие                                                         

2. Другое приложение Б(В, Г..) "слушает"  кафка (подписывается на событие)(если коротко)

3. Приложение А отправляет данные кафка (Поставщик)

4. кафка отправляет данные всем кто подписан на это событие (Потребитель)

5. Приложение Б(В, Г..)  получает данные

Технологии:

1. 1с (поставщик,  потребитель, tcp клиент)

2.  Разнородный бэкенд (python,  и тд) (поставщик,  потребитель)

3. с++ 1с вк native (транспорт для tcp клиента 1с)

4. apache kafka (шина данных) https://kafka.apache.org

5. flask (python micro web сервер) http://flask.pocoo.org

6. tcp сервер (python)

7. KafkaConsumer, KafkaProducer  (python) https://github.com/dpkp/kafka-python

Общая принцип работы(модули):

1с(1):

При запуске 1с стартует tcp клиент (вк native)(3) .Устанавливает соединение с tcp сервером(6) (передавая ид пользователя из 1с). Подписывается на событие вк native. При наступления события уходит в контекст 1с через ОбработкаВнешнегоСобытия для последующей обработки. Для генерации событий выполняет гет, пост запросы на  веб сервер(5).

tcp сервер(6):

Хеш таблица открытых сокетов(активных соединений) и ид пользователя. Подписывается на события шины данных для отправки клиенту 1с. При наступлении событий отправляет данные в сокет(клиенту 1с). Генерирует события при авторизации(установка сокета), выхода(разрыв, закрытие сокета) в шину данных.

web сервер(5):

Обрабатывает запросы со стороны 1с(прокси для кафка) и отправляет в шину данных. Также подписывается на события сторонних приложений требующих отправку данных для 1с(изменился статус звонка asterisk, прилетел тригер для обновления формы, перегнать что то с &НаСервере на &НаКлиенте , и тд).

Шина данных(4):

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

Разнородный бэкенд(2):

Подписывается, генерирует события в шину данных.(например web app time line(журнал записи), asterisk ami client(автообзвон, фонер), из предыдущих статей)

Шаг 1. tcp сервер 

 
 tcp сервер

установка сокета(прослушка):
while True:

    try:
        buf = request.recv(256).decode('utf-8')
    except:
        break

отправка в сокет:

sock.sendall(message.value)

генерация события для шины данных: 

producer.send(f'user_auth', key=key, value=value) 

подписка,обработка события:

consumer = KafkaConsumer('ones_socket_send_user', 'ones_socket_send_user_send_all', 'ones_socket_add_listener', 
                                 group_id='my-group', bootstrap_servers=['192.168.777.555:9092']) 
for message in consumer:
    if message.topic=="ones_socket_send_user":

Шаг 2. web сервер

 
 start
 
 route
 
 app

регистрация енд поинт(точка входа, путь и тд):

@app.route('/api_user_event',  methods=['GET', 'POST'])
def api_user_event(): ...

Шаг 3. Пример генерации из стороннего приложения

 
 time line triger update
 
 asterisk ami event triger
def event_listener(event, **kwargs):
    if event.name in EVENTS_NOT_LISTEN:
        return
    
    #print(f"""{str(event)}""")
    
    if event.name == 'Newstate' or event.name == 'Hangup' or event.name == 'VarSet':
        if event.name == 'VarSet':
            if not event.keys['Variable'] in EVENTS_VARS_LISTEN:
                return

        for x in USER_EVENTS:
            if USER_EVENTS[x]['channel'] in event.keys['Channel']:
                d = {}
                
                d['Действия'] = 'Asterisk_Event' 
                d['Данные'] = event.keys 
                d['Данные']['name'] = event.name 
                d['Данные']['id_ext'] = USER_EVENTS[x]['id_ext'] 
                d['Данные']['event_date'] = datetime.now()
                
                jdata = json.dumps(d, default=json_serial)
                
                do_user_event(jdata, USER_EVENTS[x]['user'])

                print(f"""{str(event)}""")

Прослушка ами:

client = AMIClient(address=AMI_ADDRESS, port=AMI_PORT)
future = client.login(username=AMI_USER, secret=AMI_SECRET)

client.add_event_listener(event_listener)

 

Шаг 4. 1с

 
пример кода для работы

Шаг 5. вк native

Полное создание вк native в статье не рассматривается.

 
(часть tcp клиента)

Шаг 6. 1c web services

Используется для передачи сообщения из бизнес приложения для отправки в 1с (серверная часть)(для дальнейшей обработка бизнес логики в контексте 1с) (создание документа, старт бизнес процесса, заполнение справочника) (конечно можно сделать сделать прямой вызов без использования сообщений, здесь идея в том что на один ответ 1c ws может быть в дальнейшем подписано несколько подписчиков, тем самым все получат сообщение и будут выполнят свою логику далее)      

 
1с ws consumer

Подключение к ws:

client = Client(ws, username = username, password = password, cache = NoCache(), timeout = 60)

Вызов метода в контексте 1с(метод ws сервиса):

eval_str = 'client.service.%s(%s)' % (method, jdata and "%r" % jdata or '')
    
    try:
        res = eval(eval_str)
    except Exception as e:
        print(e)
        return

Конструкция вида: upd_event_lists.append([]), и затем  _thread.start_new_thread(upd_loop, (i,)), сделано для того чтобы не завалить ws 1c. Те может случится так что прилетит много запросов и если делать send сразу происходит отказ в установке соединения (Удаленный компьютер отверг запрос на подключение, еррор вин сок и тд.)(проверено примерно на 1000 сообщения поданных вход модулю который выполнял _thread.start_new_thread(send, (username, password, jdata, method, ws,)) для каждого принятого сообщения, сгенерировав их в кафку предварительно с другого модуля, произошел отказ(пользователей было 400 на момент приема сообщений) ну и 1с чета затупила сразу, в плане установки новых соединений с рпхостом(рагент сдох короче)).

 
 1с http consumer

 

import json
from kafka import KafkaProducer, KafkaConsumer
#import _thread
import time
import requests
from requests.auth import HTTPBasicAuth


headers = {'Content-type': 'application/json'}
           #'Accept': 'text/plain'}


ONES_USER = ''
ONES_PASSWORD = ''
ONES_HOST = '192.168.555.560'
ONES_HTTP = 'http://192.168.555.560/AA'

consumer = KafkaConsumer('ones_http_event', group_id='my-group', bootstrap_servers=['192.168.5.131:9092'])

producer = KafkaProducer(bootstrap_servers=['192.168.5.131:9092'])

for message in consumer:
    print(f"""ones_http_event->{message}""")

    method = message.key.decode('utf-8')
    
    data = message.value.decode('utf-8')

    jdata = data
    
    username = ONES_USER
    password = ONES_PASSWORD

    data = json.loads(data)

    id_request = None

    if not data.get('id_request') is None:
        id_request = data.get('id_request')
    
    if not data.get('event_setting') is None:
        event_setting = data.get('event_setting')
        
        username = event_setting.get('username')
        password = event_setting.get('password')

        jdata = event_setting.get('jdata')
        
        if not jdata.get('id_request') is None:
            id_request = jdata.get('id_request')

    auth_ones = HTTPBasicAuth(username, password)
    
    r = None

    try:
        r = requests.get(f"""{ONES_HTTP}/hs/gate/v1?method={method}&data={jdata}""", headers=headers, auth=auth_ones)
            #data=res_str, 
    except Exception as e:
        print(e)
    
    res = ''
    
    if not r is None:
        if r.status_code != 200:
            res = r.reason
            print(r.reason)
        else:
            res = r.text

    if not id_request is None:
        key = id_request.encode('utf-8')
        value = res.encode('utf-8')
        
        producer.send('ones_http_event_response', key=key, value=value)

 

в 1с это http сервис. Это работает быстрее ws, потому что ws это soap over http. Чтобы понять нужно cмотреть в структуру вызовов клиент-сервер SOAP.(получение wsdl, вызов метода soap и тд). http сервис - это голый http - get/post/put/head

Примеры работы:

1c посылает гет во внешнее приложение->внешнее приложение получает событие, обрабытвает генерирует событие на обновление клиента 1с отправляет в кафка->кафка марштузирует tcp серверу->tcp сервер отпраляет в сокет всем клиентам которые зарегистрированы по данному ид->1с обрабатывает внешние событие.

1c посылает гет, пост на веб сервер->веб сервер отправляет в кафка->кафка марштузирует tcp серверу->tcp сервер отпраляет в сокет всем клиентам которые зарегистрированы по данному ид->1с обрабатывает внешние событие.

Пример отправки и получения 500 запросов + в процессе отправки генерация из внешних приложений.

Пример подключения/отключения в процессе отправки.

 

 

Деплой и идеология apache kafka в статье не рассматривается(написано тысячи статей).

Для мониторинга apache kafka используется https://github.com/yahoo/kafka-manager.

 

Метрика:

upd для тех кто мало что понял мануал для dot net от ms, смотреть в общие принципы и идеи

 

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

Наименование Файл Версия Размер
вк native

. 135,50Kb
28.01.19
20
. 135,50Kb 20 Скачать

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

Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. TreeDogNight 18 28.01.19 09:29 Сейчас в теме
С помощью какой программы снимали GIF ?
vrednyi_glavred; UniversaLL; +2 Ответить
6. KroVladS 33 28.01.19 15:10 Сейчас в теме
(1)
С помощью какой программы снимали GIF ?

Судя по ватермаркам автор пользовался Icecream Screen Recorder
мне больше нравится LICEcap
TreeDogNight; dour-dead; +2 Ответить
11. dmarenin 286 28.01.19 16:32 Сейчас в теме
(1) Icecream Screen Recorder дальше в гугле convert web m to gif
TreeDogNight; +1 Ответить
2. s_vidyakin 28.01.19 10:38 Сейчас в теме
ну хоть внешнюю компоненту-то выложите ((
TreeDogNight; KroVladS; AntonSm; UniversaLL; rintik; +5 Ответить
31. dmarenin 286 28.01.19 17:05 Сейчас в теме
(2) добавил
TreeDogNight; rintik; KroVladS; +3 Ответить
3. KroVladS 33 28.01.19 12:17 Сейчас в теме
Статья для того чтобы похвастаться?
Примеры чтобы самим потестить где?
12. dmarenin 286 28.01.19 16:32 Сейчас в теме
4. s_vidyakin 28.01.19 12:24 Сейчас в теме
Чтобы скомпилить одну ДЛЛ-ку надо поставить 2 гигабайтную студию. ОК.
Запускаю билд примера с ИТС - 211 ошибок при сборке. WTF??
19. dmarenin 286 28.01.19 16:43 Сейчас в теме
(4) ну дак вин сдк нужно для версии длл, иначе как?
20. s_vidyakin 28.01.19 16:47 Сейчас в теме
(19) Классно, как раз хотел закачать еще 3 ГБ библиотек и почпокаться с С++ первый раз в жизни
21. dmarenin 286 28.01.19 16:49 Сейчас в теме
(20) больше 3х если для крос
67. starik-2005 2195 25.03.19 18:20 Сейчас в теме
(4) бедняги подвиндозные )))
5. s_vidyakin 28.01.19 14:00 Сейчас в теме
kafka-manager как поставить? там в описании указано что надо ставить Play Framework и компилить бинарник через sbt. Так?
13. dmarenin 286 28.01.19 16:33 Сейчас в теме
(5) нет есть путь короче имя ему докер хаб
22. s_vidyakin 28.01.19 16:52 Сейчас в теме
(13) 6 тысяч результатов по "kafka", в первых нескольких нет инфы, что в них есть zkeeper, kafka-manager. Опять нет конкретики
30. s_vidyakin 28.01.19 17:04 Сейчас в теме
(23) Было бы круто сделать свой докер со всеми упомянутыми средствами - zkeeper, kafka, kafka-man, flask, и одной командой разворачивать всю схему
32. dmarenin 286 28.01.19 17:08 Сейчас в теме
(30) zkeeper, kafka, kafka-man, flask, .... windows, 1c, excel, word, doom...

а если по делу суть контейнеров как раз так и заключается в разделении приложения

те.

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

это мое мнение, и вот так вот мы делаем.
flask вообще пакет питона, ставится одной строкой в докер бизнес приложения(если в имидже его не было).
starik-2005; +1 Ответить
7. minimajack 64 28.01.19 15:30 Сейчас в теме
Какова производительность отправки?
18. dmarenin 286 28.01.19 16:40 Сейчас в теме
(7) в сравнении с чем? на гифках видно думаю при отправке 500 постов. с учетом того что штатными средствами (без использования бд) межсеансовая клиентская передача не возможна, считаю ваш вопрос не корректным. но суть не сколько во межсеансовой передаче, сколько во внешнем воздействии (события)
24. minimajack 64 28.01.19 16:54 Сейчас в теме
(18) сколько пакетов в секунду размером в 1 байт отправляется
25. dmarenin 286 28.01.19 16:56 Сейчас в теме
(24) сколько пакетов отправляется откуда?
26. minimajack 64 28.01.19 16:56 Сейчас в теме
33. dmarenin 286 28.01.19 17:19 Сейчас в теме
(26) добавил гифку по скорости передачи, там где с браузера передача идет (последняя гифка). это под рабочей нагрузкой.
34. minimajack 64 28.01.19 18:25 Сейчас в теме
(33) господи....цифру напишите - потолок.
Например отправляется 200 сообщений в секунду. Пиковая нагрузка полторы тыщи.
37. dmarenin 286 28.01.19 18:40 Сейчас в теме
28. dmarenin 286 28.01.19 16:59 Сейчас в теме
(24) там все над сишные, крестовые поделки(питон(консумер, продакшен кафка), 1с аддин), отсюда скорость.(ну да ртос далеко, ну так реалтайм до 1с, дальше конечно просадка). более 100 сокетов.сразу. к чему такой вопрос?
35. minimajack 64 28.01.19 18:27 Сейчас в теме
(28) как можно по гифке можно оценить скорость? Вот 100 сокетов - это уже полезно...значит на 100 пользователях возможно не упадет =)
Хочу оценить порядок скорости со своим велосипедом.
36. dmarenin 286 28.01.19 18:38 Сейчас в теме
(35) должно упасть? если и упадет кафка доставит чуть позже. см идеологию
38. minimajack 64 28.01.19 18:40 Сейчас в теме
(36) хорошо...
У меня стоит двадцать датчиков которые генерируют 100 событий в секунду. Смогу ли я отправлять в кафку 2000 сообщений из клиента 1С? А если да - сколько я могу поставить еще датчиков что бы уперется в предел отправки?
40. dmarenin 286 28.01.19 18:49 Сейчас в теме
(38) не упрется в том то и дело! что упорядоченная очередь. те как там в 1с прийдет дело 3 тье, главное их в стэк очередь. и если честно генерацию датчиков 2000 в сек наверно лучше не делать из 1с. в моем примере отправка 500 постов в первом случае, 5000 в другом на скринах, не упало.
starik-2005; +1 Ответить
39. dmarenin 286 28.01.19 18:41 Сейчас в теме
(36) по гифке? визуально явно там не байты ходят. вам метрика нужна? я могу замерить, потом окажется у вас железо не то, деплой не тот, нагрузка не та., и тд...
43. minimajack 64 28.01.19 18:58 Сейчас в теме
(39)
явно там не байты ходят. вам метрика нужна? я могу замерить, потом окажется у вас железо не то, деплой не тот, нагрузка не та

да какая разница какое железо...там в 100% упрется в 1С. По гифке 1 сообщение в секунду =)
46. dmarenin 286 28.01.19 19:03 Сейчас в теме
(43) да упрется в 1с так как карусельная виртуальная машина(выполнение потоков по карусели)
47. dmarenin 286 28.01.19 19:05 Сейчас в теме
(46) почему и высокую нагрузку в обход 1с и предлагал делать, а там куда запишет и как не столь важно. наверно имеет смысл после кафки писать в дб сразу. тогда показания будут корректными. на 1с только отображать
starik-2005; +1 Ответить
48. minimajack 64 28.01.19 19:10 Сейчас в теме
Вы нагрузочное тестирование вообще проводили?
51. dmarenin 286 28.01.19 19:18 Сейчас в теме
(48) отправки 20000 в сек сообщений с 2000 клиентов из 1с. конечно нет. а смысл ? в статье нет речи о посторении скады. тесты были для бизнес приложений и взаимодействия 1с. написано выше было более 100 открытых сокетов и пример передачи. какой вопрос? вы что хотите цифры? дак разверните у себя сделайте замер...
52. minimajack 64 28.01.19 19:41 Сейчас в теме
(51) а смысл кафки в вашем контексте? 100 открытых сокетов держит древний селерон с гигом оперативы...а 1 сообщение в секунду можно и в sqllite писать и читать...
Нагнать хайпа ? ))
53. dmarenin 286 28.01.19 19:46 Сейчас в теме
(52) смысл во внешнем воздействии сторонних приложений и обработкой в 1с. обработка ивента например на обновление формы, реакция на смену статуса звонка, реакция межсеансового события 1с клиента. sqllite писать и читать это возможно ваш подход, не мой. прочитайте статью от начала. просьба.
56. minimajack 64 28.01.19 20:06 Сейчас в теме
Насколько я вижу взаимодействие происходит с вебсервером(TCP-сервером)...что и где там дальше по цепочке впринцепе не важно...меняем кафку на реббит или базу данных - и ничего для 1С не меняется.
Вот в чем вопрос...почему кафка?? а ответа нет.
Так варианты:
1С + webserver + кафка
1C + регистр сведений + чтение периодическое
1С + native api + rabbit mq
57. dmarenin 286 28.01.19 20:08 Сейчас в теме
(56) ну давайте не будем про 1C + регистр сведений + чтение периодическое

1С + native api + rabbit mq

что за native сможет в туда и сюда(клиент и сервер)?
58. dmarenin 286 28.01.19 20:10 Сейчас в теме
(57) есть сорсы(крестовые) для натс под 1с(натив вк) стоит ли мерятся? не вижу смысла.
61. minimajack 64 28.01.19 20:31 Сейчас в теме
(58) а толку? Снова же: конфигурация не та...деплой говно, метрику не дам, нагрузочного тестирования не делал =))))
Soloist; DimaP; +2 Ответить
65. dmarenin 286 29.01.19 09:28 Сейчас в теме
(61) "конфигурация не та...деплой говно" - возможно, это будут ваши первые слова когда наши метрики не совпадут и у вас будет ниже, "метрику не дам" - дам,
"нагрузочного тестирования не делал" - вероятно делал
60. minimajack 64 28.01.19 20:28 Сейчас в теме
(57)
Вместо метрики - gif.
Вместо внятного объяснения выбора кафки - хрень с натсом.

Нормально бы написали:
Пользовался тем то - устраивало
Пользовался тем то - стало лучше
Пользовался тем-то - еще лучше и стабильней
Внедрил кафку - ваще огонь...

p.s. Yellow RabbitMQ - вроде может и отправлять и принимать, и на сервере и на клиенте. Если что я не от них =)
62. dmarenin 286 29.01.19 08:57 Сейчас в теме
(60) метрика:
Прикрепленные файлы:
63. dmarenin 286 29.01.19 09:15 Сейчас в теме
(60) еще метрика
Прикрепленные файлы:
64. dmarenin 286 29.01.19 09:26 Сейчас в теме
(60) еще метрика:

Хватит метрик? или еще добавить?
Прикрепленные файлы:
66. minimajack 64 29.01.19 11:25 Сейчас в теме
59. dmarenin 286 28.01.19 20:13 Сейчас в теме
(56) "Насколько я вижу взаимодействие происходит с вебсервером(TCP-сервером) " ну да дальше то сокет уже открыт, считай лонг пол для сторонних приложений. бля, до сих пор не понимаю. в чем вопрос то??
8. s_vidyakin 28.01.19 15:34 Сейчас в теме
фух, поставил зукипер, кафку, кафкоманагер. Осталось компоненту внешнюю получить!
9. minimajack 64 28.01.19 15:37 Сейчас в теме
(8) не забудьте про питон и скрипты запуска вебсервера
15. dmarenin 286 28.01.19 16:34 Сейчас в теме
16. dmarenin 286 28.01.19 16:35 Сейчас в теме
(8) дак там ничего в ней нет. сишный tcp клиент под интерфейсом addin 1c. ну если сильно нужно то конечно могу приложить
17. dmarenin 286 28.01.19 16:37 Сейчас в теме
(16) код tcp клиента есть в статье. вообще на этом форуме возможно их есть с десяток.
10. comol 4350 28.01.19 15:57 Сейчас в теме
Так я не понял со стороны 1С сообщения получаются на tcp сервер? т.е. на стороне 1С должна быть поднята ВК с tcp сервером, так?
14. dmarenin 286 28.01.19 16:33 Сейчас в теме
(10) нет. не сервер, tcp клиент. в статье написано.
27. comol 4350 28.01.19 16:57 Сейчас в теме
(14)
Меня смутили:
1с обрабатывает внешние событие
внешнее событие генерит компонента?

tcp сервер отпраляет в сокет всем клиентам
клиенты же отправляют...
29. dmarenin 286 28.01.19 17:01 Сейчас в теме
(27) генерит компонента? да. клиенты же отправляют не всегда, в чем суть то и есть. поставщиком может быть как 1с так и не 1с. и клиенты чего?? в статье же разделение логики вроде как описывалось. есть часть которая отвечает только за отправку в сокеты для 1с, есть часть которая генерирует эти события, есть часть которая генерирует события которые нужно в сокет отправить. объяснил?
41. s_vidyakin 28.01.19 18:55 Сейчас в теме
а потянет кафка перекидывания 1..2-х мегабайтными XML-ями?
44. dmarenin 286 28.01.19 19:00 Сейчас в теме
(41) потянет 100% (тут вопрос не кафке уже а в железе и оси), но лучше не так. создать файл, сделать ивент, получить ивент типа прочитай. (типа выставил указатель), получил ответ снял с регистрации, и тд. это как бы и есть событийная логика. а не гонять данные. на крайняк кафка может в стримы.
42. s_vidyakin 28.01.19 18:56 Сейчас в теме
Еще вопрос, как можно в реальном времени смотреть за нагрузкой/очередями в кафке?
45. dmarenin 286 28.01.19 19:02 Сейчас в теме
(42) да на скринах есть(нет передачи потому что нужно включить логи). прям реал тайм график построить кафка манеджер не сможет, можно самому запилить там делов... еще вопросы?
49. s_vidyakin 28.01.19 19:11 Сейчас в теме
(45) Как все это запускается? У вас все сервисы в докере? Вроде можно композером объединить все в одну кучу?
И кстати tcp-сервер на питоне надо в виде сервиса завернуть? или как запускать чтоб постоянно работал?
50. dmarenin 286 28.01.19 19:14 Сейчас в теме
(49) в скрипте работает постоянно. ибо main. в статье разные приложения. даже расписано что за чо отвечает. ключевое слово "шаг"

ответ на вопрос " кстати tcp-сервер на питоне надо в виде сервиса завернуть?" screen
54. s_vidyakin 28.01.19 19:56 Сейчас в теме
(50) то что постоянно работает я понял, я имею в виду как сделать автостарт и фоновую работу всех служб. В винде можно специальной софтиной из любой программы сделать обычную службу. У вас все эти сервисы на линуксе как демоны или както по другому?
55. dmarenin 286 28.01.19 20:02 Сейчас в теме
(54) "У вас все эти сервисы" (он один контейнер из статьи) "на линуксе" -да, "как демоны" - нет. в винде батник нормально сработает. в дебе в полне себе баш сработает вида:

screen -dmUS queue выпелено
screen -dmUS server python3.6 /OnesSocketServer/OnesSocketServer/ones_socket_server.py
screen -dmUS proxy python3.6 /OnesSocketServer/ProxyOnesSocketServer/runserver.py
screen -dmUS consumer python3.6 /OnesSocketServer/ProxyOnesSocketServer/ones_socket_consumer­.py - это часть из статьи вынесенная отдельно для генерации событий отправки в сокет, можно так не делать, можно делать...
68. pm74 177 16.01.20 15:16 Сейчас в теме
(0) flask запускается на отладочном сервере ?
69. electrolis 11 06.04.20 08:36 Сейчас в теме
Ничего не понятно. Но очень интересно. :-)
Оставьте свое сообщение

См. также

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

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

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

1 стартмани

25.03.2019    34132    tormozit    44    

Загрузка, скачивание, удаление файлов с помощью НачатьПомещениеФайлаНаСервер() и НачатьПолучениеФайлаССервера()

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

В платформе 8.3.15 появились новые методы НачатьПомещениеФайлаНаСервер() и НачатьПолучениеФайлаССервера(). В данной статье рассмотрено готовое решение проверенное и прекрасно работающее на тонком и веб-клиенте.

1 стартмани

25.07.2020    2243    Flashill    10    

Параллельные вычисления расчета факториала числа N

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

Распараллеливание алгоритма с помощью фоновых заданий (асинхронные вычисления)

1 стартмани

29.06.2020    2408    Rustig    17    

Универсальная печатная форма Приказа/Договора с возможностью настройки макета в пользовательском режиме

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

В данной статье я опишу реализацию универсальной (в кавычках) печати Приказа (Договора или чего пожелаете) с возможностью настройки выводимого текста с параметрами из пользовательского режима

1 стартмани

24.06.2020    1214    BuriyLesha    0    

1С + asterisk (автоматический обзвон) часть 2. Распознавание речи Промо

Телефония, SIP Россия Бесплатно (free)

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

18.03.2019    8184    dmarenin    4    

Методика обновления формы объекта данных при изменении объекта

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

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

1 стартмани

09.03.2020    7386    tormozit    13    

Отправка уведомлений с помощью командной строки, Оповещения с сервера на клиент с помощью командной строки

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

Отправка уведомлений с помощью команды командной строки msg. Оповестить пользователей из серверного модуля или регламентного задания, с помощью командной строки msg.

1 стартмани

05.03.2020    5398    user5300    3    

Вывод сообщений в HTML поле средствами 1С

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

Пример использования вывода большого количества сообщений в поле HTML. С возможностью открывать ссылочные объекты и создавать новые объекты передавая параметры прямо из HTML поля. Протестировано на релизах 8.3.12 и 8.3.15+

2 стартмани

31.01.2020    5533    burni4    16    

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

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

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

2 стартмани

08.05.2018    26909    wowik    3    

Краткое руководство по внесению изменений в конфигурацию

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

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

1 стартмани

13.01.2020    16569    sapervodichka    41    

Универсальные функции: разложение произвольной строки адреса в структуру

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

Процедуры и функции раскладывают произвольную строку адрес в структуру по ключевым словам.

1 стартмани

30.12.2019    3482    vik070777    10    

"Живые" картинки со Snap.SVG

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

В статье рассмотрен пример использования http-сервисов для визуализации данных

1 стартмани

24.10.2019    13274    blackhole321    7    

Как нарисовать граф на 1С Промо

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

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

1 стартмани

09.08.2013    70151    ildarovich    117    

RLS - дубли условий в запросах к СУБД

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

"Подводные камни", возникающие при бездумном копировании ролей с ограничениями RLS, как это отражается на производительности, разбор примера и инструмент для анализа.

1 стартмани

07.10.2019    8286    geron4    4    

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

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

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

1 стартмани

07.10.2019    29147    HostHost    40    

Полное копирование одной формы в другую

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

Однажды я столкнулся с необходимостью открыть форму ЛЮБОГО документа с определенными изменениями, не зависящими от структуры объекта (например, заблокировать все кнопки). В интернете решения я не нашел. Обычно на форумах на запросы подобного рода отвечают чем-то вроде "покажи первоначальную задачу, а не спрашивай как реализовать то, что ты придумал". Тем не менее, мне стало интересно, как это можно сделать.

1 стартмани

03.10.2019    4764    nekit_rdx    23    

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

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

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

1 стартмани

28.09.2016    39287    ildarovich    22    

Многопоточная обработка данных на примере перепроведения документов

Обработка документов Практика программирования v8 ERP2 УТ11 КА2 Абонемент ($m)

Дальнейшее развитие темы фоновой обработки данных - проведение документов в потоках. Настройка параметров и запуск основного процесса (менеджера потоков). Разбивка документов для проведения на не связанные друг с другом наборы и запуск дополнительных фоновых заданий для отдельных потоков. Отслеживание выполнения каждого потока в родительском сеансе.

1 стартмани

17.09.2019    8888    ids79    46    

Отображение истории выполнения по всем задачам комплексного процесса в документообороте

Документооборот и делопроизводство Практика программирования v8 ДО Абонемент ($m)

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

1 стартмани

15.09.2019    6642    pavelpribytkin96    8    

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

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

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

1 стартмани

06.09.2019    19042    Dementor    30    

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

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

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

1 стартмани

01.02.2018    34833    rpgshnik    49    

Удобный просмотр результата запроса с большим количеством временных таблиц

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

Если Вам часто приходится просматривать в отладчике сложные пакетные запросы с большим количеством временных таблиц, то эта статья для Вас.

1 стартмани

27.08.2019    10712    ids79    21    

Запуск фонового задания во внешней обработке. Отключение предупреждений защиты от опасных действий в фоновом задании

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

Как запустить фоновое задание из модуля внешней обработки используя БСП. Как отключить безопасный режим и сообщения защиты от опасных действий независимо от профиля безопасности пользователя в фоновом задании во внешней обработке.

2 стартмани

24.08.2019    10252    BenGunn    22    

Изменяющееся контекстное меню в 1С 8.3

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

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

1 стартмани

06.08.2019    15191    signum2009    16    

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

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

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

1 стартмани

10.05.2018    44077    dsdred    36    

Процедура ПриКомпоновкеРезультата

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

Коллекция кода

1 стартмани

26.07.2019    36750    vasilev2015    64    

10 способов получить модуль числа (а может, и больше)

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

Пишем функцию вычисления модуля числа. Сколько способов существует? Давайте посчитаем!

1 стартмани

11.07.2019    7764    sam441    29    

Ловец дедлоков СУБД

Производительность и оптимизация (HighLoad) Практика программирования Разработка v8 Россия Абонемент ($m)

Анализ простейшего дедлока СУБД в рабочей базе с использованием ЦУП (центра управления производительностью) и profiler MS SQL (Microsoft SQL Server). Эта статья будет полезна людям, изучающим вопросы оптимизации работы 1С, или тем, у кого возникают дедлоки в рабочей базе. UPD 09.07.2019 добавлено воспроизведение блокировки в случае установки управляемой блокировки перед чтением набора записей регистра сведений. UPD 10.07.2019 добавлена тестовая база с примером.

1 стартмани

08.07.2019    10908    azazana    79    

Некоторая работа с данными через COM Промо

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

В статье приведены примеры работы с Платформой 8.X через COM (точнее, через объект COMConnector). Примеры кода были использованы при реализации прикладных задач в процессе трудовой деятельности.

2 стартмани

05.12.2012    57224    wowik    32    

Мониторинг производительности и искусственный интеллект

Производительность и оптимизация (HighLoad) Практика программирования Разработка v8 Абонемент ($m)

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

1 стартмани

01.07.2019    9094    ivanov660    28    

"Убер на складе": динамический расчет маршрутов с учетом реальных расстояний

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

Представляю методику и инструмент для динамического расчета маршрутов отбора на высоконагруженных складах для максимального повышения эффективности склада, ускорения проходимости и, как следствие, экономии денег. Это методика и обработка для интеграции в WMS решения. Тестировалось на 1С 8.3.14.1565.

3 стартмани

24.06.2019    15100    informa1555    17    

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

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

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

1 стартмани

21.06.2019    28210    Evil Beaver    126    

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

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

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

1 стартмани

24.04.2018    43343    kalyaka    35    

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

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

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

1 стартмани

12.06.2019    29133    Hatson    23    

Графики работы из БСП

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

Не очень давно на канале 1С:БСП была опубликована заметка по использованию Графиков работы и Календарных графиков.

1 стартмани

23.05.2019    3136    fenixnow    0    

Создание внешней печатной формы в формате документа Word

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

В статье написано, как создать внешнюю печатную форму (для конфигураций с БСП) в формате Word.

1 стартмани

17.05.2019    12723    ВикторП    20    

Многопоточность. Универсальный «Менеджер потоков» (фреймворк) с отслеживанием зависимости объектов Промо

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

Восстановление партий, расчет зарплаты, пакетное формирование документов или отчетов - теперь все это стало доступнее. * Есть желание повысить скорость работы медленных алгоритмов! Но... * Нет времени думать о реализации многопоточности? * о запуске и остановке потоков? * о поддержании потоков в рабочем состоянии? * о передаче данных в потоки и как получить ответ из потока? * об организации последовательности? Тогда ЭТО - то что надо!!!

26.05.2017    48801    DarkAn    86    

Пример настройки шаблонов и реализации печати отчетов в документ MS Word используя функциональную часть "Библиотеки Стандартных Подсистем 1С" (БСП)

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

В конфигурации выбраны и использованы только необходимые объекты библиотеки стандартных подсистем для реализации вывода отчёта, с табличными частями, в документ MS Word. Показан пример создания необходимых областей в шаблоне для вывода параметров в отчёт.

1 стартмани

23.04.2019    6007    olegpkc    11    

Ops средствами 1С:Предприятие

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

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

1 стартмани

23.04.2019    17234    blackhole321    28    

1C + Python + Django Rest Framework + Vue.js. Опыт несложной full-stack разработки

Практика программирования Внешние источники данных Обмен через XML WEB Разработка v8 1cv8.cf Абонемент ($m)

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

1 стартмани

22.04.2019    32335    riposte    65    

Новый запрос и новая таблица значений как функции Промо

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

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

1 стартмани

27.11.2012    45071    ildarovich    46    

Вывод вариантов СКД в таблицы на управляемой форме

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

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

05.04.2019    10878    artkor    1    

Функциональное программирование в 1С

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

Статья о функциональном программировании в 1С. Добавляем новые возможности. Пример передачи функций в качестве аргумента.

1 стартмани

28.03.2019    8275    alexey.kutya    26    

[EnterpriseData] Антисвертка характеристик номенклатуры при выгрузке в Бухгалтерию

Практика программирования Перенос данных из 1C8 в 1C8 Разработка v8 v8::ПВХ КД УНФ БП3.0 Россия БУ Абонемент ($m)

Рассмотрена выгрузка каждой пары значений Номенклатура - Характерстика из УНФ 1.6 в отдельную номенклатуру в Бухгалтерию 3.0 путём доработки правил обмена в формате EnterpriseData.

1 стартмани

27.03.2019    4504    nforce    5    

Уровни, глубина, прародители, циклы и аналоги запросом Промо

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

В продолжение публикации «Транзитивное замыкание запросом» [http://infostart.ru/public/158512/] добавлены другие варианты использования того же приема. Приведены запросы для быстрого определения уровней всех элементов справочника, максимальной глубины справочника, прародителей произвольных элементов справочника, запрос для быстрого определения циклов (на примере справочника спецификаций «1С:Управление производственным предприятием») и определения множеств аналогов номенклатуры (также на примере конфигурации «1С:Управление производственным предприятием»).

1 стартмани

13.11.2012    111284    ildarovich    98    

Интеграция 1С и SharePoint

Практика программирования Разработка v8 УНФ ДО ERP2 БП3.0 УТ11 УХ КА2 Россия Абонемент ($m)

Заказчики поставили задачу автоматизации согласования заявок на оплату в программе 1С:Бухгалтерия предприятия 3.0. Согласно ТЗ, данные должны подтягиваться из действующей электронной системы документаоборота на MS SharePoint (в дальнейшем СЭД MS SP).

1 стартмани

22.03.2019    5292    -I-    4    

Легкий "тюнинг" УТ 10.3

Практика программирования Разработка v8 v8::ОУ УТ10 Россия УУ Абонемент ($m)

Вариант программной реализации изменения форм типовых объектов для конфигурации Управление торговлей 10.3.

1 стартмани

15.03.2019    4318    pm74    6    

Пример использования СКД и данных расшифровки на мобильной платформе

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

СКД в мобильном приложении и меню действий на основе данных расшифровки (отчет, совместимый с мобильной платформой 8.3.13.45).

1 стартмани

12.03.2019    5454    majoram    0    

Неоплаченные долги при распределении оплаты по правилу ФИФО одним запросом и намного быстрее, чем Вы думали Промо

Практика программирования Дебиторская и кредиторская задолженность Дебиторская и кредиторская задолженность v8 v8::СКД КА1 УТ10 УПП1 УУ Абонемент ($m)

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

1 стартмани

28.02.2014    67984    ildarovich    123    

Программное создание реквизита управляемой формы с помощью механизма расширений

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

В ЗУП 3 возникла задача добавить реквизит в справочник не внося изменений в конфигурацию. БСП с механизмом дополнительных реквизитов использовать было нежелательно, поэтому был использован механизм расширений. Для вывода данного реквизита на форму добавлять саму форму в расширение не хотелось по ряду причин, описанных ниже. Создание реквизита и элемента формы, соответствующего данному реквизиту было решено сделать программно в самом расширении, следуя принципу минимального воздействия на конфигурацию.

1 стартмани

12.03.2019    34127    ni_cola    31    

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

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

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

1 стартмани

04.03.2019    5698    Alxby    4