Home >Backend Development >Golang >Protogen Goroutine stack exceeds
php Xiaobian Yuzai today will introduce to you a problem related to Protogen: the situation when the Goroutine stack exceeds. When developing with Protogen, sometimes you will encounter an error message indicating that the Goroutine stack exceeds. The occurrence of this problem may cause program crashes or performance degradation. So, why does this problem occur and how to solve it? Next, we will answer them one by one.
Recently I encountered a code generation problem in golang. I have a huge raw file and now need to add logging to most of the messages using an external package. However, if I add logging for too many fields, it panics and says the goroutine stack is exceeded. Is there a way to generate code in chunks, or just increase the maximum cache size of generated goroutines?
I tried debug.SetMaxStack and running the build command with go code but nothing changed, it didn't seem like a good solution to me
It turns out, The problem is, as @BurakSerdar said in the comment about the recursive print loop. So if you have something like:
message human { string name = 1; human child = 2; human parent = 3; }
You shouldn’t do this:
message human { string name = 1; human child = 2 [(logger.field) = true]; human parent = 3; }
I believe the same goes for other customizations you want to add to fields, if you have a message that contains a field with the same message type
The above is the detailed content of Protogen Goroutine stack exceeds. For more information, please follow other related articles on the PHP Chinese website!