99a98ccc14
This PR adds support for running regular containers to be connected to swarm mode multi-host network so that: - containers connected to the same network across the cluster can discover and connect to each other. - Get access to services(and their associated loadbalancers) connected to the same network Signed-off-by: Jana Radhakrishnan <mrjana@docker.com>
52 lines
1.2 KiB
Go
52 lines
1.2 KiB
Go
package main
|
|
|
|
import (
|
|
"fmt"
|
|
"strconv"
|
|
"syscall"
|
|
"unsafe"
|
|
|
|
"github.com/go-check/check"
|
|
)
|
|
|
|
func openEvent(desiredAccess uint32, inheritHandle bool, name string, proc *syscall.LazyProc) (handle syscall.Handle, err error) {
|
|
namep, _ := syscall.UTF16PtrFromString(name)
|
|
var _p2 uint32
|
|
if inheritHandle {
|
|
_p2 = 1
|
|
}
|
|
r0, _, e1 := proc.Call(uintptr(desiredAccess), uintptr(_p2), uintptr(unsafe.Pointer(namep)))
|
|
handle = syscall.Handle(r0)
|
|
if handle == syscall.InvalidHandle {
|
|
err = e1
|
|
}
|
|
return
|
|
}
|
|
|
|
func pulseEvent(handle syscall.Handle, proc *syscall.LazyProc) (err error) {
|
|
r0, _, _ := proc.Call(uintptr(handle))
|
|
if r0 != 0 {
|
|
err = syscall.Errno(r0)
|
|
}
|
|
return
|
|
}
|
|
|
|
func signalDaemonDump(pid int) {
|
|
modkernel32 := syscall.NewLazyDLL("kernel32.dll")
|
|
procOpenEvent := modkernel32.NewProc("OpenEventW")
|
|
procPulseEvent := modkernel32.NewProc("PulseEvent")
|
|
|
|
ev := "Global\\docker-daemon-" + strconv.Itoa(pid)
|
|
h2, _ := openEvent(0x0002, false, ev, procOpenEvent)
|
|
if h2 == 0 {
|
|
return
|
|
}
|
|
pulseEvent(h2, procPulseEvent)
|
|
}
|
|
|
|
func signalDaemonReload(pid int) error {
|
|
return fmt.Errorf("daemon reload not supported")
|
|
}
|
|
|
|
func cleanupExecRoot(c *check.C, execRoot string) {
|
|
}
|