metaclass: (Default)
[personal profile] metaclass
Продолжаю вникать в легковесные MQ библиотеки и ужасаюсь одной всепроникающей идее - ассерты в релизном коде, буквально на каждый возможный косяк.
С одной стороны, fail-fast это правильный подход, пусть супервизор процессов разбирается что дальше делать.
С другой - abort или RaiseException на виндах кидают messagebox, а messagebox в виндосервисе, если нет чек-бокса "разрешить взаимодействие с десктопом", это гамон, такой процесс можно только убить, он больше не подчиняется указаниям от сервис-контроллера. То же самое - запуск процессов из task scheduler, этот мессаджбокс будет "где-то висеть" в гребенях сессии в которой запущены сервисы.

Далее, нормальная методика при обработке ошибок: try {} catch(exception) { log(сообщение, параметры вызова, exception);throw}. Т.е. я по крайней мере, по логам узнаю, что привело к исключению (за исключением совсем плохих вещей, типа полной нехватки памяти, умершего железа или выдернутого езернет-провода).
В случае же assert - у меня процесс сдыхает (и не дай бог в соседних потоках писать на диск или работать с железом), причем если супервизор, который может прочесть stderr и скопировать сообщение в свой лок,отсутствует - сообщение об ошибке уйдет в никуда.

Судя по тому, как друг на друга псят Martin Sustrik и Pieter Hintjens, отзывам про либы и тому бардаку, который творится в коде nanomsg(например, комментарий вида: /* For some reason simple CancelIo doesn't seem to work here. We have to use CancelIoEx instead. */ в коде, из-за которого nanomsg вообще не запускается на 2003 и xp), ситуация с этими либами откровенно нехорошая.

Date: 2014-12-05 11:27 pm (UTC)
From: [identity profile] vit-r.livejournal.com
Ассерт на виндусе - это как двигатель от гоночного автомобиля на трёхколёсном велосипеде. Удел Виндов - тихие убогие баги.

Date: 2014-12-06 12:00 am (UTC)
From: [identity profile] podberezovik345.livejournal.com
Даже трехколесному велосипеду не нужен игрушечный двигатель игрушечного гоночного автомобиля.

Date: 2014-12-06 12:04 am (UTC)
From: [identity profile] vit-r.livejournal.com
Всё можно сделать через жопу.

Date: 2014-12-16 10:43 am (UTC)
From: [identity profile] rashid80.livejournal.com
не осилил?

Profile

metaclass: (Default)
metaclass

April 2017

S M T W T F S
      1
2345678
9101112 131415
16171819202122
23242526272829
30      

Most Popular Tags

Style Credit

Expand Cut Tags

No cut tags
Page generated Sep. 24th, 2025 03:33 pm
Powered by Dreamwidth Studios