Skip to content

Commit

Permalink
Merge branch 'Mirantis:release/1.6' into release/1.6
Browse files Browse the repository at this point in the history
  • Loading branch information
aepifanov authored Dec 27, 2023
2 parents df020da + 1c78576 commit 01adfdc
Show file tree
Hide file tree
Showing 3 changed files with 30 additions and 3 deletions.
3 changes: 3 additions & 0 deletions pkg/deprecation/deprecation.go
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,8 @@ const (
CRIAPIV1Alpha2 Warning = Prefix + "cri-api-v1alpha2"
// AUFSSnapshotter is a warning for the use of the aufs snapshotter
AUFSSnapshotter Warning = Prefix + "aufs-snapshotter"
// RestartLogpath is a warning for the containerd.io/restart.logpath label
RestartLogpath Warning = Prefix + "restart-logpath"
// RuntimeV1 is a warning for the io.containerd.runtime.v1.linux runtime
RuntimeV1 Warning = Prefix + "runtime-v1"
// RuntimeRuncV1 is a warning for the io.containerd.runc.v1 runtime
Expand Down Expand Up @@ -75,6 +77,7 @@ var messages = map[Warning]string{
"Use `config_path` instead.",
CRIAPIV1Alpha2: "CRI API v1alpha2 is deprecated since containerd v1.7 and removed in containerd v2.0. Use CRI API v1 instead.",
AUFSSnapshotter: "The aufs snapshotter is deprecated since containerd v1.5 and removed in containerd v2.0. Use the overlay snapshotter instead.",
RestartLogpath: "The `containerd.io/restart.logpath` label is deprecated since containerd v1.5 and removed in containerd v2.0. Use `containerd.io/restart.loguri` instead.",
RuntimeV1: "The `io.containerd.runtime.v1.linux` runtime is deprecated since containerd v1.4 and removed in containerd v2.0. Use the `io.containerd.runc.v2` runtime instead.",
RuntimeRuncV1: "The `io.containerd.runc.v1` runtime is deprecated since containerd v1.4 and removed in containerd v2.0. Use the `io.containerd.runc.v2` runtime instead.",
CRICRIUPath: "The `CriuPath` property of `[plugins.\"io.containerd.grpc.v1.cri\".containerd.runtimes.*.options]` is deprecated since containerd v1.7 and will be removed in containerd v2.0. " +
Expand Down
11 changes: 10 additions & 1 deletion runtime/restart/monitor/change.go
Original file line number Diff line number Diff line change
Expand Up @@ -22,9 +22,11 @@ import (
"net/url"
"syscall"

"github.com/sirupsen/logrus"

"github.com/containerd/containerd"
"github.com/containerd/containerd/cio"
"github.com/sirupsen/logrus"
"github.com/containerd/containerd/runtime/restart"
)

type stopChange struct {
Expand All @@ -41,6 +43,8 @@ type startChange struct {

// Deprecated(in release 1.5): but recognized now, prefer to use logURI
logPath string
// logPathCallback is a func invoked if logPath is defined, used for emitting deprecation warnings
logPathCallback func()
}

func (s *startChange) apply(ctx context.Context, client *containerd.Client) error {
Expand All @@ -55,6 +59,11 @@ func (s *startChange) apply(ctx context.Context, client *containerd.Client) erro
} else if s.logPath != "" {
log = cio.LogFile(s.logPath)
}
if s.logPath != "" && s.logPathCallback != nil {
logrus.WithField("container", s.container.ID()).WithField(restart.LogPathLabel, s.logPath).
Warnf("%q label is deprecated in containerd v1.5 and will be removed in containerd v2.0. Use %q instead.", restart.LogPathLabel, restart.LogURILabel)
s.logPathCallback()
}

if s.logURI != "" && s.logPath != "" {
logrus.Warnf("LogPathLabel=%v has been deprecated, using LogURILabel=%v",
Expand Down
19 changes: 17 additions & 2 deletions runtime/restart/monitor/monitor.go
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,8 @@ import (
"sync"
"time"

"github.com/sirupsen/logrus"

"github.com/containerd/containerd"
containers "github.com/containerd/containerd/api/services/containers/v1"
diff "github.com/containerd/containerd/api/services/diff/v1"
Expand All @@ -31,11 +33,12 @@ import (
"github.com/containerd/containerd/content"
"github.com/containerd/containerd/leases"
"github.com/containerd/containerd/namespaces"
"github.com/containerd/containerd/pkg/deprecation"
"github.com/containerd/containerd/plugin"
"github.com/containerd/containerd/runtime/restart"
"github.com/containerd/containerd/services"
"github.com/containerd/containerd/services/warning"
"github.com/containerd/containerd/snapshots"
"github.com/sirupsen/logrus"
)

type duration struct {
Expand Down Expand Up @@ -64,6 +67,7 @@ func init() {
Requires: []plugin.Type{
plugin.EventPlugin,
plugin.ServicePlugin,
plugin.WarningPlugin,
},
ID: "restart",
Config: &Config{
Expand All @@ -80,8 +84,14 @@ func init() {
if err != nil {
return nil, err
}
ws, err := ic.Get(plugin.WarningPlugin)
if err != nil {
return nil, err
}
warn := ws.(warning.Service)
m := &monitor{
client: client,
warn: warn,
}
go m.run(ic.Config.(*Config).Interval.Duration)
return m, nil
Expand Down Expand Up @@ -152,6 +162,7 @@ type change interface {

type monitor struct {
client *containerd.Client
warn warning.Service
}

func (m *monitor) run(interval time.Duration) {
Expand Down Expand Up @@ -221,7 +232,11 @@ func (m *monitor) monitor(ctx context.Context) ([]change, error) {
changes = append(changes, &startChange{
container: c,
logPath: labels[restart.LogPathLabel],
logURI: labels[restart.LogURILabel],
logPathCallback: func() {

m.warn.Emit(ctx, deprecation.RestartLogpath)
},
logURI: labels[restart.LogURILabel],
})
case containerd.Stopped:
changes = append(changes, &stopChange{
Expand Down

0 comments on commit 01adfdc

Please sign in to comment.