Тёмный

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

alishev
Подписаться 153 тыс.
Просмотров 131 тыс.
50% 1

Скачать PVS-Studio бесплатно: www.viva64.com/alishev
RU-vid канал PVS-Studio: / pvsstudiotool
VK группа PVS-Studio: pvsstudio_rus
pom.xml: gist.github.com/NeilAlishev/1...
Продвинутая Java - swiftbook.org/courses/415
Telegram: t.me/alishev_g
Реклама и сотрудничество: alishev.neil@gmail.com

Опубликовано:

 

23 фев 2021

Поделиться:

Ссылка:

Скачать:

Готовим ссылку...

Добавить в:

Мой плейлист
Посмотреть позже
Комментарии : 295   
@alishevN
@alishevN 3 года назад
Telegram: t.me/alishev_g
@user-jo5js4ug5b
@user-jo5js4ug5b 11 месяцев назад
Мужик, спасибо за объяснение с практикой и сжато в тоже время. Я ваще не в теме был. Но честно, мужик. ctrl + A, ctrl + c - скопировать все содержимое файла. ctrl + A, ctrl + v - вставить в файл с полной заменой. Так сильно проще, чем крутить колесико.
@wizardadeptus2044
@wizardadeptus2044 2 года назад
Хорошее видео. Позволило поверхностно разобраться в gRPC под стакан уиски. В свою очередь это позволило отдебажить gRPC сервак заказчика на котлине и понять почему он возвращал NPE в ответе. А то непонятно было, куда коней запрягать с этим gRPC. Ура, баг починен, автору респект.
@aliaksandraryzhyk4138
@aliaksandraryzhyk4138 2 года назад
Как всегда на высшем уровне.... все четко, понятно, без воды... Спасибо большое!!!
@user-vj7dc1ib2y
@user-vj7dc1ib2y Год назад
Огромная благодарность, Наиль, за Ваш труд! Реально талант. Настолько доступным языком объяснять сложные вещи. Смотрел в других источниках про gRPC , почти ничего не понял. После этого видео сразу целостное понимание технологии, подхода и преимуществ. И сразу с примером👍Спасибо!)
@eugenenazirov
@eugenenazirov Год назад
Офигенно! Как раз на проекте столкнулся с использованием микросервисов, которые общаются по gRPC. Помогло очень быстро въехать в тему. Спасибо большое!
@user-hv2vy3kd9f
@user-hv2vy3kd9f 2 года назад
Я наконец то разобрался с gRPC) Спасибо тебе за проделанную работу!
@Skykvi
@Skykvi Год назад
Очень круто, отличное содержание, приятно смотреть. Спасибо за труд.
@psy667
@psy667 3 года назад
Очень качественная подача информации, спасибо вам огромное
@ivanfedin9094
@ivanfedin9094 Год назад
Шикарный урок - очень подробно и понятно. Спасибо!
@RG-em1nh
@RG-em1nh 3 года назад
Мне бы такого ментора как ты, спасибо большое добрый человек !
@varchar21
@varchar21 3 года назад
Наиль, благодарю! Всегда актуально и своевременно. Спасибо еще раз!
@nikenuke
@nikenuke 8 месяцев назад
Очень классный материал! Посмотрел до этого 10 роликов по gRPC и не мог разобраться все равно, теперь же все ясно, спасибо!
@DairaGames
@DairaGames 3 года назад
Блин чувак. Ты просто вангуешь. Я только сегодня такой думал: блин, вот бы урок про микросервисы замутил бы кто то годный. И тут уведомление. Просто бомба. Спасибо большое. От души. Я в этой жизни теперь точно не буду счастлив, пока лично не найду тебя не пожму руку. Спасибо
@alishevN
@alishevN 3 года назад
:)
@user-mk2xy9py8s
@user-mk2xy9py8s 7 месяцев назад
Наиль, у Вас талант объяснять сложные вещи простым языком. Например я очень долго искал и не мог найти понятное для себя руководство по Spring'у, пока не наткнулся на Ваш курс - он стал для меня единственным спасательным кругом. И то же самое с gRPC. Вам нужно собственную школу по программированию открывать для программистов, уже владеющих основами языков программирования, такой как бы продвинутый курс. Или стажировать людей за деньги где-то с оплатой в Вашу сторону. Первую работу найти очень тяжело, поэтому думаю на это реально должен быть спрос - новичкам дать возможность покупать коммерческий опыт, котирующийся у работодателей, за деньги.
@user-ty7dj4pm5b
@user-ty7dj4pm5b Год назад
Спасибо большое за ценный и подробный урок!
@user-fy5kj8hf4j
@user-fy5kj8hf4j 3 года назад
Отличный и понятный урок, спасибо!
@svetlanamazhaykina6918
@svetlanamazhaykina6918 Месяц назад
Спасибо за Ваш труд! Коммент в поддержку канала.
@user-rk1xr3cs8x
@user-rk1xr3cs8x 2 года назад
Прекрасный урок, большое спасибо!
@olegrazin3429
@olegrazin3429 3 года назад
Так вот как ты выглядишь, Alishev. Этот видео формат очень крут!
@user-hd8sc3ux7i
@user-hd8sc3ux7i 9 месяцев назад
Редко оставляю комментарии, но ты красавчик! Столько полезного материала!❤
@ykochubeev
@ykochubeev Год назад
Большое спасибо вам, очень полезное видео. Пойду поищу ваши уроки про Java
@dzmitrydarashuk6528
@dzmitrydarashuk6528 7 месяцев назад
Я человек простой, вижу новое видео Алишева - захожу, ставлю лайк!
@It_wizards
@It_wizards 2 года назад
Круто, очень доступно, красавчик!
@CyberAcidPlanet
@CyberAcidPlanet 3 года назад
Аргмент по несжимаемость JSON надуманный. Он отлично жмётся тем же gzip или brotli, где не будет проблемы того что у нас один и тот же ключ повторяется много раз (будет ссылка на этот символ при сжатии).
@leonidvolobuev7096
@leonidvolobuev7096 3 года назад
Чел ты лучший, серьезно, мне кажется если бы ты объяснял кватновую механику или молекулярную физику, даже тут все было бы предельно понятно. Огромное тебе спасибо, благодаря тебе научился действительно многому
@fedyasavchuk1043
@fedyasavchuk1043 3 года назад
Был бы очень признателен за подобные уроки по kafka и maven :)
@Denis-Orlov
@Denis-Orlov 3 года назад
Как же ж вовремя! Как раз на работе попросили замутить gRPC клиент!
@MrNil1982
@MrNil1982 3 года назад
Ща некогда, но позже обязательно погляжу. И чую новый формат зайдет (давно пора) Пока просто лайкос и низкий поклон за труд!
@AndreyMalygin
@AndreyMalygin 2 года назад
Товарищ Алишев, хочу сказать тебе, что ты крутой поц, который выручает меня в знаниях уже который раз, тебя знают половина моей группы в институте, ты уже стал некой мафией в java. Держишь уже свою нишу довольно долго, репект
@faniskhalikov9736
@faniskhalikov9736 3 года назад
Круто! Очень хорошо разобрано, заходит отлично ) Талантливый человек талантлив во многом (на заднем плане гитара и синтезатор : ) )
@ZzooD
@ZzooD 3 года назад
Классный урок, побольше бы таких )
@antondzmitruk2102
@antondzmitruk2102 3 года назад
Нет слов! Спасибо тебе огромное!
@miketuev3241
@miketuev3241 3 года назад
Супер ролик! Большое спасибо. Доходчиво и понятно.
@user-lx4dc1ls3e
@user-lx4dc1ls3e 6 месяцев назад
По моему мнению Наиль самый комфортный обозреватель по Java!!! Скорость подачи ин-фы + грамотная речь + хороший объём нового материала!!! В общем просто КЛАСС👍
@vladimirnechiporyuk2948
@vladimirnechiporyuk2948 11 месяцев назад
Афигенная штука. Теперь буду писать пет проекты только на gRPC!
@spilnich
@spilnich 3 года назад
Получил первый оффер! Спасибо огромное за grpc и все видео по Spring, кучу раз пересматривал и конспектировал.
@alishevN
@alishevN 3 года назад
Кайф!
@ivanstrelka3448
@ivanstrelka3448 2 года назад
Очень круто. Спасибо
@llARXANGELll
@llARXANGELll 2 года назад
Ух годнота. Однозначно лайк!!!
@pozystark
@pozystark 2 года назад
Хороший урок. Спасибо)
@kursruk
@kursruk 3 года назад
Отсутствие строгой типизации, это не минус, а плюс JSON. По поводу избыточности JSON. { "header":["date", "event"], "data": [ ["2020-01-14", "Событие 1"], ["2020-01-19", "Событие 2"], ["2020-01-23", "Событие N"], ] } Так, что избыточных ключей легко избежать. Также ничто не мешает гонять потоки JSON объектов по HTTP 2. Тем не менее большое спасибо за видеоролик.
@alexanderp6982
@alexanderp6982 Год назад
А теперь каждый раз пиши ручные парсеры на этот вот свой формат, который из коробки ни одна либа для работы с жсонами не поймет.
@alekcandrovich
@alekcandrovich 2 года назад
спасибо! все понятно и лаконично
@evgenkr2993
@evgenkr2993 3 года назад
супер видео! понятно преподнесено материал! спасибо!
@Nievinor
@Nievinor 3 года назад
Не знал ранее про данный механизм. Спасибо)
@user-uu7cg8mp7l
@user-uu7cg8mp7l 3 года назад
Классно!!! Спасибо большое за проделанную работу! Очень интересно слушать!
@maxim9976
@maxim9976 3 года назад
21:30 для браузера можно использовать gRPC-web. Там пока есть ряд ограничений по стримингу, но в целом рабочий вариант.
@RedkeiGost
@RedkeiGost 2 года назад
Да ну куча проблем у gRPC-web. Вот приходит вам мессаг-респонс, и нужно её прочитать. Вы делаете toObject и если в глубине есть тип google_protobuf_struct_pb.Struct то оно превратится в fieldsMap. И можно конечно на Struct юзать toJavaScript, но Struct может быть очень глубоким потомком jspb.Message и во-первы, идти через геттеры к нему крайне неудобно, а во-вторых, нам нужно все дерево и нужно как-то мержить результат toObject и его потомка. С типизацией у Struct тоже плохо - она вообще не имеет типа и это реально приводит к проблемам в typescript. В целом ну очень неудобно, имхо.
@DairaGames
@DairaGames 3 года назад
Формат кстати бомбезный. Люблю иногда посмотреть стримы от GeekBrains (Александр Фирсунов) из за того, что урок идёт на примере и больше часа.
@GT-cv3xu
@GT-cv3xu 3 года назад
Спасибо! Видео супер!
@user-iu6yz6ck6h
@user-iu6yz6ck6h 3 года назад
Отличное видео) Спасибо
@aidynabirov7728
@aidynabirov7728 2 года назад
Отличное видео !
@tuujhfjjiyiiitr5763
@tuujhfjjiyiiitr5763 Год назад
Спасибо! очень помог
@mykytafrolov
@mykytafrolov 3 года назад
Крутой урок, спасибо!
@daniyarrakhymbek5876
@daniyarrakhymbek5876 11 месяцев назад
Большое спасибо!
@indecentexposure852
@indecentexposure852 Год назад
Спасибо за видео
@antondzmitruk2102
@antondzmitruk2102 3 года назад
Ты мог бы сказать типо есть такая штука от Гугла и используйте ее вместо REST, она лучше), но ты прям с самого начала разжевал) Браво!
@lookingforthetruth5903
@lookingforthetruth5903 10 месяцев назад
Спасибо!
@Pewdew
@Pewdew 3 года назад
Послушал с удовольствием, первый раз покурить оторвался на 47й минуте))
@IgorAlov
@IgorAlov 3 года назад
json так же сжимается может deflate или gzipом, если настроено сжатие между клиентом и серверов. это прям очень стандартно. и реально эффективно это все и получается бинарно. так же весь html передается, он сжимается при передаче. посмотрите это с помощью tcpdump данные в теле буду бинарными а не текстовыми при использовании сжатия
@Das.Kleine.Krokodil
@Das.Kleine.Krokodil Год назад
Спасибо
@TeamKiller06
@TeamKiller06 3 года назад
В REST API ведь можно использовать потоковые данные через библиотеку Reactor для Spring Boot. Данные передаются через Mono и Flux. Спасибо за обзор. Все четко и доступно. Однозначно заинтересовала технология. Немного напрягает что вместо JSON используется бинарный код
@johnxibai8454
@johnxibai8454 2 года назад
Если не нравится делай на старых технологиях, и как ты собираешься организовывать стримы?
@ZIK_1337
@ZIK_1337 5 месяцев назад
привет! а как происходит версионирование proto файлов? допустим на сервере он поменялся, это же не значит, что все клиенты должны обновляться? есть какие-то версии пакетов, чтобы использовать конкретный proto файл на клиентах?
@ChamZod
@ChamZod 3 года назад
Не успел начать рест изучать, а тут уже что-то новое)
@NummeSpnet
@NummeSpnet 3 года назад
не парься, ещё долго рест будет актуален.
@gamechannel_833
@gamechannel_833 3 года назад
Не посмотрев видео, сразу ставлю лайк!
@user-vq2hi1df2i
@user-vq2hi1df2i 3 года назад
так же делаю
@MrShark123123
@MrShark123123 3 года назад
Надеюсь тема grpc будет дальше развиваться,очень нужная штука сейчас,а русскоязычных материалов нету
@p.polunin
@p.polunin Год назад
Обалдеть! 😳
@alexeymyasnichenko3318
@alexeymyasnichenko3318 2 года назад
был ли у кого затык в том, что после генерации классов из прото файла, в таргет папке все как в видео, но при имплементации возникает затык, идея просто не видит этот класс из таргета, при ручном импорте com.example.grpc* , идея не видит уже с папки example . хотя ТООЧНО она в иерархии папок в таргет файлах есть как в видео.
@eugenenovikov671
@eugenenovikov671 2 года назад
Наиль, а если мы работаем в другой IDE, где нету такого окна Maven с package, как нам тогда всё запускать?
@user-be2cy2fb9u
@user-be2cy2fb9u 2 года назад
огромное списибо
@mazeltov2701
@mazeltov2701 3 года назад
Неплохая обертка веб сокетов
@denislobanov7582
@denislobanov7582 2 года назад
Просто Вау! Такая крутая штука, а я и не знал! Спасибо автору за труд, очень хороший и нужный вводный ролик! Кстати, а почему в сервере response билдится каждую итерацию цикла? Один раз сбилдить, затем много раз отправлять. Или так нельзя?
@ramilsafin5751
@ramilsafin5751 3 года назад
С удовольствием послушал тебя, Наиль!
@ramilsafin5751
@ramilsafin5751 3 года назад
Из предложений по улучшению контента: можешь приобрести планшет или ноутбук с поддержкой стилуса (ручки) для интерактивного добавления материала поверх слайдов.
@alishevN
@alishevN 3 года назад
@@ramilsafin5751 Спасибо за фидбэк!) Подумаю над этим.
@darkstyleV
@darkstyleV 2 года назад
Просто топ)
@vladislavborisov985
@vladislavborisov985 2 года назад
У меня такой вопрос, когда мы делаем стрим данных от сервера клиенту, в этот стрим попадает 10000 сообщений, которые клиент вычитывает подключившись к серверу, если происходит перезапуск клиента то сообщения читаются с начала, а как сделать, чтобы сервер стримил сообщения которые клиент получал бы не с самого начала, а в реальном времени, т.е. со следующего отправленного после подключения клиента?
@user-fg7hf4qo8m
@user-fg7hf4qo8m 3 года назад
Никто не мешает в rest использовать бинарный формат и сжатие.
@kalashnikofsergey7064
@kalashnikofsergey7064 3 года назад
Я бы посмотрел как ты свагером нагенеришь код под бинарные сообщения
@dark_evil77
@dark_evil77 3 года назад
Я мешаю
@user-fg7hf4qo8m
@user-fg7hf4qo8m 3 года назад
@@kalashnikofsergey7064 чем? Тут ведь речь шла не об удобстве и трудозатратах, а о принципиальной возможности.
@user-ns7jq7sf1g
@user-ns7jq7sf1g 3 года назад
это помимо того, что json, как и любой текст, прекрасно жмётся апаратными средствами, прозрачно для разработчика.
@redologs
@redologs 3 года назад
Увидел тему, посмотрел длительность - лайк не глядя.
@pavelgolin2421
@pavelgolin2421 3 года назад
для приема данных с сенсоров используется mqtt, а http для веба
@Softovick
@Softovick 3 года назад
Спасибо за видео. Но вопрос возник в голове у меня - ведь если текст, то его тоже можно сжимать на лету, есть же алгоритмы. Которые достаточно эффективно и быстро сжимаю данные и вот их можно по сети гонять. По сути ведь все равно gRPC дает накладные расходы на кодировние/декодирование, в REST это можно на сжатие/распаковку тратить. Ну правде это не решает вопрос с протоколом и стримами, согласен, но тем не менее.
@tonyvegas6009
@tonyvegas6009 3 года назад
Лукас атдущи! работа с железом wanted :)
@user-df1bx3jl2c
@user-df1bx3jl2c 3 года назад
В тренде :) 👍
@dmitr8194
@dmitr8194 3 года назад
Годно, плюсую!
@cannibalirk3055
@cannibalirk3055 11 месяцев назад
некоторые зависимости из этого урока и protobuf-maven-plugin не обновлялись аж с 2018 года. есть какой-то более современный стек, заменяющий эти, очевидно, устаревшие инструменты?
@user-vc5sn3ob6c
@user-vc5sn3ob6c Год назад
Блин , хорошая лекция. Толковый лектор....
@phil2964
@phil2964 3 года назад
Наилю лайк неглядя)
@arthureirich7591
@arthureirich7591 3 года назад
Скажите, пожалуйста, в чем отличие установки соединения по HTTP 2 с последующим получением по этому соединению потока данных и сокетов? Используя сокеты тоже ведь можно установить отдельное соединение с сервером и получать по нему данные? Большое спасибо за урок!
@gregory-povorozniuk-piano
@gregory-povorozniuk-piano Год назад
HTTP и Web Sockets это разные протоколы сделанные на основе TCP
@olzhasserikbayev1155
@olzhasserikbayev1155 3 года назад
спасибо огромное за урок, очень многое для себя уловил))
@mikhail6694
@mikhail6694 3 года назад
спасибо!
@konstantinviktorovich8194
@konstantinviktorovich8194 3 года назад
Подход работы с gRPC, чем то похож с SOAP. Там на основе wsdl генерится java код, а здесь на основе proto файла. Как у клиента так и у сервера эти два файла должны быть одинаковые.
@user-vz5yr3dm7d
@user-vz5yr3dm7d 3 года назад
Спасибо большое за видео. Хочу спросить - а как задавать повторяющиеся поля?Как задать хобби в этом примере? Я постоянно отваливаюсь по OutOfBoundException
@konstantinr7632
@konstantinr7632 3 года назад
Отличные видео! Спасибо!
@nikolay7658
@nikolay7658 3 года назад
Интересная технология
@gennatok2587
@gennatok2587 7 месяцев назад
Привет. При запуске package падает ошибка "protoc did not exit cleanly. Review output for more information.". В чем может быть причина? ​
@vladimirblagin3105
@vladimirblagin3105 Год назад
24:05 Глядя как развиваются последние несколько лет нейронки, есть большая вероятность замены таких инструментов как PVS-Studio анализаторами на базе AI. Желаю ребятам скорее оседлать этого конька и включить в свой проект AI подсистему анализатора кода.
@ilyababcenco6864
@ilyababcenco6864 3 года назад
Автолайк, Наиль скажи пожалуйста когда ждать следующий урок по спрингу, ну ооочень жду там как раз на самом интересном ты остановился
@alishevN
@alishevN 3 года назад
по спрингу я записываю полный курс. выйдет через месяц-два
@user-og2ti2wd5o
@user-og2ti2wd5o Год назад
топ
@Roma4086
@Roma4086 3 года назад
а SoapUI еще используется где-нибудь?
@mahmoody8913
@mahmoody8913 Год назад
а почему можно final class наследовать, может кто-нибудь объяснить? с 35:30
@kazakhification
@kazakhification 3 года назад
Json сжимается gzip-ом разве нет?
@alishevN
@alishevN 3 года назад
даже сжатый JSON все равно занимает больше места, чем protobuf - nilsmagnus.github.io/post/proto-json-sizes/
@FastDamage
@FastDamage 3 года назад
@@alishevN Честно не много не понял,так если проблема в размере JSON,что мешает весь JSON прогнать через protobuf и отправить? я ничего не имею против gRpc но в большом проекте где под 1000+ методов которые взаимодействуют с различными микросервисами замучаешься всё описывать в .proto (для такой задачи надо нанимать отдельно человека на должность mapper ;) )
@mishashins
@mishashins 3 года назад
@@FastDamage у нас в C# можно описывать интерфейсы)
@brunneng8575
@brunneng8575 3 года назад
Автор даёт ссылку на тесты. Там видно что при коротких сообщениях прото дает выигрыш. Однако на больших сообщениях явно теряет преимущество. Я думаю что нужно ещё больше тестов. Повысить энтропию данных, зажать их и посмотреть что получиться. Есть шанс что в разных ситуациях, в разных задачах придется выбирать между прото или json вариантом, так как есть зависимость от объема данных и рассеивании. Аргумент того что json сжатие требует процессорное время, такое себя, так как любое сжатие этого требует. Нужно больше хороших синтетических тестов и тестов из жизни, реальных проектов. Но по мне, пока что, JSON выглядит лучше, даже если на коротких сообщениях проигрывает.
@kamurashev
@kamurashev 3 года назад
Как скопировать джава RMI в другие языки и ни кому не говорить. Структура 1 в 1. И этой штуке 100 лет в обед. Я еще не родился. За видео лайк.
@dmsa9404
@dmsa9404 3 года назад
Прикольно... я уже хотел написать что-то из серии так это уже проходили с WSDL а тут и скорость выше раз в 10 и тыры пыры
@k0rinf
@k0rinf 3 года назад
Поясните как контролить версии прото файла!? Как сервисы должны понять что он обновился и нужно его поменять и перегенерить код!?
Далее
Kotlin за час. Теория и практика.
1:21:33
Что такое gRPC и Protobuf?
8:37
Просмотров 37 тыс.
gRPC Crash Course - Modes, Examples, Pros & Cons and more
1:19:38
gRPC 101 for Java Developers by Ray Tsang
55:17
Просмотров 25 тыс.
What is RPC? gRPC Introduction.
6:09
Просмотров 448 тыс.