Este contenido no está disponible en el idioma seleccionado.
Chapter 5. Cluster Network Operator in OpenShift Container Platform
You can use the Cluster Network Operator (CNO) to deploy and manage cluster network components on an OpenShift Container Platform cluster, including the Container Network Interface (CNI) network plugin selected for the cluster during installation.
5.1. Cluster Network Operator
				The Cluster Network Operator implements the network API from the operator.openshift.io API group. The Operator deploys the OVN-Kubernetes network plugin, or the network provider plugin that you selected during cluster installation, by using a daemon set.
			
Procedure
					The Cluster Network Operator is deployed during installation as a Kubernetes Deployment.
				
- Run the following command to view the Deployment status: - oc get -n openshift-network-operator deployment/network-operator - $ oc get -n openshift-network-operator deployment/network-operator- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - NAME READY UP-TO-DATE AVAILABLE AGE network-operator 1/1 1 1 56m - NAME READY UP-TO-DATE AVAILABLE AGE network-operator 1/1 1 1 56m- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Run the following command to view the state of the Cluster Network Operator: - oc get clusteroperator/network - $ oc get clusteroperator/network- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - NAME VERSION AVAILABLE PROGRESSING DEGRADED SINCE network 4.5.4 True False False 50m - NAME VERSION AVAILABLE PROGRESSING DEGRADED SINCE network 4.5.4 True False False 50m- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The following fields provide information about the status of the operator: - AVAILABLE,- PROGRESSING, and- DEGRADED. The- AVAILABLEfield is- Truewhen the Cluster Network Operator reports an available status condition.
5.2. Viewing the cluster network configuration
				Every new OpenShift Container Platform installation has a network.config object named cluster.
			
Procedure
- Use the - oc describecommand to view the cluster network configuration:- oc describe network.config/cluster - $ oc describe network.config/cluster- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
5.3. Viewing Cluster Network Operator status
				You can inspect the status and view the details of the Cluster Network Operator using the oc describe command.
			
Procedure
- Run the following command to view the status of the Cluster Network Operator: - oc describe clusteroperators/network - $ oc describe clusteroperators/network- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
5.4. Enabling IP forwarding globally
				From OpenShift Container Platform 4.14 onward, global IP address forwarding is disabled on OVN-Kubernetes based cluster deployments to prevent undesirable effects for cluster administrators with nodes acting as routers. However, in some cases where an administrator expects traffic to be forwarded a new configuration parameter ipForwarding is available to allow forwarding of all IP traffic.
			
				To re-enable IP forwarding for all traffic on OVN-Kubernetes managed interfaces set the gatewayConfig.ipForwarding specification in the Cluster Network Operator to Global following this procedure:
			
Procedure
- Backup the existing network configuration by running the following command: - oc get network.operator cluster -o yaml > network-config-backup.yaml - $ oc get network.operator cluster -o yaml > network-config-backup.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Run the following command to modify the existing network configuration: - oc edit network.operator cluster - $ oc edit network.operator cluster- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Add or update the following block under - specas illustrated in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Save and close the file.
 
- After applying the changes, the OpenShift Cluster Network Operator (CNO) applies the update across the cluster. You can monitor the progress by using the following command: - oc get clusteroperators network - $ oc get clusteroperators network- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The status should eventually report as - Available,- Progressing=False, and- Degraded=False.
- Alternatively, you can enable IP forwarding globally by running the following command: - oc patch network.operator cluster -p '{"spec":{"defaultNetwork":{"ovnKubernetesConfig":{"gatewayConfig":{"ipForwarding": "Global"}}}}}- $ oc patch network.operator cluster -p '{"spec":{"defaultNetwork":{"ovnKubernetesConfig":{"gatewayConfig":{"ipForwarding": "Global"}}}}}- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Note- The other valid option for this parameter is - Restrictedin case you want to revert this change.- Restrictedis the default and with that setting global IP address forwarding is disabled.
5.5. Viewing Cluster Network Operator logs
				You can view Cluster Network Operator logs by using the oc logs command.
			
Procedure
- Run the following command to view the logs of the Cluster Network Operator: - oc logs --namespace=openshift-network-operator deployment/network-operator - $ oc logs --namespace=openshift-network-operator deployment/network-operator- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
5.6. Cluster Network Operator configuration
				The configuration for the cluster network is specified as part of the Cluster Network Operator (CNO) configuration and stored in a custom resource (CR) object that is named cluster. The CR specifies the fields for the Network API in the operator.openshift.io API group.
			
				The CNO configuration inherits the following fields during cluster installation from the Network API in the Network.config.openshift.io API group:
			
- clusterNetwork
- IP address pools from which pod IP addresses are allocated.
- serviceNetwork
- IP address pool for services.
- defaultNetwork.type
- Cluster network plugin, such as OpenShift SDN or OVN-Kubernetes.
					After cluster installation, you can only modify the clusterNetwork IP address range. The default network type can only be changed from OpenShift SDN to OVN-Kubernetes through migration.
				
				You can specify the cluster network plugin configuration for your cluster by setting the fields for the defaultNetwork object in the CNO object named cluster.
			
5.6.1. Cluster Network Operator configuration object
The fields for the Cluster Network Operator (CNO) are described in the following table:
| Field | Type | Description | 
|---|---|---|
| 
									 | 
									 | 
									The name of the CNO object. This name is always  | 
| 
									 | 
									 | A list specifying the blocks of IP addresses from which pod IP addresses are allocated and the subnet prefix length assigned to each individual node in the cluster. For example: | 
| 
									 | 
									 | A block of IP addresses for services. The OpenShift SDN and OVN-Kubernetes network plugins support only a single IP address block for the service network. For example: spec: serviceNetwork: - 172.30.0.0/14 
									This value is ready-only and inherited from the  | 
| 
									 | 
									 | Configures the network plugin for the cluster network. | 
| 
									 | 
									 | The fields for this object specify the kube-proxy configuration. If you are using the OVN-Kubernetes cluster network plugin, the kube-proxy configuration has no effect. | 
						For a cluster that needs to deploy objects across multiple networks, ensure that you specify the same value for the clusterNetwork.hostPrefix parameter for each network type that is defined in the install-config.yaml file. Setting a different value for each clusterNetwork.hostPrefix parameter can impact the OVN-Kubernetes network plugin, where the plugin cannot effectively route object traffic among different nodes.
					
5.6.1.1. defaultNetwork object configuration
						The values for the defaultNetwork object are defined in the following table:
					
| Field | Type | Description | 
|---|---|---|
| 
										 | 
										 | 
										Either  Note OpenShift Container Platform uses the OVN-Kubernetes network plugin by default. | 
| 
										 | 
										 | This object is only valid for the OpenShift SDN network plugin. | 
| 
										 | 
										 | This object is only valid for the OVN-Kubernetes network plugin. | 
5.6.1.1.1. Configuration for the OpenShift SDN network plugin
The following table describes the configuration fields for the OpenShift SDN network plugin:
| Field | Type | Description | 
|---|---|---|
| 
											 | 
											 | The network isolation mode for OpenShift SDN. | 
| 
											 | 
											 | The maximum transmission unit (MTU) for the VXLAN overlay network. This value is normally configured automatically. | 
| 
											 | 
											 | 
											The port to use for all VXLAN packets. The default value is  | 
Example OpenShift SDN configuration
5.6.1.1.2. Configuration for the OVN-Kubernetes network plugin
The following table describes the configuration fields for the OVN-Kubernetes network plugin:
| Field | Type | Description | 
|---|---|---|
| 
											 | 
											 | The maximum transmission unit (MTU) for the Geneve (Generic Network Virtualization Encapsulation) overlay network. This value is normally configured automatically. | 
| 
											 | 
											 | The UDP port for the Geneve overlay network. | 
| 
											 | 
											 | If the field is present, IPsec is enabled for the cluster. | 
| 
											 | 
											 | Specifies a configuration object for IPv4 settings. | 
| 
											 | 
											 | Specifies a configuration object for IPv6 settings. | 
| 
											 | 
											 | Specify a configuration object for customizing network policy audit logging. If unset, the defaults audit log settings are used. | 
| 
											 | 
											 | Optional: Specify a configuration object for customizing how egress traffic is sent to the node gateway. Note While migrating egress traffic, you can expect some disruption to workloads and service traffic until the Cluster Network Operator (CNO) successfully rolls out the changes. | 
| Field | Type | Description | 
|---|---|---|
| 
											 | string | 
											If your existing network infrastructure overlaps with the  
											The default value is  | 
| 
											 | string | 
											If your existing network infrastructure overlaps with the  
											The default value is  | 
| Field | Type | Description | 
|---|---|---|
| 
											 | string | 
											If your existing network infrastructure overlaps with the  
											This field cannot be changed after installation. The default value is  | 
| 
											 | string | 
											If your existing network infrastructure overlaps with the  
											The default value is  | 
| Field | Type | Description | 
|---|---|---|
| 
											 | integer | 
											The maximum number of messages to generate every second per node. The default value is  | 
| 
											 | integer | 
											The maximum size for the audit log in bytes. The default value is  | 
| 
											 | integer | The maximum number of log files that are retained. | 
| 
											 | string | One of the following additional audit log targets: 
 | 
| 
											 | string | 
											The syslog facility, such as  | 
| Field | Type | Description | 
|---|---|---|
| 
											 | 
											 | 
											Set this field to  
											This field has an interaction with the Open vSwitch hardware offloading feature. If you set this field to  | 
| 
											 | 
											 | 
											You can control IP forwarding for all traffic on OVN-Kubernetes managed interfaces by using the  | 
| 
											 | 
											 | Optional: Specify an object to configure the internal OVN-Kubernetes masquerade address for host to service traffic for IPv4 addresses. | 
| 
											 | 
											 | Optional: Specify an object to configure the internal OVN-Kubernetes masquerade address for host to service traffic for IPv6 addresses. | 
| Field | Type | Description | 
|---|---|---|
| 
											 | 
											 | 
											The masquerade IPv4 addresses that are used internally to enable host to service traffic. The host is configured with these IP addresses as well as the shared gateway bridge interface. The default value is  | 
| Field | Type | Description | 
|---|---|---|
| 
											 | 
											 | 
											The masquerade IPv6 addresses that are used internally to enable host to service traffic. The host is configured with these IP addresses as well as the shared gateway bridge interface. The default value is  | 
								You can only change the configuration for your cluster network plugin during cluster installation, except for the gatewayConfig field that can be changed at runtime as a postinstallation activity.
							
Example OVN-Kubernetes configuration with IPSec enabled
5.6.1.2. kubeProxyConfig object configuration (OpenShiftSDN container network interface only)
						The values for the kubeProxyConfig object are defined in the following table:
					
| Field | Type | Description | 
|---|---|---|
| 
										 | 
										 | 
										The refresh period for  Note 
											Because of performance improvements introduced in OpenShift Container Platform 4.3 and greater, adjusting the  | 
| 
										 | 
										 | 
										The minimum duration before refreshing  kubeProxyConfig:
  proxyArguments:
    iptables-min-sync-period:
    - 0s | 
5.6.2. Cluster Network Operator example configuration
A complete CNO configuration is specified in the following example:
Example Cluster Network Operator object