Hi Folks! If you are interested, I'm currently developing a new course - building a gRPC Microservice in Go which you can find here - tutorialedge.net/courses/go-grpc-services-course/ This covers everything from project setup and layout, testing, and best practices around things like versioning.
@nicolotafta71507 ай бұрын
Has been past 4 years but most well done video on the gRPC! gj
@alpaslaneldemir69044 жыл бұрын
Thanks for the Tutorial. A stream example would be a nice one for next. Broadcasting a gıven message to all connected clients.
@wkdj2522 Жыл бұрын
extremely well done. i had no idea what gRPC was; now i do. thanks!
@ericb2523 жыл бұрын
This is invaluable. This really helps so many of us. Thank you!
@jayeshthamke78604 жыл бұрын
Good work!! Could you bring a tutorial in golang/context package with its real use in application? Thanks
@Tutorialedge4 жыл бұрын
Great suggestion!
@alexveeuk4 жыл бұрын
This was a very useful tutorial thank you 👌! I would be grateful if you could you show us stream examples and maybe connecting it to MongoDB with how to bind them to primitives using todos as an example would be awesome!
@ixaran4 жыл бұрын
are you mobile developer?
@Csc5csc53 жыл бұрын
I'm following along and ran into some issues: using go v1.16 in VSCode with the go helpers installed. At 10:39 I'm being told that *Message is not defined. It's my understanding that the `package chat` declaration in both the chat.go and chat.pb.go meant that no import was required. Further, at 13:25 line 21 I'm being told RegisterChatServiceServer is not declared by the chat package. The package is definitely imported, as autocomplete suggested the method. Is there something happening due to differing versions of Go between the video here and what I'm using, or do I need to look for issues elsewhere?
@Csc5csc53 жыл бұрын
Figured out half of it - chat.proto requires a line: `option go_package = ".;chat";` to be included. Still stuck on server.go ln 21: passing &s into RegisterChatServiceServer, but I'm sure I'll figure it out.
@sreerampanigrahi2 жыл бұрын
@@Csc5csc5 Hey! I've found the fix and putting it here so that it helps someone in future. Basically we need to embed the field. i.e. Add this part in the chat.go file and it should work fine type Server struct { ChatServiceServer }
@nazarpysko2 жыл бұрын
Try compiling the proto file with this command too: protoc --go-grpc_out=./ chat.proto It generates another pb file and it contains all the functions shown on the video. There are few other changes that must be made. Search for my comment for more details.
@albinbackstrom92972 жыл бұрын
I could not get the protoc command work from this video. Had to run it like this: protoc -I. --go_out=. --go-grpc_out=require_unimplemented_servers=false:. chat.proto and also add this to the .proto file option go_package = "./chat";
@gdgo61662 жыл бұрын
this was helpful! you should be pinned so other people can be unblocked faster
@andrewklein3349 Жыл бұрын
banger comment, saved me tearing my hair out
@mystica7284 Жыл бұрын
you are lifesaver dude!! thanks
@GodofStories Жыл бұрын
Great tutorial. Appreciate your video, and some of the other helpful comments
@Omar-hw7zi3 жыл бұрын
Thanks, very simple example. Straight to the point!
@jordansilva153 жыл бұрын
Thank you for the video, really usefull, there is so few quality learning material on this topic, this tutorial helped me a lot.
@pedroramos57153 жыл бұрын
Thanks for this.
@pedroramos57153 жыл бұрын
I just couldn't generate protoc code without stating explicitly the option "go_package" in my .proto file
@georgelza3 жыл бұрын
I had the same, it seems the standards have changed, and this is now required, similar to the go.mod that is now compulsory
@WaldirBorbaJunior4 жыл бұрын
Amazing content. tks for sharing
@Rcls01Ай бұрын
Kewl. Thanks for clarifying a few things!
@hanzohasashi30252 жыл бұрын
Great video. Btw what vscode theme are you using?
@politicsmovies64224 жыл бұрын
tq for this tutorial
@VaibhavPatil-rx7pc4 жыл бұрын
Excellent !!!
@muzammilsyed2339 Жыл бұрын
Can I get your vscode settings? Theme, font family, line height everything looks very clean
@chrisreplogle61724 жыл бұрын
Thank you for great content!
@mecamonАй бұрын
Thank you so much!
@grudgemudgen54884 жыл бұрын
Excellent tutorial! 👏🏼 I look forward to more from you :-)
@xtapa32713 жыл бұрын
If I was to consume an api as a client, I assume I would just look at what the output of the api is (in api documentation e.g.), define my own chat.proto like I would define my own json model struct in rest, and then it just works the same way? And would the chat.Server be my place for dependency injections? If so, this seems so lightweight and convenient.
@enjili60623 жыл бұрын
When I followed, protoc --go_out=. *.proto, I got error below. How should I fix this? protoc-gen-go: unable to determine Go import path for "chat.proto" Please specify either: • a "go_package" option in the .proto source file, or • a "M" argument on the command line.
@enjili60623 жыл бұрын
Oh, simply add `option go_package = "example.com/dummy"` would work
@otabek77513 жыл бұрын
@@enjili6062 ive spent like 5 hrs to solve this...(
@empaguia3 жыл бұрын
oh hi' @@enjili6062 where to add this?
@pinkmmaggit14482 жыл бұрын
You'd also want to use this URL instead of his for "go mod init" and so on, starting at 10:48
@venil824 жыл бұрын
would you store generated pb.go file in git or exclude it? how do you share a contract between server and client, and keep them in sync ?
@Tutorialedge4 жыл бұрын
One approach I've seen used in production environments is to have a monorepo that contains all of your compiled files in every language that teams in your company develop in. You then follow appropriate versioning in order to ensure that any breaking changes are done under new versions and don't break existing applications using these compiled files. Let me know if this helps! I'm actually planning on doing a more comprehensive series in the near future!
@PrashantShekher4 жыл бұрын
Great, Do you have any idea run the same code with docker container?
@amirhasanbasic21934 жыл бұрын
Would we implement this Sayhello function in the same package chat in produciton, because it seems reasonable that we would implement it in other package so we "hide implementation" from client, this way client could just call the function without having to use RPC... correct me if i'm wrong
@DavidAlsh2 жыл бұрын
So the Go protoc plugin will always generate Go service interface method definitions with context.Context as the first argument?
@neiluli83294 жыл бұрын
Awesome !
@0xcoder5422 жыл бұрын
@TutorialEdge - Thank you for creating such a nice tutorial video about GRPC. I found one issue while following the video. The "option go_package" missing in the Proto file? Please advise
@vtvvnha22304 жыл бұрын
how to use grpc with envoy proxy
@Tutorialedge4 жыл бұрын
That was just an example, on having a look, there is an excellent go package called grpc-gateway which can act as a proxy for HTTP requests through to your gRPC service - github.com/grpc-ecosystem/grpc-gateway
@raco954 жыл бұрын
@@Tutorialedge grpcwebproxy by improbable is a lot easier to use than envoy, not sure about the one you linked but it's worth giving a shot. no extra set up, just list the port of your grpc server and you're good to go github.com/improbable-eng/grpc-web/tree/master/go/grpcwebproxy
@codelucky4 жыл бұрын
REST VS GRPC VS GRAPHQL? Choose one and why?
@sanjanaprakash16484 жыл бұрын
Thank you for the video, very useful. One doubt, server.go and client.go both have main functions and they are in the same package. How does this work? Sorry I'm a newbie to Golang, so don't know much. It'll be great if anyone could clear the doubt.
@georgelza3 жыл бұрын
if you execute go run . then you would have a problem, but as you're executing go run server.go it only looks internal to that file, it's not aware of the main package in client.go
@HSharpknifeedge2 жыл бұрын
Thank you !
@nikta4564 жыл бұрын
Getting a `Missing 'go_package' option in "chat.proto` after running a `protoc --go_out=plugins=grpc:chat chat.proto` (Win 10). Any suggestions?
@nikta4564 жыл бұрын
Was able to fix it by adding `option go_package = "github.com/monkrus/grpc-from0;grpc_from0";` line. Walkthrough of this great tutorial is here github.com/monkrus/grpc-from0
@bulsyt99032 жыл бұрын
Nice video 🔥 can golang grpc use a different package between server and client?
@seoch20644 жыл бұрын
When generating chat.pb.go, my file is different from the one the video shows. For instance, I don't have the Marshall and Unmarshall functions, what could be causing this?
@rinosukmandityo64484 жыл бұрын
I think that because different version of protoc or protoc-gen-go. And that should not cause a problem IMO.
@kirayamato6128 Жыл бұрын
im new to go. what is the meaning of %v? ty in advance
@prasannadiwadkar81534 жыл бұрын
chat.pb.go. How should i import this in another go file ?
@milakay4 жыл бұрын
Add the following to your import statement in client.go and server.go: "./chat"
@umeshsunnapu2 жыл бұрын
very helpful. just one edit compared to when this is recorded vs current releases of protoc, proto-gen-go-grpc etc. I believe executing protoc command, did not add package name in chat.pb.go and instead had it like ___. Change that to "chat"
@gabrielmsampson8 ай бұрын
What theme is this?
@palashbhasme39002 ай бұрын
it gives main redeclared in error
@codelucky4 жыл бұрын
gRPC vs GraphQL ? With Go.
@Tutorialedge4 жыл бұрын
Thanks for the suggestion! I'm not sure I could do a direct comparison on these two technologies though as they approach 2 different problem domains. In fact, I believe they could be used together, where a GraphQL application talks to a gRPC server in order to retrieve some of the data!
@codelucky4 жыл бұрын
@@Tutorialedge There are not many courses available on gRPC with Go. I wonder why? Is it because of its low popularity or due to any technical reason? Or is it difficult to implement than GraphQL?
@Zapanath4 жыл бұрын
LucKie they have different use cases...
@jayeshthamke78604 жыл бұрын
@@codelucky Though there are less tutorial doesn't mean gRPC is less popular or has no usecase. In Kubernetes, they use gRPC to communicate and data transfer within cluster
@anilchaudhry8043 жыл бұрын
can you please come up with some real world microservice using golang? It helps a lot especially for young developers. Lets build from scratch??
@Tutorialedge3 жыл бұрын
This is a great idea and something I will be doing on my site in the form of a course! I've got a couple of real-world examples I want to solve myself, so building courses around these adventures would be great :)
@vtvvnha22304 жыл бұрын
thank you
@abbyck4 жыл бұрын
Thanks
@srikantprasad67114 жыл бұрын
Thanks for this video. Sir if you want to create a tutorial. Please create tutorial on gomobile. How to create mobile app in golang.
@tnvmadhav24424 жыл бұрын
👏🏻
@AndiSyafrianda4 жыл бұрын
jejak gans
@BrackenDawson2 жыл бұрын
context has been in the standard library for a long time..
@Suriprofz Жыл бұрын
grpc is undefined
@NancyLopez-g8n2 ай бұрын
Sheila Knoll
@benwatson963310 ай бұрын
thank you 2x speed
@Tutorialedge10 ай бұрын
Most people struggle with my Scottish accent so I do find myself slowing down when recording 😂
@ElizabethPerez-t8w3 ай бұрын
Josephine Lodge
@creddym13 жыл бұрын
super youtube why beacuse he put in youtube vidio thanks all youtube
@abdulrahmanmohmmd1029 Жыл бұрын
For those who having error in the new version with generation thr grpc files Run protoc -proto_path=. *.proto -go_out=. -go-grpc_out=.
@ExiNani Жыл бұрын
help a lot
@bharathram397717 күн бұрын
How is this even a good tutorial? He is typing out lines and lines of code without explaining how everything ties together. Commenters are either wayyy too smart or they are bots
@hackaholic0110 ай бұрын
sorry Man, but I have to say grpc are shiny and fancy words, TCP is simple and more efficient than grpc
@Tutorialedge10 ай бұрын
gRPC is typically built on-top of TCP and is one of the highest performance methods of transportation available due to the fact you are sending far smaller amounts of information (typically) than say JSON over HTTP. In terms of simplicity, I’d 100% agree with the statement that JSON over HTTP wins every day of the week. I’ve seen both sides of the coin and definitely lean more towards JSON over HTTP for all applications that don’t demand the absolute highest of performance.
@sammyj293 ай бұрын
My chat.pb.go doesn't have the RegisterChatServiceServer function for some reason. Am I doing something wrong?
@RalphTruman-e4s3 ай бұрын
6537 Fred Passage
@creddym13 жыл бұрын
This was a very useful tutorial thank you 👌! I would be grateful if you could you show us stream examples and maybe connecting it to MongoDB with how to bind them to primitives using todos as an example would be awesome!