Don't cap GOMAXPROCS at 4.

Before Go 1.5, GOMAXPROCS defaulted to 1, hence it made
sense to unconditionally increase it to 4.

But since Go 1.5, GOMAXPROCS defaults to the number of cores,
so don't keep it from increasing above 4.

Also, update the performance numbers.
This commit is contained in:
Jakob Unterwurzacher 2017-06-01 20:53:03 +02:00
parent f44902aaae
commit 53b7c17261
2 changed files with 8 additions and 2 deletions

View File

@ -28,6 +28,7 @@ v1.2.1-33 112 21 12 1.6 4.4 (go1.8)
v1.2.1-33 v1.2.1-33
-serialize_reads 116 21 39 1.5 4.4 -serialize_reads 116 21 39 1.5 4.4
v1.3-27 113 20 11 1.4 4.2 v1.3-27 113 20 11 1.4 4.2
v1.3-53-gf44902a 119 19 12 1.6 4.1
Results for EncFS for comparison (benchmark.bash -encfs): Results for EncFS for comparison (benchmark.bash -encfs):

View File

@ -11,6 +11,8 @@ import (
"strings" "strings"
"time" "time"
"github.com/hanwen/go-fuse/fuse"
"github.com/rfjakob/gocryptfs/internal/configfile" "github.com/rfjakob/gocryptfs/internal/configfile"
"github.com/rfjakob/gocryptfs/internal/contentenc" "github.com/rfjakob/gocryptfs/internal/contentenc"
"github.com/rfjakob/gocryptfs/internal/exitcodes" "github.com/rfjakob/gocryptfs/internal/exitcodes"
@ -18,7 +20,6 @@ import (
"github.com/rfjakob/gocryptfs/internal/speed" "github.com/rfjakob/gocryptfs/internal/speed"
"github.com/rfjakob/gocryptfs/internal/stupidgcm" "github.com/rfjakob/gocryptfs/internal/stupidgcm"
"github.com/rfjakob/gocryptfs/internal/tlog" "github.com/rfjakob/gocryptfs/internal/tlog"
"github.com/hanwen/go-fuse/fuse"
) )
// GitVersion is the gocryptfs version according to git, set by build.bash // GitVersion is the gocryptfs version according to git, set by build.bash
@ -111,7 +112,11 @@ func printVersion() {
} }
func main() { func main() {
mxp := runtime.GOMAXPROCS(0)
if mxp < 4 {
// On a 2-core machine, setting maxprocs to 4 gives 10% better performance
runtime.GOMAXPROCS(4) runtime.GOMAXPROCS(4)
}
var err error var err error
// Parse all command-line options (i.e. arguments starting with "-") // Parse all command-line options (i.e. arguments starting with "-")
// into "args". Path arguments are parsed below. // into "args". Path arguments are parsed below.