I'm a new Go programmer, coming from the world of web application and service development. Apologies is this is a herp de-derp question, but my googling around for an answer hasn't found anything. Also, this is borderline Server Fault territory, but since I'm more interested in the APIs/programmatic interfaces I'm asking here.
I've written a small go program using the net/http
package's built-in web server. I'm getting ready to deploy to production, but I'm a little unclear on the process of model go Go's web-server and how I should deploy.
Specifically -- in the environments I'm used to (PHP, Ruby, Python) we have a web server (Apache, Nginx, etc.) sitting in front of our application, and we configure these web servers to use a certain number of worker processes/threads, and configure how many individual HTTP(S) connections each thread should process.
I haven't been able to find information on how Go's web-server handles this, or practical information on how to scale/plan-for-scale for a Go web server.
i.e. -- if I have a simple program running, ready to handle an HTTP request
func main() {
http.HandleFunc("/", processRequest)
http.ListenAndServe(":8000", nil)
}
how many connections will HandleFunc
try to handle at once? Or will it start blocking when a connection opens, and only serve the next connection once the connection closes?
Or should I just not worry about this and jam everything into a go routine? But if I do that how do I prevent the system from becoming bogged down by too many threads of execution?
I'm basically trying to
- Understand the process mode of the go web server
- Find the built-in features of go for tweaking this, and/or whatever standard package folks are using
Like I said, I'm very new to go, so if I'm completely missing the plot on this please let me know!
See Question&Answers more detail:os