Введение в gRPC: пишем сервер на Go
HTML-код
- Опубликовано: 4 авг 2019
- В этом видео я расскажу про gRPC. Мы с вами попробуем написать простой gRPC-сервер на Go, который будет складывать два числа и возвращать результат этой операции.
Ссылки из видео:
- Evans (gRPC-клиент) - github.com/ktr0731/evans
Мой Twitter - / atipugin
Канал в TG - t.me/someoneistyping
#golang #gopherschool
Хороший урок, сделайте серию уроков по созданию микросервисов.
Спасибо, таких каналов не хватает
Всё супер! Автору большой зачёт!!!
Здравствуйте, спасибо за видео! Очень помогло: узнал про эванс, разобрался с протобафом. С меня подписка :)
Кросс, голос приятный , удачи тебе и лайк!
Команда для генерация протокола бафера уже не работает как на данном видео, думаю устарели, как никак видео 3 года, рабочий вариант
protoc --proto_path=proto proto/*.proto --go_out=. --go-grpc_out=.
и если вы щас будете действовать по инструкции, то в структуру GRPCServer необходимо также добавить интерфейс UnimplementedInventoryServer так как без него функция RegisterInventoryServer будет ругаться
также помимо evans вы можете скачать BloomRPC. принцип такой же как и Evans только туда необходимо загрузить прото файл
А так автору огромное спасибо, очень полезное видео
Лайк. Выложил ссылку на ролик. Ждём продолжения
Спасибо!
отличная подача материала
Спасибо!
Годнота. Перевожу свой пет проект на grpc, два микросервиса, с вебсокетами ковыряться не хочу, а данные нужно, чтобы потоком моментально прилетали
Удобненько. Не надо вручную прописывать много вещей
Спасибо. Жаль что уже не все актуально.
Можно ли заменить MQ на gRPC? Как у gRPC с отказоустойчиватью? Спасибо!
Привет! Почему у меня нет интерфейса AdderClient с методом Add? Откуда это вообще взялось? В кратце пожалуйста поясни как получить подобные методы. В .proto мы это не указываем, на что оно ссылается?
gRPC использует протокол http2 так, а зачем поверх http2 что-то еще нужно? если оно и так может например через Rest ? я бы понял, что это чистый TCP или UDP чтобы быстрее все было.
Подскажите, почему для генерации файла pb.go мне необходимо добавить в proto файл строку option go_package = "./"; Без этого выдается ошибка: protoc-gen-go: unable to determine Go import path for "proto/reverse.proto"
Please specify either:
• a "go_package" option in the .proto source file, or
• a "M" argument on the command line.
Если добавить, как говорится в ошибке, то все работает. Я не понимаю зачем надо дополнительно определять go_package
Этому видео 2 года. Протокол поменял свою работу. Лучше читать документацию.
ruclips.net/video/z-mHhobE0Pw/видео.html
Видимо пакет обновился - правильная команда
protoc --proto_path=api/proto --go-grpc_out=pkg/api api/proto/adder.proto
Хотелось бы осветить логирование и обработку ошибок в grpc
Комфортно смотреть на скорости 1.5
Подскажи сколько у тебя опыта в Golang
Около 3-х лет. Правда, основным у меня всегда был Ruby, го скорее хобби.
Есть смысл настраивать concurrency на grcp сервере?
В целом настраивать ничего не надо, из коробки всё работает, по аналогии с http-сервером каждый хендлер отрабатывает в своей горутине. Подробнее можно глянуть тут -
github.com/grpc/grpc-go/blob/master/Documentation/concurrency.md
что за тема и как сделать != как у тебя ?
подскажите пожалуйста, при выполнении команды protoc -I api/proto --go-out=plugins=grpc:pkg/api api/proto/adder.proto я получаю ошибку: Unknown flag: --go-out
--go_out :)
Бро, напили уроки по Go kit
Grpc-gateway i swagger plugini ochenj oblegchaet sozdanie REST/gRPC API servisov.
Глянул grpc-gateway, выглядит интересно! Надо будет с ним более детально разобраться.
@@GopherSchool Esli pravilno pomnju, to eta bila dovolno horoshaja statja - medium.com/@amsokol.com/tutorial-how-to-develop-go-grpc-microservice-with-http-rest-endpoint-middleware-kubernetes-daebb36a97e9
грамотный урок
что за плагин на подсветку ошибок если нету комментариев?
Сейчас обновили protoc, потому видео немного неактуально, теперь не нужно указывать плагин
Привет! а какой командой запускаться? у меня go_packages не находит ошибка какая то?
@@TheDooMep привет, вероятнее всего ты не выполнил все шаги с сайта где описано как использовать gRPC для Go и не сделал нужные go get`ы и go install`ы. Или возможно неправильно указаны переменные окружения gopath и gobin .
Как установить Protocol Buffers под windows 10
Wsl + (vscode + devcontainer)
Попробуй посмотреть свой ролик на телефоне.
Попробовал. Что не так?
Видимо не посмотрел. Объясню на пальцах. Сегодня много контента смотрят на телефонах не большого размера. Когда сидишь на ретине этого не замечаешь. Снимать экран нужно на разрешении 1280х1080 или 1024х786. Шрифты нужно делать такие чтобы студент на телефоне мог в метро смотреть.
Да, желательно делать шрифт в редакторе больше
@@AlexSuslov Сколько язвы. Вы еще не отравились от своей же собственной токсичности?
@@youtubeperversions у меня пониженная кислотность.
Ошибки в файле adder_grpc.pb.go - undefined: AddRequest и undefined: AddResponse.