Commit d3c59f6e authored by Mikio Hara's avatar Mikio Hara

net: make use of the kernel state to listen on TCP, Unix

R=golang-dev, dave, minux.ma
CC=golang-dev
https://golang.org/cl/5545044
parent c4031482
...@@ -36,6 +36,7 @@ GOFILES_darwin=\ ...@@ -36,6 +36,7 @@ GOFILES_darwin=\
port.go\ port.go\
sendfile_stub.go\ sendfile_stub.go\
sock.go\ sock.go\
sock_bsd.go\
sockopt.go\ sockopt.go\
sockopt_bsd.go\ sockopt_bsd.go\
sockoptip.go\ sockoptip.go\
...@@ -68,6 +69,7 @@ GOFILES_freebsd=\ ...@@ -68,6 +69,7 @@ GOFILES_freebsd=\
port.go\ port.go\
sendfile_stub.go\ sendfile_stub.go\
sock.go\ sock.go\
sock_bsd.go\
sockopt.go\ sockopt.go\
sockopt_bsd.go\ sockopt_bsd.go\
sockoptip.go\ sockoptip.go\
...@@ -99,6 +101,7 @@ GOFILES_linux=\ ...@@ -99,6 +101,7 @@ GOFILES_linux=\
port.go\ port.go\
sendfile_linux.go\ sendfile_linux.go\
sock.go\ sock.go\
sock_linux.go\
sockopt.go\ sockopt.go\
sockopt_linux.go\ sockopt_linux.go\
sockoptip.go\ sockoptip.go\
...@@ -130,6 +133,7 @@ GOFILES_netbsd=\ ...@@ -130,6 +133,7 @@ GOFILES_netbsd=\
port.go\ port.go\
sendfile_stub.go\ sendfile_stub.go\
sock.go\ sock.go\
sock_bsd.go\
sockopt.go\ sockopt.go\
sockopt_bsd.go\ sockopt_bsd.go\
sockoptip.go\ sockoptip.go\
...@@ -155,6 +159,7 @@ GOFILES_openbsd=\ ...@@ -155,6 +159,7 @@ GOFILES_openbsd=\
port.go\ port.go\
sendfile_stub.go\ sendfile_stub.go\
sock.go\ sock.go\
sock_bsd.go\
sockopt.go\ sockopt.go\
sockopt_bsd.go\ sockopt_bsd.go\
sockoptip.go\ sockoptip.go\
...@@ -184,6 +189,7 @@ GOFILES_windows=\ ...@@ -184,6 +189,7 @@ GOFILES_windows=\
lookup_windows.go\ lookup_windows.go\
sendfile_windows.go\ sendfile_windows.go\
sock.go\ sock.go\
sock_windows.go\
sockopt.go\ sockopt.go\
sockopt_windows.go\ sockopt_windows.go\
sockoptip.go\ sockoptip.go\
......
...@@ -91,11 +91,6 @@ func favoriteAddrFamily(net string, raddr, laddr sockaddr, mode string) int { ...@@ -91,11 +91,6 @@ func favoriteAddrFamily(net string, raddr, laddr sockaddr, mode string) int {
return syscall.AF_INET6 return syscall.AF_INET6
} }
// TODO(rsc): if syscall.OS == "linux", we're supposed to read
// /proc/sys/net/core/somaxconn,
// to take advantage of kernels that have raised the limit.
func listenBacklog() int { return syscall.SOMAXCONN }
// Internet sockets (TCP, UDP) // Internet sockets (TCP, UDP)
// A sockaddr represents a TCP or UDP network address that can // A sockaddr represents a TCP or UDP network address that can
......
...@@ -14,6 +14,8 @@ import ( ...@@ -14,6 +14,8 @@ import (
"syscall" "syscall"
) )
var listenerBacklog = maxListenerBacklog()
// Generic socket creation. // Generic socket creation.
func socket(net string, f, p, t int, la, ra syscall.Sockaddr, toAddr func(syscall.Sockaddr) Addr) (fd *netFD, err error) { func socket(net string, f, p, t int, la, ra syscall.Sockaddr, toAddr func(syscall.Sockaddr) Addr) (fd *netFD, err error) {
// See ../syscall/exec.go for description of ForkLock. // See ../syscall/exec.go for description of ForkLock.
......
// Copyright 2009 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
// +build darwin freebsd netbsd openbsd
// Sockets for BSD variants
package net
import (
"runtime"
"syscall"
)
func maxListenerBacklog() int {
var (
n uint32
err error
)
switch runtime.GOOS {
case "darwin", "freebsd":
n, err = syscall.SysctlUint32("kern.ipc.somaxconn")
case "netbsd":
// NOTE: NetBSD has no somaxconn-like kernel state so far
case "openbsd":
n, err = syscall.SysctlUint32("kern.somaxconn")
}
if n == 0 || err != nil {
return syscall.SOMAXCONN
}
return int(n)
}
// Copyright 2009 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
// Sockets for Linux
package net
import "syscall"
func maxListenerBacklog() int {
fd, err := open("/proc/sys/net/core/somaxconn")
if err != nil {
return syscall.SOMAXCONN
}
defer fd.close()
l, ok := fd.readLine()
if !ok {
return syscall.SOMAXCONN
}
f := getFields(l)
n, _, ok := dtoi(f[0], 0)
if n == 0 || !ok {
return syscall.SOMAXCONN
}
return n
}
// Copyright 2009 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
// Sockets for Windows
package net
import "syscall"
func maxListenerBacklog() int {
// TODO: Implement this
return syscall.SOMAXCONN
}
...@@ -249,10 +249,10 @@ func ListenTCP(net string, laddr *TCPAddr) (l *TCPListener, err error) { ...@@ -249,10 +249,10 @@ func ListenTCP(net string, laddr *TCPAddr) (l *TCPListener, err error) {
if err != nil { if err != nil {
return nil, err return nil, err
} }
errno := syscall.Listen(fd.sysfd, listenBacklog()) err = syscall.Listen(fd.sysfd, listenerBacklog)
if errno != nil { if err != nil {
closesocket(fd.sysfd) closesocket(fd.sysfd)
return nil, &OpError{"listen", "tcp", laddr, errno} return nil, &OpError{"listen", "tcp", laddr, err}
} }
l = new(TCPListener) l = new(TCPListener)
l.fd = fd l.fd = fd
......
...@@ -315,7 +315,7 @@ type UnixListener struct { ...@@ -315,7 +315,7 @@ type UnixListener struct {
// ListenUnix announces on the Unix domain socket laddr and returns a Unix listener. // ListenUnix announces on the Unix domain socket laddr and returns a Unix listener.
// Net must be "unix" (stream sockets). // Net must be "unix" (stream sockets).
func ListenUnix(net string, laddr *UnixAddr) (l *UnixListener, err error) { func ListenUnix(net string, laddr *UnixAddr) (*UnixListener, error) {
if net != "unix" && net != "unixgram" && net != "unixpacket" { if net != "unix" && net != "unixgram" && net != "unixpacket" {
return nil, UnknownNetworkError(net) return nil, UnknownNetworkError(net)
} }
...@@ -326,10 +326,10 @@ func ListenUnix(net string, laddr *UnixAddr) (l *UnixListener, err error) { ...@@ -326,10 +326,10 @@ func ListenUnix(net string, laddr *UnixAddr) (l *UnixListener, err error) {
if err != nil { if err != nil {
return nil, err return nil, err
} }
e1 := syscall.Listen(fd.sysfd, 8) // listenBacklog()); err = syscall.Listen(fd.sysfd, listenerBacklog)
if e1 != nil { if err != nil {
closesocket(fd.sysfd) closesocket(fd.sysfd)
return nil, &OpError{Op: "listen", Net: "unix", Addr: laddr, Err: e1} return nil, &OpError{Op: "listen", Net: "unix", Addr: laddr, Err: err}
} }
return &UnixListener{fd, laddr.Name}, nil return &UnixListener{fd, laddr.Name}, nil
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment