Введение в gRPC: пишем сервер на Go
В этом видео я расскажу про gRPC. Мы с вами попробуем написать простой gRPC-сервер на Go, который будет складывать два числа и возвращать результат этой операции.
Ссылки из видео:
- Evans (gRPC-клиент) - github.com/ktr0731/evans
Мой Twitter - / atipugin
Канал в TG - t.me/someoneistyping
#golang #gopherschool
Пікірлер: 58
Хороший урок, сделайте серию уроков по созданию микросервисов.
Спасибо, таких каналов не хватает
Кросс, голос приятный , удачи тебе и лайк!
Лайк. Выложил ссылку на ролик. Ждём продолжения
@GopherSchool
4 жыл бұрын
Спасибо!
Здравствуйте, спасибо за видео! Очень помогло: узнал про эванс, разобрался с протобафом. С меня подписка :)
Всё супер! Автору большой зачёт!!!
Команда для генерация протокола бафера уже не работает как на данном видео, думаю устарели, как никак видео 3 года, рабочий вариант protoc --proto_path=proto proto/*.proto --go_out=. --go-grpc_out=. и если вы щас будете действовать по инструкции, то в структуру GRPCServer необходимо также добавить интерфейс UnimplementedInventoryServer так как без него функция RegisterInventoryServer будет ругаться также помимо evans вы можете скачать BloomRPC. принцип такой же как и Evans только туда необходимо загрузить прото файл А так автору огромное спасибо, очень полезное видео
отличная подача материала
@GopherSchool
2 жыл бұрын
Спасибо!
Годнота. Перевожу свой пет проект на grpc, два микросервиса, с вебсокетами ковыряться не хочу, а данные нужно, чтобы потоком моментально прилетали
Спасибо. Жаль что уже не все актуально.
Удобненько. Не надо вручную прописывать много вещей
gRPC использует протокол http2 так, а зачем поверх http2 что-то еще нужно? если оно и так может например через Rest ? я бы понял, что это чистый TCP или UDP чтобы быстрее все было.
Комфортно смотреть на скорости 1.5
Хотелось бы осветить логирование и обработку ошибок в grpc
kzread.info/dash/bejne/rGGhqsqokqiWgNo.html Видимо пакет обновился - правильная команда protoc --proto_path=api/proto --go-grpc_out=pkg/api api/proto/adder.proto
Можно ли заменить MQ на gRPC? Как у gRPC с отказоустойчиватью? Спасибо!
Подскажите, почему для генерации файла 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
@dasydasy9268
2 жыл бұрын
Этому видео 2 года. Протокол поменял свою работу. Лучше читать документацию.
Привет! Почему у меня нет интерфейса AdderClient с методом Add? Откуда это вообще взялось? В кратце пожалуйста поясни как получить подобные методы. В .proto мы это не указываем, на что оно ссылается?
Grpc-gateway i swagger plugini ochenj oblegchaet sozdanie REST/gRPC API servisov.
@GopherSchool
4 жыл бұрын
Глянул grpc-gateway, выглядит интересно! Надо будет с ним более детально разобраться.
@Oswee
4 жыл бұрын
@@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
Бро, напили уроки по Go kit
Сейчас обновили protoc, потому видео немного неактуально, теперь не нужно указывать плагин
@TheDooMep
2 жыл бұрын
Привет! а какой командой запускаться? у меня go_packages не находит ошибка какая то?
@user-jk9jo1kg9o
2 жыл бұрын
@@TheDooMep привет, вероятнее всего ты не выполнил все шаги с сайта где описано как использовать gRPC для Go и не сделал нужные go get`ы и go install`ы. Или возможно неправильно указаны переменные окружения gopath и gobin .
Подскажи сколько у тебя опыта в Golang
@GopherSchool
4 жыл бұрын
Около 3-х лет. Правда, основным у меня всегда был Ruby, го скорее хобби.
Есть смысл настраивать concurrency на grcp сервере?
@GopherSchool
4 жыл бұрын
В целом настраивать ничего не надо, из коробки всё работает, по аналогии с 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
@timickb
Жыл бұрын
--go_out :)
что за плагин на подсветку ошибок если нету комментариев?
Как установить Protocol Buffers под windows 10
@user-jd2xr7bf2t
Жыл бұрын
Wsl + (vscode + devcontainer)
Попробуй посмотреть свой ролик на телефоне.
@GopherSchool
4 жыл бұрын
Попробовал. Что не так?
@AlexSuslov
4 жыл бұрын
Видимо не посмотрел. Объясню на пальцах. Сегодня много контента смотрят на телефонах не большого размера. Когда сидишь на ретине этого не замечаешь. Снимать экран нужно на разрешении 1280х1080 или 1024х786. Шрифты нужно делать такие чтобы студент на телефоне мог в метро смотреть.
@alezyyy
4 жыл бұрын
Да, желательно делать шрифт в редакторе больше
@youtubeperversions
3 жыл бұрын
@@AlexSuslov Сколько язвы. Вы еще не отравились от своей же собственной токсичности?
@AlexSuslov
3 жыл бұрын
@@youtubeperversions у меня пониженная кислотность.
Ошибки в файле adder_grpc.pb.go - undefined: AddRequest и undefined: AddResponse.