-
Notifications
You must be signed in to change notification settings - Fork 5
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
shim: add initial v2 shim implementation for runu
the runtime name is io.containerd.runu.v2. Signed-off-by: Hajime Tazaki <thehajime@gmail.com>
- Loading branch information
Showing
3 changed files
with
157 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
package main | ||
|
||
import ( | ||
"github.com/containerd/containerd/runtime/v2/shim" | ||
) | ||
|
||
const ( | ||
// RuntimeV2 is the name of runtime | ||
RuntimeV2 = "io.containerd.runu.v2" | ||
) | ||
|
||
func main() { | ||
shim.Run("io.containerd.runu.v2", New) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,139 @@ | ||
//go:build linux | ||
// +build linux | ||
|
||
/* | ||
Copyright The containerd Authors. | ||
Licensed under the Apache License, Version 2.0 (the "License"); | ||
you may not use this file except in compliance with the License. | ||
You may obtain a copy of the License at | ||
http://www.apache.org/licenses/LICENSE-2.0 | ||
Unless required by applicable law or agreed to in writing, software | ||
distributed under the License is distributed on an "AS IS" BASIS, | ||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
See the License for the specific language governing permissions and | ||
limitations under the License. | ||
*/ | ||
|
||
package main | ||
|
||
import ( | ||
"context" | ||
"os" | ||
|
||
"github.com/containerd/containerd/errdefs" | ||
"github.com/containerd/containerd/runtime/v2/shim" | ||
taskAPI "github.com/containerd/containerd/runtime/v2/task" | ||
ptypes "github.com/gogo/protobuf/types" | ||
) | ||
|
||
var ( | ||
// check to make sure the *service implements the GRPC API | ||
_ = (taskAPI.TaskService)(&service{}) | ||
) | ||
|
||
// New returns a new shim service | ||
func New(ctx context.Context, id string, publisher shim.Publisher, shutdown func()) (shim.Shim, error) { | ||
return &service{}, nil | ||
} | ||
|
||
type service struct { | ||
} | ||
|
||
// StartShim is a binary call that executes a new shim returning the address | ||
func (s *service) StartShim(ctx context.Context, opts shim.StartOpts) (string, error) { | ||
return "", nil | ||
} | ||
|
||
// Cleanup is a binary call that cleans up any resources used by the shim when the service crashes | ||
func (s *service) Cleanup(ctx context.Context) (*taskAPI.DeleteResponse, error) { | ||
return nil, errdefs.ErrNotImplemented | ||
} | ||
|
||
// Create a new container | ||
func (s *service) Create(ctx context.Context, r *taskAPI.CreateTaskRequest) (_ *taskAPI.CreateTaskResponse, err error) { | ||
return nil, errdefs.ErrNotImplemented | ||
} | ||
|
||
// Start the primary user process inside the container | ||
func (s *service) Start(ctx context.Context, r *taskAPI.StartRequest) (*taskAPI.StartResponse, error) { | ||
return nil, errdefs.ErrNotImplemented | ||
} | ||
|
||
// Delete a process or container | ||
func (s *service) Delete(ctx context.Context, r *taskAPI.DeleteRequest) (*taskAPI.DeleteResponse, error) { | ||
return nil, errdefs.ErrNotImplemented | ||
} | ||
|
||
// Exec an additional process inside the container | ||
func (s *service) Exec(ctx context.Context, r *taskAPI.ExecProcessRequest) (*ptypes.Empty, error) { | ||
return nil, errdefs.ErrNotImplemented | ||
} | ||
|
||
// ResizePty of a process | ||
func (s *service) ResizePty(ctx context.Context, r *taskAPI.ResizePtyRequest) (*ptypes.Empty, error) { | ||
return nil, errdefs.ErrNotImplemented | ||
} | ||
|
||
// State returns runtime state of a process | ||
func (s *service) State(ctx context.Context, r *taskAPI.StateRequest) (*taskAPI.StateResponse, error) { | ||
return nil, errdefs.ErrNotImplemented | ||
} | ||
|
||
// Pause the container | ||
func (s *service) Pause(ctx context.Context, r *taskAPI.PauseRequest) (*ptypes.Empty, error) { | ||
return nil, errdefs.ErrNotImplemented | ||
} | ||
|
||
// Resume the container | ||
func (s *service) Resume(ctx context.Context, r *taskAPI.ResumeRequest) (*ptypes.Empty, error) { | ||
return nil, errdefs.ErrNotImplemented | ||
} | ||
|
||
// Kill a process | ||
func (s *service) Kill(ctx context.Context, r *taskAPI.KillRequest) (*ptypes.Empty, error) { | ||
return nil, errdefs.ErrNotImplemented | ||
} | ||
|
||
// Pids returns all pids inside the container | ||
func (s *service) Pids(ctx context.Context, r *taskAPI.PidsRequest) (*taskAPI.PidsResponse, error) { | ||
return nil, errdefs.ErrNotImplemented | ||
} | ||
|
||
// CloseIO of a process | ||
func (s *service) CloseIO(ctx context.Context, r *taskAPI.CloseIORequest) (*ptypes.Empty, error) { | ||
return nil, errdefs.ErrNotImplemented | ||
} | ||
|
||
// Checkpoint the container | ||
func (s *service) Checkpoint(ctx context.Context, r *taskAPI.CheckpointTaskRequest) (*ptypes.Empty, error) { | ||
return nil, errdefs.ErrNotImplemented | ||
} | ||
|
||
// Connect returns shim information of the underlying service | ||
func (s *service) Connect(ctx context.Context, r *taskAPI.ConnectRequest) (*taskAPI.ConnectResponse, error) { | ||
return nil, errdefs.ErrNotImplemented | ||
} | ||
|
||
// Shutdown is called after the underlying resources of the shim are cleaned up and the service can be stopped | ||
func (s *service) Shutdown(ctx context.Context, r *taskAPI.ShutdownRequest) (*ptypes.Empty, error) { | ||
os.Exit(0) | ||
return &ptypes.Empty{}, nil | ||
} | ||
|
||
// Stats returns container level system stats for a container and its processes | ||
func (s *service) Stats(ctx context.Context, r *taskAPI.StatsRequest) (*taskAPI.StatsResponse, error) { | ||
return nil, errdefs.ErrNotImplemented | ||
} | ||
|
||
// Update the live container | ||
func (s *service) Update(ctx context.Context, r *taskAPI.UpdateTaskRequest) (*ptypes.Empty, error) { | ||
return nil, errdefs.ErrNotImplemented | ||
} | ||
|
||
// Wait for a process to exit | ||
func (s *service) Wait(ctx context.Context, r *taskAPI.WaitRequest) (*taskAPI.WaitResponse, error) { | ||
return nil, errdefs.ErrNotImplemented | ||
} |