Fix CreatePages
authorNate Finch <nate.finch@gmail.com>
Fri, 29 Aug 2014 17:40:21 +0000 (13:40 -0400)
committerspf13 <steve.francia@gmail.com>
Sat, 30 Aug 2014 05:02:35 +0000 (01:02 -0400)
commit47c91a4ca2ac3db496b9d495757eda121b612bec
treeb6dc3e77bc144341b5f6b499d1958a2fb4fb5907
parent93addfcbeec301e4f37b0f83bc5735f1939f1895
Fix CreatePages

This fixes #450.  There are two problems:

1.) We're creating a new goroutine for every page.
2.) We're calling s.Pages = append(s.Pages, page) inside each goroutine.

1 is a problem if in that if you have a ton of pages, that's a ton of goroutines.  It's not really useful to have more than a few goroutines at a time, and lots can actually make your code much slower, and, evidently, crash.

2 is a problem in that append is not thread safe. Sometimes it returns a new slice with a larger capacity, when the original slice isn't large enough.  This can cause problems if two goroutines do this at the same time.

The solution for 1 is to use a limited number of workers (I chose 2*GOMAXPROCS as a nice guess).
The solution for 2 is to serialize access to s.Pages, which I did by doing it in a single goroutine.
hugolib/site.go