powered by simpleCommunicator - 2.0.30     © 2024 Programmizd 02
Map
Форумы / Java [игнор отключен] [закрыт для гостей] / Новый альтернативный Slf4j логгер Бобина
25 сообщений из 320, страница 9 из 13
Новый альтернативный Slf4j логгер Бобина
    #39846625
Фотография mayton
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
dakeirasmaytonпропущено...

Упорство - это хорошая черта. Я уважаю упорных.

Но иногда упорство переходит в твердолобость.

Как мы объясним пользователю или кастомеру clash имен классов?
Ок, без проблем. Пусть будет Logger Name ( in most cases Class Name). Ок?
Да это ОК.

Был такой персонаж. Капитан Врунглель.
Он говорил - Как вы яхту назовёте - так она и поплывет.

Логгер - должен называться логгер. А никак не className. И вообще в современной JDK
не стоит завязываться на имя класса. И семантика должна быть как у логгера.
А не как у класса. Логгер - важен. Логгер может накрывать группу классов.
Имя логгера может браться откуда угодно. Он может быть динамичен. Но он не может
быть равен 1:1 с классом. Классы - сущность которой управляет класслоадер.
Логгеры - сущность которой управляем мы и бизнес.
...
Рейтинг: 0 / 0
Новый альтернативный Slf4j логгер Бобина
    #39846626
dakeiras
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
maytondakeirasпропущено...

Ок, без проблем. Пусть будет Logger Name ( in most cases Class Name). Ок?
Да это ОК.

Был такой персонаж. Капитан Врунглель.
Он говорил - Как вы яхту назовёте - так она и поплывет.

Логгер - должен называться логгер. А никак не className. И вообще в современной JDK
не стоит завязываться на имя класса. И семантика должна быть как у логгера.
А не как у класса. Логгер - важен. Логгер может накрывать группу классов.
Имя логгера может браться откуда угодно. Он может быть динамичен. Но он не может
быть равен 1:1 с классом. Классы - сущность которой управляет класслоадер.
Логгеры - сущность которой управляем мы и бизнес.
Ок, согласен. Спасибо.

Чуть позже переименую переменную.
...
Рейтинг: 0 / 0
Новый альтернативный Slf4j логгер Бобина
    #39846741
Alexey Tomin
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
dakeirasГде я кого-то высокомерно оценивал? Можно пример или цитату мою?


А пожалуйста:
dakeirasлегкой и простой настройкой (в отличии от невменяемых настроек других логгеров)


dakeirasПо какому уровню Log4j? Совершенно не индустриальная библиотека, которая по стечению обстоятельств и отсутствия альтернатив стала популярной.
У неё совершенно упоротая концепция иерархических логгеров - абсолютно не удобная привязка к уровню логирования.
Непонятно почему нельзя было изначально сделать её нормально.

Достаточно?

dakeirasВ данном случае (как и в нескольких других в этой теме от других комментаторов) вы переходите на личности, зачем-то подразумеваете мою тупость и пр.

Вы сами первый начали.
Вообще начать тему с заявления "20 лет все фигнёй занимались а я тут пришёл и сделал намного лучше" - это подставится под сильную критику.

dakeirasавторТо ли что не понимает, что документацию пишуют чтобы читать, а не чтобы высокомерно отвергать.
Не совсем понял, вы про какую документацию? Есть Вики, там довольно детально всё описано.
Никто ничего не отвергает.

Вам сразу указали на то, что нельзя использовать SimpleDateFormat в многопоточном коде. Что в его документации это явно написано.
Но зачем-то Вы упёрлись, что можно, что "я тестировал" (тут Шипёлёв привычно икнул).

Ну и вооще- предлагать всем библиотеку логирования, которая тащит с собой несколько мегабайт зависимостей (groovy-runtime) - это странной действо, заставляющее перейти на личность автора.
SDK это такая вещь, в которой размер имеет значение.
...
Рейтинг: 0 / 0
Новый альтернативный Slf4j логгер Бобина
    #39846765
PetroNotC Sharp
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Alexey Tomin,
+1
...
Рейтинг: 0 / 0
Новый альтернативный Slf4j логгер Бобина
    #39846842
dakeiras
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Alexey Tomin,

Вы скачали Бобину? Попробуйте.
Удивитесь, насколько всё сделано лучше чем logback.

А так Ваша предвзятость обоснована уверенностью, что «всё уже изобретено» и всё новое (особенно от неизвестных авторов) - не нужно.

Советую менять настрой. Вот только краткий список проектов в Pipeline:
- Портирование BlackBox на GCLIB - автоматическое добавление логирования на этапе компиляции. Реализовано сейчас на Groovy AST и работает только с Груви кодом
- Step Up авторизационный сервер и валидация JWT без обращения к БД - при помощи regex, и настройкой доступа на авторизационном сервере (а не на сервере ресурсов) - в универсальной форме
- Универсальный CRUD GUI к HATEOAS сервисам на ReactJs

Из того что уже сделано:
- Pigeon - рассылки и push notifications (SOAP, REST)
- BlackBox - уникальный проект по автоматическому добавлению логирования с помощью аннотации (на уровнях от Ошибки с аргументами вызова, Вызова метода, Стейтментов - и до самого НИЖНЕГО уровня - expression). Работает на Груви AST API.
- Supplies - разные утилиты мелкие
Ну и сама Бобина.
...
Рейтинг: 0 / 0
Новый альтернативный Slf4j логгер Бобина
    #39846851
dakeiras
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Ну и вооще- предлагать всем библиотеку логирования, которая тащит с собой несколько мегабайт зависимостей (groovy-runtime) - это странной действо, заставляющее перейти на личность автора.
SDK это такая вещь, в которой размер имеет значение.

Место на диске чтоли кончится?))
Вы похоже из любителей битовых масок в прикладных приложениях)
...
Рейтинг: 0 / 0
Новый альтернативный Slf4j логгер Бобина
    #39846873
Фотография mayton
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
dakeiras, по поводу скачать и попробовать. Я обещаю что когда-нибудь попробую.
Но до того как попробовать я обычно пытаюсь понять каково "прендазначение" вещи.
Например. Предназначение жопы - чтобы испражняться. Хотя есть некоторые
любители странного секса которые хотят погрузить в чью-то жопу свой крайний
отросток. И когда например мен на code-review приносят константы завёрнутые
в java interface - я просто спрашиваю. Ты что - любишь совокупляться в жопу?

Понятно да?

Предназначение. Ты должен сообществу объяснить предназначение твоей библиотеки.
Про BlackBox можешь даже не рассказывать. Форум не знает что это такое и никому
не интересны твои тестерские практики. Плевать на блек бокс. У нас - другие задачи.

Далее. По поводу Толстого Бобина.

И какую идею закладывал туда автор. Или какую философию. Обычно зрелость
продукта определяется этим. Например Log4j2 в режиме Async использует (косвенно)
зависимость от библиотеки неблокирующих очередей disruptor. Эта библиотечка
буферизирует не дисковый трафик а именно события. Events. Вот такая вот идея.
Хотя возможность асинхронной записи в файл тоже поддерживается но это другая
настройка.

За кадром остался вопрос перформанса. Ты так и не предоставил сообществу никаких
бенчмарков. Я по прежнему убёжден что Groovy генерирует самый медленный код
(для интенсивных вычислений) и никто меня не убедил в обратном. Грубо говоря
в линейке Java/Kotlin/Scala/Groovy, последний занимает последнее место. Груви - медленный
покемон в этом списке. И ты выкатил на общий суд тайм-критичную библиотеку взяв
за основу самый медленный компиллятор.
...
Рейтинг: 0 / 0
Новый альтернативный Slf4j логгер Бобина
    #39846892
Фотография Valentin Kolesnikov
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Может вам будет полезен метод U.format(string, .. args) в библиотеке из соседней ветки.

20531307

Хорошего Вам дня!
...
Рейтинг: 0 / 0
Новый альтернативный Slf4j логгер Бобина
    #39846908
Alexey Tomin
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
dakeirasВы скачали Бобину? Попробуйте.

Я вроде уже объяснил причину, почему не буду это делать.

dakeirasУдивитесь, насколько всё сделано лучше чем logback.

У меня код очень многопоточный, с высоким требованием к производительности. После SimpleDateFormat дальше читать не интересно- если есть столь очевидная бага- зачем искать другие? Конкаренси баги могут стрелять очень редко и ОЧЕНЬ больно. Мне наших баг хватает. logback работает быстро и надёжно.

dakeirasА так Ваша предвзятость обоснована уверенностью, что «всё уже изобретено» и всё новое (особенно от неизвестных авторов) - не нужно.

Нет.
Чтобы изобрести что-то хорошее, надо сначала понять то, что сделали предшественники.
Для тестов использовать JMH например. И показывать преимущество в виде конкретных тестов, которые каждый может запустить и получить результат.

Показать преимущество настройки в виде примеров, а не просто слов.

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

dakeiras- BlackBox - уникальный проект по автоматическому добавлению логирования с помощью аннотации (на уровнях от Ошибки с аргументами вызова, Вызова метода, Стейтментов - и до самого НИЖНЕГО уровня - expression).

Я тут думаю, как очень нужную либу перевести с кодогенерации при компиляции на лямбды- потому что "добавление кода в компиляции"- это добавление проблем в отладке.
...
Рейтинг: 0 / 0
Новый альтернативный Slf4j логгер Бобина
    #39846929
dakeiras
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Давайте здесь не обсуждать производительность Груви.
Это оффтопик.
Можно отдельную тему сделать. Если в кратце - Вы заблуждаетесь, это опять же МИФ, основанный на ОООЧЕНЬ ранних версиях (более 8 лет назад). Ещё раз повторю что используется @CompileStatic во всех классах Бобины, так что он даёт просто обычный Java код.
...
Рейтинг: 0 / 0
Новый альтернативный Slf4j логгер Бобина
    #39846930
dakeiras
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Я уже даже приводил пример декомпилированного класса в этой теме, если охота - можно посмотреть и убедиться.
...
Рейтинг: 0 / 0
Новый альтернативный Slf4j логгер Бобина
    #39846937
dakeiras
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
авторПосле SimpleDateFormat дальше читать не интересно- если есть столь очевидная бага- зачем искать другие
Мой богатый опыт подсказывает что что-то очевидно только при поверхностном ознакомлении.

Изначально ВСЕ экземпляры класса Bobbin были в ThreadLocal.
Так что не было это микроскопической баги с SimpleDateFormat.

Потом дизайн поменяли, и это стало актуально. Уже исправлено.
...
Рейтинг: 0 / 0
Новый альтернативный Slf4j логгер Бобина
    #39846948
dakeiras
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
авторТы должен сообществу объяснить предназначение твоей библиотеки.
Про BlackBox можешь даже не рассказывать. Форум не знает что это такое и никому
не интересны твои тестерские практики. Плевать на блек бокс. У нас - другие задачи.

Далее. По поводу Толстого Бобина.

И какую идею закладывал туда автор. Или какую философию. Обычно зрелость
продукта определяется этим. Например Log4j2 в режиме Async использует (косвенно)
зависимость от библиотеки неблокирующих очередей disruptor. Эта библиотечка
буферизирует не дисковый трафик а именно события. Events. Вот такая вот идея.
Хотя возможность асинхронной записи в файл тоже поддерживается но это другая
настройка.

За кадром остался вопрос перформанса. Ты так и не предоставил сообществу никаких
бенчмарков. Я по прежнему убёжден что Groovy генерирует самый медленный код
(для интенсивных вычислений) и никто меня не убедил в обратном. Грубо говоря
в линейке Java/Kotlin/Scala/Groovy, последний занимает последнее место. Груви - медленный
покемон в этом списке. И ты выкатил на общий суд тайм-критичную библиотеку взяв
за основу самый медленный компиллятор.

Из readme.md:

авторBobbin is a high-performance Groovy Slf4j-compatible logger designed for multi-threaded applications (especially those with persistent threads like batch and messaging applications).

Bobbin leverages the concept of Logback/Log4j2 sifting appenders while providing much more easier configuration using native Groovy/Java scripting expressions.

https://github.com/INFINITE-TECHNOLOGY/BOBBIN

Из Вики:

авторBobbin creates multiple isolated log files using a simple JSON configuration supporting Groovy Scripts to compute file names and other dynamic parameters during run-time.

Some of the File name segregation criteria include:

- Thread Name
- - Thread Group Name
- Class Name
- Log level
- MDC values
- Date
- Any other run-time parameters and their combinations
Bobbin leverages the concept of Logback/Log4j2 sifting appenders while providing much more easier configuration using native Groovy/Java scripting expressions.

Bobbin is high-performance logger optimized to be used in heavy load multi-threaded environments (with hundreds of persistent threads - especially those with persistent threads like batch and messaging applications).

It's CPU, GC and RAM footprint has been tuned to work as a primary logger within Spring stack, including Web context and JPA.

https://github.com/INFINITE-TECHNOLOGY/BOBBIN/wiki

Не хотел этого говорить, но "не читал, но осуждаю"...

Насчёт Бенчмарка: будет в течении 3-4 дней:
- Однопоточная работа в 1 файл
- Однопоточная работа в много файлов
- Многопоточная в 1 файл
- Многопоточная в много файлов со смешиванием потоков
- Многопоточная в много файлов без смешивания потоков (1 поток на файл)

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

Как тут написали, люди 10 лет делали Груви, а тут такой кадр нарисовался - и ему идея не нравится.
Зато появился котлин - сразу всем понравилось :) Потому что он продвинут при нечестной конкуренции.
И не поддерживает и половины функционала Груви.

авторДля тестов использовать JMH например. И показывать преимущество в виде конкретных тестов, которые каждый может запустить и получить результат.
Спасибо за инфо, изучу и возможно использую.

авторЯ тут думаю, как очень нужную либу перевести с кодогенерации при компиляции на лямбды- потому что "добавление кода в компиляции"- это добавление проблем в отладке.
Зато лямбды это легко отлаживать.
...
Рейтинг: 0 / 0
Новый альтернативный Slf4j логгер Бобина
    #39846950
Фотография mayton
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Мы все ждем тестов с @Jmh.

Нужно убедительное доказательство перформанса. Иначе - это не интересно.
...
Рейтинг: 0 / 0
Новый альтернативный Slf4j логгер Бобина
    #39846954
dakeiras
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Валентин Колесников,

авторМожет вам будет полезен метод U.format(string, .. args) в библиотеке из соседней ветки.

20531307

Хорошего Вам дня!

Мощь. Обязательно изучу.
Уже сейчас её можно использовать с Бобиной, добавив в билд - и настроив format в Bobbin.json:

Код: javascript
1.
"format": "U.format(\"DateTime = {} Message = {}\", dateTime, message)",
...
Рейтинг: 0 / 0
Новый альтернативный Slf4j логгер Бобина
    #39846955
dakeiras
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
maytonМы все ждем тестов с @Jmh.

Нужно убедительное доказательство перформанса. Иначе - это не интересно.

Оки. Скоро будет бенчмарк.
...
Рейтинг: 0 / 0
Новый альтернативный Slf4j логгер Бобина
    #39846968
Alexey Tomin
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
dakeiras- Многопоточная в 1 файл
- Многопоточная в много файлов со смешиванием потоков


Этого достатоно. Если интересует скорость, то потоков будет много, а читать десятки файлов логов- так себе занятие.

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


Да я писал даже на нём. Работало. Для примитивных проектов типа UI пойдёт. Писать многопоточную математику- ад.

dakeirasКак тут написали, люди 10 лет делали Груви, а тут такой кадр нарисовался - и ему идея не нравится.


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

dakeirasЗато появился котлин - сразу всем понравилось :) Потому что он продвинут при нечестной конкуренции.
И не поддерживает и половины функционала Груви.


Понравился он далеко не всем и не сразу. Кто-то дальше любит scala, кто-то ceylon, кто-то groovy. Каждому своё.
А про "нечестную конкуренцию"- вот это интересно- расскажите, пожалуйста.

dakeirasавторЯ тут думаю, как очень нужную либу перевести с кодогенерации при компиляции на лямбды- потому что "добавление кода в компиляции"- это добавление проблем в отладке.
Зато лямбды это легко отлаживать.

Я дебажил и грувивскую "магию", и самописную кодогенерацию и лямбды.
Можете верить, можете нет- но лямбды дебажить проще всего.
Особенно "прелестно" втыкать в ошибки самописного мавен-плагина. Вот у нас в 5% билдов почему-то падает с безумным стектрейсом- я даже браться за это не хочу...
...
Рейтинг: 0 / 0
Новый альтернативный Slf4j логгер Бобина
    #39846972
dakeiras
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
авторА про "нечестную конкуренцию"- вот это интересно- расскажите, пожалуйста.


Элементарно. Забашляли Гуглу чтобы Идею протолкнуть в Android Studio и далее - забашляли чтобы сделать Котлин офиц. языком для Android.

Котлин вообще появился без надобности, нет у него use case.
...
Рейтинг: 0 / 0
Новый альтернативный Slf4j логгер Бобина
    #39846974
dakeiras
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
я уже молчу, что сама Intellij Idea застряла по функционалу в 2000х.

Не могут до сих пор нормальную поддержку Gradle сделать.
...
Рейтинг: 0 / 0
Новый альтернативный Slf4j логгер Бобина
    #39846976
Alexey Tomin
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
dakeirasавторА про "нечестную конкуренцию"- вот это интересно- расскажите, пожалуйста.


Элементарно. Забашляли Гуглу чтобы Идею протолкнуть в Android Studio и далее - забашляли чтобы сделать Котлин офиц. языком для Android.

Бред какой.
IDEA сдала Android Studio потому что работники гугла пользовуются перешли на IDEA. Вот и всё.
У них вообще в разработки порядка особо нет и деньги не сделали бы ничего.
Поддержали котлин в андроид потому что решили, что это хорошо для андроид и всё.

dakeirasКотлин вообще появился без надобности, нет у него use case.

Бреслав прямым текстом говорил, что цели создания котлина (в порядке его приоритетов):
- потому что это интересно
- у фирмы достаточно денег, чтобы выделить работников для разработки неведомой фигни с нулевой одходностью
- они хотели поднять свой статус как фирмы
- на java писать надоело и непродуктивно, а scala/groovy не вызывали энтузиазма.
...
Рейтинг: 0 / 0
Новый альтернативный Slf4j логгер Бобина
    #39846978
Фотография mayton
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Сборщиков много. И среда вовсе не обязана поддержать их всех на 100%.

Понимаете да? Это не ее ответственность поддерживать всех и вся. Иначе стоимость
техподдержки превысит вообще прибыль от существования проекта.
...
Рейтинг: 0 / 0
Новый альтернативный Slf4j логгер Бобина
    #39846981
dakeiras
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
maytonСборщиков много. И среда вовсе не обязана поддержать их всех на 100%.

Понимаете да? Это не ее ответственность поддерживать всех и вся. Иначе стоимость
техподдержки превысит вообще прибыль от существования проекта.

Это смешно.

Есть 2 сборщика: Maven и Gradle.

И среда:
1) Обязана их поддерживать
2) В 2019 НЕ должна изобретать свою сборку ("проект\модули")

Иначе такая среда не нужна. Есть индустриальный стандарт в Java.
...
Рейтинг: 0 / 0
Новый альтернативный Slf4j логгер Бобина
    #39846986
dakeiras
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Alexey Tomindakeirasпропущено...


Элементарно. Забашляли Гуглу чтобы Идею протолкнуть в Android Studio и далее - забашляли чтобы сделать Котлин офиц. языком для Android.

Бред какой.
IDEA сдала Android Studio потому что работники гугла пользовуются перешли на IDEA. Вот и всё.
У них вообще в разработки порядка особо нет и деньги не сделали бы ничего.
Поддержали котлин в андроид потому что решили, что это хорошо для андроид и всё.

dakeirasКотлин вообще появился без надобности, нет у него use case.

Бреслав прямым текстом говорил, что цели создания котлина (в порядке его приоритетов):
- потому что это интересно
- у фирмы достаточно денег, чтобы выделить работников для разработки неведомой фигни с нулевой одходностью
- они хотели поднять свой статус как фирмы
- на java писать надоело и непродуктивно, а scala/groovy не вызывали энтузиазма.

Вы просто подтвердили мои слова.

Тут есть ещё момент - суды между Oracle и Google касательно Java в Android.
Но Гугл должен был выбрать Груви, а не котлин.
...
Рейтинг: 0 / 0
Новый альтернативный Slf4j логгер Бобина
    #39846988
Фотография mayton
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
dakeirasmaytonСборщиков много. И среда вовсе не обязана поддержать их всех на 100%.

Понимаете да? Это не ее ответственность поддерживать всех и вся. Иначе стоимость
техподдержки превысит вообще прибыль от существования проекта.

Это смешно.

Есть 2 сборщика: Maven и Gradle.

И среда:
1) Обязана их поддерживать
2) В 2019 НЕ должна изобретать свою сборку ("проект\модули")

Иначе такая среда не нужна. Есть индустриальный стандарт в Java.
Я sbt пользуюсь. И он хреново поддерживается. Что мне делать?
...
Рейтинг: 0 / 0
Новый альтернативный Slf4j логгер Бобина
    #39846989
Фотография mayton
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
dakeirasТут есть ещё момент - суды между Oracle и Google касательно Java в Android.
Но Гугл должен был выбрать Груви, а не котлин.
Зачем ты в технический топик затаскиваешь суды крупных контор?
Это вообще никаким боком не имеет отношения к теме топика.

Обсуждаем Толстого Робина-Бобина.
...
Рейтинг: 0 / 0
25 сообщений из 320, страница 9 из 13
Форумы / Java [игнор отключен] [закрыт для гостей] / Новый альтернативный Slf4j логгер Бобина
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]