gRPC - альтернатива REST API от Google. Пишем gRPC сервер и клиент на Java и Python.

Поділитися
Вставка
  • Опубліковано 17 гру 2024

КОМЕНТАРІ • 299

  • @alishevN
    @alishevN  3 роки тому +7

    Telegram: t.me/alishev_g

  • @wizardadeptus2044
    @wizardadeptus2044 2 роки тому +12

    Хорошее видео. Позволило поверхностно разобраться в gRPC под стакан уиски. В свою очередь это позволило отдебажить gRPC сервак заказчика на котлине и понять почему он возвращал NPE в ответе. А то непонятно было, куда коней запрягать с этим gRPC. Ура, баг починен, автору респект.

  • @DairaGames
    @DairaGames 3 роки тому +39

    Блин чувак. Ты просто вангуешь. Я только сегодня такой думал: блин, вот бы урок про микросервисы замутил бы кто то годный. И тут уведомление. Просто бомба. Спасибо большое. От души. Я в этой жизни теперь точно не буду счастлив, пока лично не найду тебя не пожму руку. Спасибо

  • @АлексТвист-ф8ж
    @АлексТвист-ф8ж 2 роки тому +21

    Огромная благодарность, Наиль, за Ваш труд! Реально талант. Настолько доступным языком объяснять сложные вещи. Смотрел в других источниках про gRPC , почти ничего не понял. После этого видео сразу целостное понимание технологии, подхода и преимуществ. И сразу с примером👍Спасибо!)

  • @AlekseiBeloglazov
    @AlekseiBeloglazov Рік тому +1

    Мужик, спасибо за объяснение с практикой и сжато в тоже время.
    Я ваще не в теме был.
    Но честно, мужик.
    ctrl + A, ctrl + c - скопировать все содержимое файла.
    ctrl + A, ctrl + v - вставить в файл с полной заменой.
    Так сильно проще, чем крутить колесико.

  • @eugenenazirovpersonal
    @eugenenazirovpersonal 2 роки тому +2

    Офигенно! Как раз на проекте столкнулся с использованием микросервисов, которые общаются по gRPC. Помогло очень быстро въехать в тему. Спасибо большое!

  • @aliaksandraryzhyk4138
    @aliaksandraryzhyk4138 3 роки тому +4

    Как всегда на высшем уровне.... все четко, понятно, без воды... Спасибо большое!!!

  • @АндрейНикола-п6ю
    @АндрейНикола-п6ю 2 роки тому +4

    Я наконец то разобрался с gRPC) Спасибо тебе за проделанную работу!

  • @AndreyMalygin
    @AndreyMalygin 2 роки тому +1

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

  • @RG-em1nh
    @RG-em1nh 3 роки тому +41

    Мне бы такого ментора как ты, спасибо большое добрый человек !

  • @spilnich
    @spilnich 3 роки тому +3

    Получил первый оффер! Спасибо огромное за grpc и все видео по Spring, кучу раз пересматривал и конспектировал.

  • @fedyasavchuk1043
    @fedyasavchuk1043 3 роки тому +16

    Был бы очень признателен за подобные уроки по kafka и maven :)

  • @psy667
    @psy667 3 роки тому +7

    Очень качественная подача информации, спасибо вам огромное

  • @ivanfedin9094
    @ivanfedin9094 Рік тому +1

    Шикарный урок - очень подробно и понятно. Спасибо!

  • @МаксимСамойлов-р6ф

    По моему мнению Наиль самый комфортный обозреватель по Java!!! Скорость подачи ин-фы + грамотная речь + хороший объём нового материала!!! В общем просто КЛАСС👍

  • @dzmitrydarashuk6528
    @dzmitrydarashuk6528 Рік тому

    Я человек простой, вижу новое видео Алишева - захожу, ставлю лайк!

  • @nikenuke
    @nikenuke Рік тому

    Очень классный материал! Посмотрел до этого 10 роликов по gRPC и не мог разобраться все равно, теперь же все ясно, спасибо!

  • @Skykvi
    @Skykvi 2 роки тому +1

    Очень круто, отличное содержание, приятно смотреть. Спасибо за труд.

  • @CyberAcidPlanet
    @CyberAcidPlanet 3 роки тому +6

    Аргмент по несжимаемость JSON надуманный. Он отлично жмётся тем же gzip или brotli, где не будет проблемы того что у нас один и тот же ключ повторяется много раз (будет ссылка на этот символ при сжатии).

  • @maxim9976
    @maxim9976 3 роки тому +6

    21:30 для браузера можно использовать gRPC-web. Там пока есть ряд ограничений по стримингу, но в целом рабочий вариант.

    • @RedkeiGost
      @RedkeiGost 2 роки тому +1

      Да ну куча проблем у gRPC-web. Вот приходит вам мессаг-респонс, и нужно её прочитать. Вы делаете toObject и если в глубине есть тип google_protobuf_struct_pb.Struct то оно превратится в fieldsMap. И можно конечно на Struct юзать toJavaScript, но Struct может быть очень глубоким потомком jspb.Message и во-первы, идти через геттеры к нему крайне неудобно, а во-вторых, нам нужно все дерево и нужно как-то мержить результат toObject и его потомка. С типизацией у Struct тоже плохо - она вообще не имеет типа и это реально приводит к проблемам в typescript. В целом ну очень неудобно, имхо.

  • @tolibijava
    @tolibijava 5 місяців тому

    Очень внятно и просто как всегда - СУПЕР ПОДАЧА

  • @leonidvolobuev7096
    @leonidvolobuev7096 3 роки тому +3

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

  • @kursruk
    @kursruk 3 роки тому +2

    Отсутствие строгой типизации, это не минус, а плюс JSON.
    По поводу избыточности JSON.
    {
    "header":["date", "event"],
    "data": [
    ["2020-01-14", "Событие 1"],
    ["2020-01-19", "Событие 2"],
    ["2020-01-23", "Событие N"],
    ]
    }
    Так, что избыточных ключей легко избежать.
    Также ничто не мешает гонять потоки JSON объектов по HTTP 2.
    Тем не менее большое спасибо за видеоролик.

    • @apoloz-p6x
      @apoloz-p6x 2 роки тому

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

  • @svetlanamazhaykina6918
    @svetlanamazhaykina6918 8 місяців тому

    Спасибо за Ваш труд! Коммент в поддержку канала.

  • @Евгений-ь3г5к
    @Евгений-ь3г5к Рік тому

    Редко оставляю комментарии, но ты красавчик! Столько полезного материала!❤

  • @olegrazin3429
    @olegrazin3429 3 роки тому +3

    Так вот как ты выглядишь, Alishev. Этот видео формат очень крут!

  • @ykochubeev
    @ykochubeev Рік тому

    Большое спасибо вам, очень полезное видео. Пойду поищу ваши уроки про Java

  • @JohnSmith-m6y4r
    @JohnSmith-m6y4r Рік тому

    Наиль, у Вас талант объяснять сложные вещи простым языком. Например я очень долго искал и не мог найти понятное для себя руководство по Spring'у, пока не наткнулся на Ваш курс - он стал для меня единственным спасательным кругом. И то же самое с gRPC. Вам нужно собственную школу по программированию открывать для программистов, уже владеющих основами языков программирования, такой как бы продвинутый курс. Или стажировать людей за деньги где-то с оплатой в Вашу сторону. Первую работу найти очень тяжело, поэтому думаю на это реально должен быть спрос - новичкам дать возможность покупать коммерческий опыт, котирующийся у работодателей, за деньги.

  • @varchar21
    @varchar21 3 роки тому +2

    Наиль, благодарю! Всегда актуально и своевременно. Спасибо еще раз!

  • @vladimirnechiporyuk2948
    @vladimirnechiporyuk2948 Рік тому

    Афигенная штука. Теперь буду писать пет проекты только на gRPC!

  • @Denis-Orlov
    @Denis-Orlov 3 роки тому +9

    Как же ж вовремя! Как раз на работе попросили замутить gRPC клиент!

  • @АндрейСемка-ъ1ы
    @АндрейСемка-ъ1ы 2 роки тому

    Спасибо большое за ценный и подробный урок!

  • @It_wizards
    @It_wizards 3 роки тому

    Круто, очень доступно, красавчик!

  • @kazakhification
    @kazakhification 3 роки тому +24

    Json сжимается gzip-ом разве нет?

    • @alishevN
      @alishevN  3 роки тому +1

      даже сжатый JSON все равно занимает больше места, чем protobuf - nilsmagnus.github.io/post/proto-json-sizes/

    • @FastDamage
      @FastDamage 3 роки тому +6

      @@alishevN Честно не много не понял,так если проблема в размере JSON,что мешает весь JSON прогнать через protobuf и отправить? я ничего не имею против gRpc но в большом проекте где под 1000+ методов которые взаимодействуют с различными микросервисами замучаешься всё описывать в .proto (для такой задачи надо нанимать отдельно человека на должность mapper ;) )

    • @mishashins
      @mishashins 3 роки тому

      @@FastDamage у нас в C# можно описывать интерфейсы)

    • @brunneng8575
      @brunneng8575 3 роки тому +5

      Автор даёт ссылку на тесты. Там видно что при коротких сообщениях прото дает выигрыш. Однако на больших сообщениях явно теряет преимущество.
      Я думаю что нужно ещё больше тестов. Повысить энтропию данных, зажать их и посмотреть что получиться. Есть шанс что в разных ситуациях, в разных задачах придется выбирать между прото или json вариантом, так как есть зависимость от объема данных и рассеивании. Аргумент того что json сжатие требует процессорное время, такое себя, так как любое сжатие этого требует. Нужно больше хороших синтетических тестов и тестов из жизни, реальных проектов.
      Но по мне, пока что, JSON выглядит лучше, даже если на коротких сообщениях проигрывает.

  • @ВладимирШереметьев-в2ю

    Отличный и понятный урок, спасибо!

  • @RedkeiGost
    @RedkeiGost 2 роки тому +2

    "в случаи с монолитным приложением мы можем изменить какую-то часть и это затронет другие приложения" - вопрос архитектуры монолита. Зацепленность-связанность, все дела. "Всё объединено" это не от монолитности же зависит. Микросервис тоже можно изменить так, что это затронет зависящие от него микросервисы.
    Используется версия http2 только если браузер его полностью поддерживает. Иначе энвой же шлет по http1, разве нет?
    Ключ-единицу 29:21 мог бы и proto сгенерировать.

  • @КириллЛемесев-е3е
    @КириллЛемесев-е3е 3 роки тому

    Прекрасный урок, большое спасибо!

  • @llARXANGELll
    @llARXANGELll 2 роки тому

    Ух годнота. Однозначно лайк!!!

  • @antondzmitruk2102
    @antondzmitruk2102 3 роки тому +2

    Нет слов! Спасибо тебе огромное!

  • @faniskhalikov9736
    @faniskhalikov9736 3 роки тому +3

    Круто! Очень хорошо разобрано, заходит отлично ) Талантливый человек талантлив во многом (на заднем плане гитара и синтезатор : ) )

  • @АлександрМамзиков-х1у

    Никто не мешает в rest использовать бинарный формат и сжатие.

    • @kalashnikofsergey7064
      @kalashnikofsergey7064 3 роки тому

      Я бы посмотрел как ты свагером нагенеришь код под бинарные сообщения

    • @dark_evil77
      @dark_evil77 3 роки тому

      Я мешаю

    • @АлександрМамзиков-х1у
      @АлександрМамзиков-х1у 3 роки тому +2

      @@kalashnikofsergey7064 чем? Тут ведь речь шла не об удобстве и трудозатратах, а о принципиальной возможности.

    • @Миха-и7г
      @Миха-и7г 3 роки тому +5

      это помимо того, что json, как и любой текст, прекрасно жмётся апаратными средствами, прозрачно для разработчика.

  • @ChamZod
    @ChamZod 3 роки тому +1

    Не успел начать рест изучать, а тут уже что-то новое)

    • @NummeSpnet
      @NummeSpnet 3 роки тому

      не парься, ещё долго рест будет актуален.

  • @gamechannel_833
    @gamechannel_833 3 роки тому +4

    Не посмотрев видео, сразу ставлю лайк!

  • @ilyababcenco6864
    @ilyababcenco6864 3 роки тому +7

    Автолайк, Наиль скажи пожалуйста когда ждать следующий урок по спрингу, ну ооочень жду там как раз на самом интересном ты остановился

    • @alishevN
      @alishevN  3 роки тому +11

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

  • @shubinsyu
    @shubinsyu 3 роки тому +5

    А чем отличается микросервис от EJB-компонента, работающего в распределенной JEE-платформе? И в чем отличие gRPC от RMI/Corba?

    • @ЕвгенийАфанасьев-о5у
      @ЕвгенийАфанасьев-о5у 3 роки тому +5

      EJB аналогичен по своей сути мультимодульному проекту на мавене, когда монолит делят на разные куски в зависимости от его действий в приложении, например, один ejb компонент отвечает за DAO, другой бизнес логика, другой интеграция с внешними сервисами и ТД.
      Концепция миеросесервисов строится вокруг DDD подхода в рамках которого у каждого сервиса может быть и свой dao слой, и свой слой интеграции и своя бизнес логика. А по поводу RMI, так эта технология и так используется в спринг клауд и является его базой. Grpc в отличии от RMI можно сипмлементировать на любом языке, таким образом не завязываясь на определенном стеке, в то время как клауд в рамках одного цельного приложения это набор микросервисов на java

  • @silentium_noxe
    @silentium_noxe 3 роки тому +1

    >нам нужно только унаследоваться от этого класса 35:45
    Тем временем класс public **final** class
    Upd: так бы прямо и говорил что мы будем наследоваться от вложенного класса. 😂

  • @redologs
    @redologs 3 роки тому +1

    Увидел тему, посмотрел длительность - лайк не глядя.

  • @vladimirblagin3105
    @vladimirblagin3105 Рік тому

    24:05 Глядя как развиваются последние несколько лет нейронки, есть большая вероятность замены таких инструментов как PVS-Studio анализаторами на базе AI. Желаю ребятам скорее оседлать этого конька и включить в свой проект AI подсистему анализатора кода.

  • @antondzmitruk2102
    @antondzmitruk2102 3 роки тому

    Ты мог бы сказать типо есть такая штука от Гугла и используйте ее вместо REST, она лучше), но ты прям с самого начала разжевал) Браво!

  • @miketuev3241
    @miketuev3241 3 роки тому

    Супер ролик! Большое спасибо. Доходчиво и понятно.

  • @ivanstrelka3448
    @ivanstrelka3448 3 роки тому

    Очень круто. Спасибо

  • @k0rinf
    @k0rinf 3 роки тому +1

    Поясните как контролить версии прото файла!? Как сервисы должны понять что он обновился и нужно его поменять и перегенерить код!?

  • @kamurashev
    @kamurashev 3 роки тому +5

    Как скопировать джава RMI в другие языки и ни кому не говорить. Структура 1 в 1. И этой штуке 100 лет в обед. Я еще не родился. За видео лайк.

  • @canti2332
    @canti2332 3 роки тому +3

    Справедливости ради, так как JSON это простой текст, то отлично сжимается gzip, и настроить его как для отдачи так и для получения довольно просто. Такие минусы как не сжимается и повторяющиеся ключи для сжатого json не работают, правда добавляется архивирование и разархивирование.

    • @alishevN
      @alishevN  3 роки тому +2

      да, правильное замечание, но даже сжатый JSON все равно занимает больше места, чем protobuf - nilsmagnus.github.io/post/proto-json-sizes/

    • @MrRais96
      @MrRais96 3 роки тому +4

      @@alishevN При передаче данных по каналам связи, что текст, что бинарные файлы сжимаются. Текст лучше, бинарные данные меньше, а в целом получающийся пакет примерно одинаков, разница в 5-10%. Излишний размер влияет на надежность, текстовый формат передается чуть медленнее, но надежнее. Все вышеописанное влияет на передачу между удаленными серверами, в случае связи между близкорасположенными серверами, без использования внешних каналов, т.е. интранет, то тут бинарный формат в 7-10 раз может быть быстрее.

    • @muxahx3096
      @muxahx3096 3 роки тому

      GraphQL вам в помощь.

  • @Блин-Наш
    @Блин-Наш 2 роки тому

    Блин , хорошая лекция. Толковый лектор....

  • @ZzooD
    @ZzooD 3 роки тому

    Классный урок, побольше бы таких )

  • @mahmoody8913
    @mahmoody8913 Рік тому

    а почему можно final class наследовать, может кто-нибудь объяснить? с 35:30

  • @aidynabirov7728
    @aidynabirov7728 3 роки тому

    Отличное видео !

  • @Pewdew
    @Pewdew 3 роки тому

    Послушал с удовольствием, первый раз покурить оторвался на 47й минуте))

  • @alekcandrovich
    @alekcandrovich 3 роки тому

    спасибо! все понятно и лаконично

  • @alexeymyasnichenko3318
    @alexeymyasnichenko3318 3 роки тому +2

    был ли у кого затык в том, что после генерации классов из прото файла, в таргет папке все как в видео, но при имплементации возникает затык, идея просто не видит этот класс из таргета, при ручном импорте com.example.grpc* , идея не видит уже с папки example . хотя ТООЧНО она в иерархии папок в таргет файлах есть как в видео.

    • @j_denis
      @j_denis 2 місяці тому +1

      Надо пометить папки со сгенерированным кодом, как sources root, и эта проблема исчезнет.

  • @DairaGames
    @DairaGames 3 роки тому +1

    Формат кстати бомбезный. Люблю иногда посмотреть стримы от GeekBrains (Александр Фирсунов) из за того, что урок идёт на примере и больше часа.

  • @ПолинаВасильева-ъ5ю
    @ПолинаВасильева-ъ5ю 4 місяці тому

    Добрый день! Подскажите, пожалуйста, как написать протофайл с двумя rpc таким образом, чтобы сначала ожидались данные от первого сервиса, а потом уже от второго?
    Как посылать запрос на первый сервер, пока не получишь данные? Спасибо большое за ответ

  • @ZIK_1337
    @ZIK_1337 Рік тому

    привет! а как происходит версионирование proto файлов? допустим на сервере он поменялся, это же не значит, что все клиенты должны обновляться? есть какие-то версии пакетов, чтобы использовать конкретный proto файл на клиентах?

  • @cannibalirk3055
    @cannibalirk3055 Рік тому

    некоторые зависимости из этого урока и protobuf-maven-plugin не обновлялись аж с 2018 года. есть какой-то более современный стек, заменяющий эти, очевидно, устаревшие инструменты?

  • @olgasbrv
    @olgasbrv 3 роки тому

    Спасибо за урок! Очень понятно объяснил. До начала практики слушала как подкаст и всё поняла. Золото!!!
    (Пусть те кто хотят похвастаться в коментах о том что знают больше, вспомнят как учились ложкой кушать.)

  • @mazeltov2701
    @mazeltov2701 3 роки тому

    Неплохая обертка веб сокетов

  • @Nievinor
    @Nievinor 3 роки тому

    Не знал ранее про данный механизм. Спасибо)

  • @IgorAlov
    @IgorAlov 3 роки тому

    json так же сжимается может deflate или gzipом, если настроено сжатие между клиентом и серверов. это прям очень стандартно. и реально эффективно это все и получается бинарно. так же весь html передается, он сжимается при передаче. посмотрите это с помощью tcpdump данные в теле буду бинарными а не текстовыми при использовании сжатия

  • @evgenyshevelev6100
    @evgenyshevelev6100 3 роки тому

    Охренеть! Это же гениально! Общение клиента и сервера как по шине между процессором и ОЗУ, например. Я балдею)

  • @p.polunin
    @p.polunin 2 роки тому

    Обалдеть! 😳

  • @soontobedivorced
    @soontobedivorced 3 роки тому +1

    Скажите, пожалуйста, в чем отличие установки соединения по HTTP 2 с последующим получением по этому соединению потока данных и сокетов? Используя сокеты тоже ведь можно установить отдельное соединение с сервером и получать по нему данные? Большое спасибо за урок!

    • @gregory-povorozniuk-piano
      @gregory-povorozniuk-piano 2 роки тому

      HTTP и Web Sockets это разные протоколы сделанные на основе TCP

  • @vladislavborisov985
    @vladislavborisov985 3 роки тому

    У меня такой вопрос, когда мы делаем стрим данных от сервера клиенту, в этот стрим попадает 10000 сообщений, которые клиент вычитывает подключившись к серверу, если происходит перезапуск клиента то сообщения читаются с начала, а как сделать, чтобы сервер стримил сообщения которые клиент получал бы не с самого начала, а в реальном времени, т.е. со следующего отправленного после подключения клиента?

  • @eugenenovikov671
    @eugenenovikov671 3 роки тому

    Наиль, а если мы работаем в другой IDE, где нету такого окна Maven с package, как нам тогда всё запускать?

  • @pavelgolin2421
    @pavelgolin2421 3 роки тому

    для приема данных с сенсоров используется mqtt, а http для веба

  • @MrShark123123
    @MrShark123123 3 роки тому +1

    Надеюсь тема grpc будет дальше развиваться,очень нужная штука сейчас,а русскоязычных материалов нету

  • @daniyarrakhymbek5876
    @daniyarrakhymbek5876 Рік тому

    Большое спасибо!

  • @TeamKiller06
    @TeamKiller06 3 роки тому

    В REST API ведь можно использовать потоковые данные через библиотеку Reactor для Spring Boot. Данные передаются через Mono и Flux.
    Спасибо за обзор. Все четко и доступно. Однозначно заинтересовала технология. Немного напрягает что вместо JSON используется бинарный код

    • @ixaran
      @ixaran 2 роки тому

      Если не нравится делай на старых технологиях, и как ты собираешься организовывать стримы?

  • @lotierm
    @lotierm 3 роки тому +2

    rest api тоже можно бинарно передавать

  • @ramilsafin5751
    @ramilsafin5751 3 роки тому

    С удовольствием послушал тебя, Наиль!

    • @ramilsafin5751
      @ramilsafin5751 3 роки тому

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

    • @alishevN
      @alishevN  3 роки тому

      @@ramilsafin5751 Спасибо за фидбэк!) Подумаю над этим.

  • @tuujhfjjiyiiitr5763
    @tuujhfjjiyiiitr5763 Рік тому

    Спасибо! очень помог

  • @_Vertan_
    @_Vertan_ 3 роки тому +1

    Не знаю на какой джаве проект, но с такими моструозными названиями классов хорошо заходит объявление через var)

    • @KotlinBack
      @KotlinBack 3 роки тому

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

  • @evgenkr2993
    @evgenkr2993 3 роки тому

    супер видео! понятно преподнесено материал! спасибо!

  • @tbazadaykin
    @tbazadaykin 3 роки тому

    1) Как НЕ копировать прото-файлы каждый раз в десяток проектов-микросервисов?
    2) Как отслеживать изменения в протофайлах?
    Первое что приходит на ум это создавать отдельный проект с описанием сервисов на протобуфе, собирать из этого проекта потом пакеты/модули для различных языков, и импортировать эти пакеты/модули как внешние зависимости в микросервисах.

    • @maxim9976
      @maxim9976 3 роки тому

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

  • @Softovick
    @Softovick 3 роки тому +1

    Спасибо за видео.
    Но вопрос возник в голове у меня - ведь если текст, то его тоже можно сжимать на лету, есть же алгоритмы. Которые достаточно эффективно и быстро сжимаю данные и вот их можно по сети гонять. По сути ведь все равно gRPC дает накладные расходы на кодировние/декодирование, в REST это можно на сжатие/распаковку тратить. Ну правде это не решает вопрос с протоколом и стримами, согласен, но тем не менее.

  • @ДанилаБагров-ъ1ы
    @ДанилаБагров-ъ1ы 3 роки тому

    Классно!!! Спасибо большое за проделанную работу! Очень интересно слушать!

  • @gennatok2587
    @gennatok2587 Рік тому

    Привет. При запуске package падает ошибка "protoc did not exit cleanly. Review output for more information.". В чем может быть причина?

  • @konstantinviktorovich8194
    @konstantinviktorovich8194 3 роки тому

    Подход работы с gRPC, чем то похож с SOAP. Там на основе wsdl генерится java код, а здесь на основе proto файла. Как у клиента так и у сервера эти два файла должны быть одинаковые.

  • @ВладимирЕвдокимов-и3х

    А как насчёт GraphQL?

    • @muxahx3096
      @muxahx3096 3 роки тому

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

  • @valeralemberov2853
    @valeralemberov2853 8 місяців тому +1

    Я один столкнулся с проблемой что не могу унаследовать Grpc класс, у меня 2 проекта, одни maven второй greadle но не там не там не получается расширить этот класс. Если есть идеи буду рад. А так автору респект!!

    • @ilyamogilan8209
      @ilyamogilan8209 8 місяців тому

      Столкнулся с такой же проблемой. Помогло изменение версии зависимостей grpc-netty-shaded, grpc-protobuf и grpc-stub до актуальной (1.62.2)

    • @valeralemberov2853
      @valeralemberov2853 8 місяців тому

      @@ilyamogilan8209 о боги, это сработало. Спасибо тебе.

  • @denislobanov7582
    @denislobanov7582 2 роки тому

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

  • @dobrochaneranonimous2496
    @dobrochaneranonimous2496 3 роки тому

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

  • @Skaiiur
    @Skaiiur 3 роки тому

    Интересно почему не используется реактивных подход где возвращая Flux так же можно стримить данные.

    • @alishevN
      @alishevN  3 роки тому

      да, flux был бы здесь уместен.

  • @ДанилаКононихин
    @ДанилаКононихин 3 роки тому

    Спасибо большое за видео. Хочу спросить - а как задавать повторяющиеся поля?Как задать хобби в этом примере? Я постоянно отваливаюсь по OutOfBoundException

  • @chapelain36
    @chapelain36 3 роки тому

    Почему-то не генерируются классы после package.
    Только после protobuf:compile и protobuf:compile-custom

    • @lionsroom
      @lionsroom 2 роки тому

      Как пофиксили?

  • @tonyv3gas
    @tonyv3gas 3 роки тому

    Лукас атдущи! работа с железом wanted :)

  • @MrAPPOLON123
    @MrAPPOLON123 2 роки тому

    получается если использовать grpc и асинхронность это капец как летать будет?

  • @mykytafrolov
    @mykytafrolov 3 роки тому

    Крутой урок, спасибо!

  • @СтасМатвеев-ъ9з

    Loguru очень хорошая альтернатива стандартному logging в Python

  • @KotlinBack
    @KotlinBack 3 роки тому

    Сразу вопрос. Как при потоковой передаче данных клиент поймёт, что данные кончились ? В данном примере клиент итератором бежит по ответам, получаемым от сервера, но если задержка между ответами будет составлять не 100мс, а разное время , то как клиент поймёт , что поток закончился? Или закрытие потока на сервере даст понять клиенту , что данных больше не будет ? За видео спасибо огромное !!