Merge pull request #5901 from jwhonce/wip/service

V2 Remove existing unix domain socket on startup
This commit is contained in:
OpenShift Merge Robot
2020-04-20 16:17:42 -04:00
committed by GitHub

View File

@ -2,8 +2,10 @@ package system
import (
"fmt"
"net/url"
"os"
"path/filepath"
"syscall"
"time"
"github.com/containers/libpod/cmd/podman/registry"
@ -59,6 +61,23 @@ func service(cmd *cobra.Command, args []string) error {
}
logrus.Infof("using API endpoint: '%s'", apiURI)
// Clean up any old existing unix domain socket
if len(apiURI) > 0 {
uri, err := url.Parse(apiURI)
if err != nil {
return err
}
// socket activation uses a unix:// socket in the shipped unit files but apiURI is coded as "" at this layer.
if "unix" == uri.Scheme && !registry.IsRemote() {
if err := syscall.Unlink(uri.Path); err != nil && !os.IsNotExist(err) {
return err
}
mask := syscall.Umask(0177)
defer syscall.Umask(mask)
}
}
opts := entities.ServiceOptions{
URI: apiURI,
Timeout: time.Duration(srvArgs.Timeout) * time.Second,