瀏覽代碼

Merge pull request #26641 from Microsoft/jjh/aggressivenamespacing

Windows: OCI aggressive namespacing
Tõnis Tiigi 8 年之前
父節點
當前提交
511fd49402
共有 2 個文件被更改,包括 28 次插入28 次删除
  1. 7 7
      daemon/oci_windows.go
  2. 21 21
      libcontainerd/windowsoci/oci_windows.go

+ 7 - 7
daemon/oci_windows.go

@@ -114,7 +114,7 @@ func (daemon *Daemon) createSpec(c *container.Container) (*libcontainerd.Spec, e
 		hv = c.HostConfig.Isolation.IsHyperV()
 	}
 	if hv {
-		hvr := &windowsoci.HvRuntime{}
+		hvr := &windowsoci.WindowsHvRuntime{}
 		if img.RootFS != nil && img.RootFS.Type == image.TypeLayers {
 			// For TP5, the utility VM is part of the base layer.
 			// TODO-jstarks: Add support for separate utility VM images
@@ -158,26 +158,26 @@ func (daemon *Daemon) createSpec(c *container.Container) (*libcontainerd.Spec, e
 			}
 		}
 	}
-	s.Windows.Networking = &windowsoci.Networking{
+	s.Windows.Networking = &windowsoci.WindowsNetworking{
 		EndpointList: epList,
 	}
 
 	// In s.Windows.Resources
 	// @darrenstahlmsft implement these resources
 	cpuShares := uint64(c.HostConfig.CPUShares)
-	s.Windows.Resources = &windowsoci.Resources{
-		CPU: &windowsoci.CPU{
+	s.Windows.Resources = &windowsoci.WindowsResources{
+		CPU: &windowsoci.WindowsCPU{
 			Percent: &c.HostConfig.CPUPercent,
 			Shares:  &cpuShares,
 		},
-		Memory: &windowsoci.Memory{
+		Memory: &windowsoci.WindowsMemory{
 			Limit: &c.HostConfig.Memory,
 			//TODO Reservation: ...,
 		},
-		Network: &windowsoci.Network{
+		Network: &windowsoci.WindowsNetwork{
 		//TODO Bandwidth: ...,
 		},
-		Storage: &windowsoci.Storage{
+		Storage: &windowsoci.WindowsStorage{
 			Bps:  &c.HostConfig.IOMaximumBandwidth,
 			Iops: &c.HostConfig.IOMaximumIOps,
 		},

+ 21 - 21
libcontainerd/windowsoci/oci_windows.go

@@ -36,15 +36,15 @@ type Spec struct {
 // Windows contains platform specific configuration for Windows based containers.
 type Windows struct {
 	// Resources contains information for handling resource constraints for the container
-	Resources *Resources `json:"resources,omitempty"`
+	Resources *WindowsResources `json:"resources,omitempty"`
 	// Networking contains the platform specific network settings for the container.
-	Networking *Networking `json:"networking,omitempty"`
+	Networking *WindowsNetworking `json:"networking,omitempty"`
 	// LayerFolder is the path to the current layer folder
 	LayerFolder string `json:"layer_folder,omitempty"`
 	// Layer paths of the parent layers
 	LayerPaths []string `json:"layer_paths,omitempty"`
 	// HvRuntime contains settings specific to Hyper-V containers, omitted if not using Hyper-V isolation
-	HvRuntime *HvRuntime `json:"hv_runtime,omitempty"`
+	HvRuntime *WindowsHvRuntime `json:"hv_runtime,omitempty"`
 }
 
 // Process contains information to start a specific application inside the container.
@@ -122,20 +122,20 @@ type Mount struct {
 	Options []string `json:"options,omitempty"`
 }
 
-// HvRuntime contains settings specific to Hyper-V containers
-type HvRuntime struct {
+// WindowsHvRuntime contains settings specific to Hyper-V containers
+type WindowsHvRuntime struct {
 	// ImagePath is the path to the Utility VM image for this container
 	ImagePath string `json:"image_path,omitempty"`
 }
 
-// Networking contains the platform specific network settings for the container
-type Networking struct {
+// WindowsNetworking contains the platform specific network settings for the container
+type WindowsNetworking struct {
 	// List of endpoints to be attached to the container
 	EndpointList []string `json:"endpoints,omitempty"`
 }
 
-// Storage contains storage resource management settings
-type Storage struct {
+// WindowsStorage contains storage resource management settings
+type WindowsStorage struct {
 	// Specifies maximum Iops for the system drive
 	Iops *uint64 `json:"iops,omitempty"`
 	// Specifies maximum bytes per second for the system drive
@@ -144,16 +144,16 @@ type Storage struct {
 	SandboxSize *uint64 `json:"sandbox_size,omitempty"`
 }
 
-// Memory contains memory settings for the container
-type Memory struct {
+// WindowsMemory contains memory settings for the container
+type WindowsMemory struct {
 	// Memory limit (in bytes).
 	Limit *int64 `json:"limit,omitempty"`
 	// Memory reservation (in bytes).
 	Reservation *uint64 `json:"reservation,omitempty"`
 }
 
-// CPU contains information for cpu resource management
-type CPU struct {
+// WindowsCPU contains information for cpu resource management
+type WindowsCPU struct {
 	// Number of CPUs available to the container. This is an appoximation for Windows Server Containers.
 	Count *uint64 `json:"count,omitempty"`
 	// CPU shares (relative weight (ratio) vs. other containers with cpu shares). Range is from 1 to 10000.
@@ -162,24 +162,24 @@ type CPU struct {
 	Percent *int64 `json:"percent,omitempty"`
 }
 
-// Network contains network resource management information
-type Network struct {
+// WindowsNetwork contains network resource management information
+type WindowsNetwork struct {
 	// Bandwidth is the maximum egress bandwidth in bytes per second
 	Bandwidth *uint64 `json:"bandwidth,omitempty"`
 }
 
-// Resources has container runtime resource constraints
+// WindowsResources has container runtime resource constraints
 // TODO Windows containerd. This structure needs ratifying with the old resources
 // structure used on Windows and the latest OCI spec.
-type Resources struct {
+type WindowsResources struct {
 	// Memory restriction configuration
-	Memory *Memory `json:"memory,omitempty"`
+	Memory *WindowsMemory `json:"memory,omitempty"`
 	// CPU resource restriction configuration
-	CPU *CPU `json:"cpu,omitempty"`
+	CPU *WindowsCPU `json:"cpu,omitempty"`
 	// Storage restriction configuration
-	Storage *Storage `json:"storage,omitempty"`
+	Storage *WindowsStorage `json:"storage,omitempty"`
 	// Network restriction configuration
-	Network *Network `json:"network,omitempty"`
+	Network *WindowsNetwork `json:"network,omitempty"`
 }
 
 const (