Merge pull request #32540 from cpuguy83/add_logdrivers_to_info

Add logdrivers to /info
This commit is contained in:
Kenfe-Mickaël Laventure 2017-04-25 23:25:30 -05:00 committed by GitHub
commit e8abe0a69d
6 changed files with 54 additions and 2 deletions

View file

@ -238,6 +238,8 @@ type PluginsInfo struct {
Network []string Network []string
// List of Authorization plugins registered // List of Authorization plugins registered
Authorization []string Authorization []string
// List of Log plugins registered
Log []string
} }
// ExecStartCheck is a temp struct used by execStart // ExecStartCheck is a temp struct used by execStart

View file

@ -90,6 +90,10 @@ func prettyPrintInfo(dockerCli *command.DockerCli, info types.Info) error {
fmt.Fprintf(dockerCli.Out(), "\n") fmt.Fprintf(dockerCli.Out(), "\n")
} }
fmt.Fprintf(dockerCli.Out(), " Log:")
fmt.Fprintf(dockerCli.Out(), " %s", strings.Join(info.Plugins.Log, " "))
fmt.Fprintf(dockerCli.Out(), "\n")
fmt.Fprintf(dockerCli.Out(), "Swarm: %v\n", info.Swarm.LocalNodeState) fmt.Fprintf(dockerCli.Out(), "Swarm: %v\n", info.Swarm.LocalNodeState)
if info.Swarm.LocalNodeState != swarm.LocalNodeStateInactive && info.Swarm.LocalNodeState != swarm.LocalNodeStateLocked { if info.Swarm.LocalNodeState != swarm.LocalNodeStateInactive && info.Swarm.LocalNodeState != swarm.LocalNodeStateLocked {
fmt.Fprintf(dockerCli.Out(), " NodeID: %s\n", info.Swarm.NodeID) fmt.Fprintf(dockerCli.Out(), " NodeID: %s\n", info.Swarm.NodeID)

View file

@ -57,6 +57,7 @@ func (e *executor) Describe(ctx context.Context) (*api.NodeDescription, error) {
// the plugin list by default. // the plugin list by default.
addPlugins("Network", append([]string{"overlay"}, info.Plugins.Network...)) addPlugins("Network", append([]string{"overlay"}, info.Plugins.Network...))
addPlugins("Authorization", info.Plugins.Authorization) addPlugins("Authorization", info.Plugins.Authorization)
addPlugins("Log", info.Plugins.Log)
// add v2 plugins // add v2 plugins
v2Plugins, err := e.backend.PluginManager().List(filters.NewArgs()) v2Plugins, err := e.backend.PluginManager().List(filters.NewArgs())
@ -67,11 +68,15 @@ func (e *executor) Describe(ctx context.Context) (*api.NodeDescription, error) {
continue continue
} }
plgnTyp := typ.Capability plgnTyp := typ.Capability
if typ.Capability == "volumedriver" { switch typ.Capability {
case "volumedriver":
plgnTyp = "Volume" plgnTyp = "Volume"
} else if typ.Capability == "networkdriver" { case "networkdriver":
plgnTyp = "Network" plgnTyp = "Network"
case "logdriver":
plgnTyp = "Log"
} }
plugins[api.PluginDescription{ plugins[api.PluginDescription{
Type: plgnTyp, Type: plgnTyp,
Name: plgn.Name, Name: plgn.Name,

View file

@ -12,6 +12,7 @@ import (
"github.com/docker/docker/api/types" "github.com/docker/docker/api/types"
"github.com/docker/docker/cli/debug" "github.com/docker/docker/cli/debug"
"github.com/docker/docker/container" "github.com/docker/docker/container"
"github.com/docker/docker/daemon/logger"
"github.com/docker/docker/dockerversion" "github.com/docker/docker/dockerversion"
"github.com/docker/docker/pkg/fileutils" "github.com/docker/docker/pkg/fileutils"
"github.com/docker/docker/pkg/parsers/kernel" "github.com/docker/docker/pkg/parsers/kernel"
@ -175,6 +176,7 @@ func (daemon *Daemon) showPluginsInfo() types.PluginsInfo {
pluginsInfo.Volume = volumedrivers.GetDriverList() pluginsInfo.Volume = volumedrivers.GetDriverList()
pluginsInfo.Network = daemon.GetNetworkDriverList() pluginsInfo.Network = daemon.GetNetworkDriverList()
pluginsInfo.Authorization = daemon.configStore.GetAuthorizationPlugins() pluginsInfo.Authorization = daemon.configStore.GetAuthorizationPlugins()
pluginsInfo.Log = logger.ListDrivers()
return pluginsInfo return pluginsInfo
} }

View file

@ -2,6 +2,7 @@ package logger
import ( import (
"fmt" "fmt"
"sort"
"sync" "sync"
containertypes "github.com/docker/docker/api/types/container" containertypes "github.com/docker/docker/api/types/container"
@ -23,6 +24,22 @@ type logdriverFactory struct {
m sync.Mutex m sync.Mutex
} }
func (lf *logdriverFactory) list() []string {
ls := make([]string, 0, len(lf.registry))
lf.m.Lock()
for name := range lf.registry {
ls = append(ls, name)
}
lf.m.Unlock()
sort.Strings(ls)
return ls
}
// ListDrivers gets the list of registered log driver names
func ListDrivers() []string {
return factory.list()
}
func (lf *logdriverFactory) register(name string, c Creator) error { func (lf *logdriverFactory) register(name string, c Creator) error {
if lf.driverRegistered(name) { if lf.driverRegistered(name) {
return fmt.Errorf("logger: log driver named '%s' is already registered", name) return fmt.Errorf("logger: log driver named '%s' is already registered", name)

View file

@ -1,9 +1,13 @@
package main package main
import ( import (
"encoding/json"
"net/http"
"strings" "strings"
"github.com/docker/docker/api/types"
"github.com/docker/docker/integration-cli/checker" "github.com/docker/docker/integration-cli/checker"
"github.com/docker/docker/integration-cli/request"
"github.com/go-check/check" "github.com/go-check/check"
) )
@ -25,3 +29,21 @@ func (s *DockerSuite) TestPluginLogDriver(c *check.C) {
dockerCmd(c, "plugin", "disable", pluginName) dockerCmd(c, "plugin", "disable", pluginName)
dockerCmd(c, "plugin", "rm", pluginName) dockerCmd(c, "plugin", "rm", pluginName)
} }
// Make sure log drivers are listed in info, and v2 plugins are not.
func (s *DockerSuite) TestPluginLogDriverInfoList(c *check.C) {
testRequires(c, IsAmd64, DaemonIsLinux)
pluginName := "cpuguy83/docker-logdriver-test"
dockerCmd(c, "plugin", "install", pluginName)
status, body, err := request.SockRequest("GET", "/info", nil, daemonHost())
c.Assert(status, checker.Equals, http.StatusOK)
c.Assert(err, checker.IsNil)
var info types.Info
err = json.Unmarshal(body, &info)
c.Assert(err, checker.IsNil)
drivers := strings.Join(info.Plugins.Log, " ")
c.Assert(drivers, checker.Contains, "json-file")
c.Assert(drivers, checker.Not(checker.Contains), pluginName)
}