Skip to content

Latest commit

 

History

History
299 lines (258 loc) · 10.7 KB

cs_static_routes.md

File metadata and controls

299 lines (258 loc) · 10.7 KB
copyright lastupdated keywords subcollection
years
2014, 2021
2021-03-22
kubernetes, iks, vyatta, strongswan, ipsec, on-premises, vpn, gateway, static route, routing table
containers

{:DomainName: data-hd-keyref="APPDomain"} {:DomainName: data-hd-keyref="DomainName"} {:android: data-hd-operatingsystem="android"} {:api: .ph data-hd-interface='api'} {:apikey: data-credential-placeholder='apikey'} {:app_key: data-hd-keyref="app_key"} {:app_name: data-hd-keyref="app_name"} {:app_secret: data-hd-keyref="app_secret"} {:app_url: data-hd-keyref="app_url"} {:authenticated-content: .authenticated-content} {:beta: .beta} {:c#: data-hd-programlang="c#"} {:cli: .ph data-hd-interface='cli'} {:codeblock: .codeblock} {:curl: .ph data-hd-programlang='curl'} {:deprecated: .deprecated} {:dotnet-standard: .ph data-hd-programlang='dotnet-standard'} {:download: .download} {:external: target="_blank" .external} {:faq: data-hd-content-type='faq'} {:fuzzybunny: .ph data-hd-programlang='fuzzybunny'} {:generic: data-hd-operatingsystem="generic"} {:generic: data-hd-programlang="generic"} {:gif: data-image-type='gif'} {:go: .ph data-hd-programlang='go'} {:help: data-hd-content-type='help'} {:hide-dashboard: .hide-dashboard} {:hide-in-docs: .hide-in-docs} {:important: .important} {:ios: data-hd-operatingsystem="ios"} {:java: .ph data-hd-programlang='java'} {:java: data-hd-programlang="java"} {:javascript: .ph data-hd-programlang='javascript'} {:javascript: data-hd-programlang="javascript"} {:new_window: target="_blank"} {:note .note} {:note: .note} {:objectc data-hd-programlang="objectc"} {:org_name: data-hd-keyref="org_name"} {:php: data-hd-programlang="php"} {:pre: .pre} {:preview: .preview} {:python: .ph data-hd-programlang='python'} {:python: data-hd-programlang="python"} {:route: data-hd-keyref="route"} {:row-headers: .row-headers} {:ruby: .ph data-hd-programlang='ruby'} {:ruby: data-hd-programlang="ruby"} {:runtime: architecture="runtime"} {:runtimeIcon: .runtimeIcon} {:runtimeIconList: .runtimeIconList} {:runtimeLink: .runtimeLink} {:runtimeTitle: .runtimeTitle} {:screen: .screen} {:script: data-hd-video='script'} {:service: architecture="service"} {:service_instance_name: data-hd-keyref="service_instance_name"} {:service_name: data-hd-keyref="service_name"} {:shortdesc: .shortdesc} {:space_name: data-hd-keyref="space_name"} {:step: data-tutorial-type='step'} {:subsection: outputclass="subsection"} {:support: data-reuse='support'} {:swift: .ph data-hd-programlang='swift'} {:swift: data-hd-programlang="swift"} {:table: .aria-labeledby="caption"} {:term: .term} {:tip: .tip} {:tooling-url: data-tooling-url-placeholder='tooling-url'} {:troubleshoot: data-hd-content-type='troubleshoot'} {:tsCauses: .tsCauses} {:tsResolve: .tsResolve} {:tsSymptoms: .tsSymptoms} {:tutorial: data-hd-content-type='tutorial'} {:ui: .ph data-hd-interface='ui'} {:unity: .ph data-hd-programlang='unity'} {:url: data-credential-placeholder='url'} {:user_ID: data-hd-keyref="user_ID"} {:vbnet: .ph data-hd-programlang='vb.net'} {:video: .video}

Adding static routes to worker nodes

{: #static-routes}

Create static routes on your worker nodes by enabling the static routes add-on for {{site.data.keyword.containerlong}} clusters. {: shortdesc}

About static routes

{: #about-static-routes}

When you configure your cluster network to communicate with other networks over the private network, you might need to add custom static routes on your worker nodes. Static routes allow worker nodes to successfully re-route response packets from your cluster to an IP address in on-premises data center through a VPN or a gateway appliance. {: shortdesc}

For example, you might use a VPN to connect your cluster to an on-premises data center over the private network. Additionally, your private VPN connection preserves the source IP address in requests between the cluster and the data center.

When an on-premises service sends a request to an app in your cluster, the worker node that your app pod is on drops the response due to reverse path filtering (RPF). RPF is a Linux kernel feature that drops any responses to IP addresses that are not listed in the worker node's routing tables. The response is dropped because the on-premises IP address that was preserved in the request is not routable by the worker node.

In this case, you can create a static route so that when a request's source IP address is from one of your on-premises subnets, the response is sent to the VPN gateway IP address instead. By adding this static route to the worker nodes' routing tables, you ensure the following:

  • Response packets are not dropped due to RPF, because a routing rule that points to the on-premises IP address exists.
  • Response packets are successfully routed first through the VPN gateway IP address, and then re-routed to your on-premises IP address.

The static route cluster add-on can be used to apply and manage static routes only. You are responsible for separately configuring and managing your own VPN, gateway appliance, or {{site.data.keyword.BluDirectLink}} connection. {: note}


Enabling the static route add-on

{: #enable-add-on}

To get started with static routes in {{site.data.keyword.containerlong_notm}}, enable the static route add-on. {: shortdesc}

Before you begin:


**To use the {{site.data.keyword.cloud_notm}} console:**
  1. In your cluster dashboard{: external}, click the name of the cluster where you want to install the static route add-on.

  2. Click the Add-ons tab.

  3. On the Static Route card, click Install.

  4. Click Install again.

  5. On the Static Route card, verify that the add-on is listed.


**To use the CLI:**
  1. Target the CLI to your cluster.

  2. Enable the static-route add-on.

ibmcloud ks cluster addon enable static-route --cluster <cluster_name_or_ID>

{: pre}

  1. Verify that the static route add-on has a status of Addon Ready.
ibmcloud ks cluster addon ls --cluster <cluster_name_or_ID>

{: pre}

Example output:

Name              Version     Health State   Health Status
static-route      1.0.0       normal         Addon Ready

{: screen}


Creating static routes

{: #create-route-resources}

After you enable the static route add-on, you can create and apply resources for custom routes. {: shortdesc}

  1. Create a YAML file for a static route resource.

    apiVersion: static-route.ibm.com/v1
    kind: StaticRoute
    metadata:
      name: <route_name>
    spec:
      subnet: "<subnet_CIDR>"
      gateway: "<gateway_IP>"
      selectors:
        - key: "<label_key>"
          values:
            - "<label_value>"
          operator: In

    {: codeblock}

    Example:

    apiVersion: static-route.ibm.com/v1
    kind: StaticRoute
    metadata:
      name: mystaticroute
    spec:
      subnet: "192.168.0.0/24"
      gateway: "10.0.0.1"
      selectors:
        - key: "kubernetes.io/arch"
          values:
            - "amd64"
          operator: In

    {: screen}

    Understanding the YAML file components
    Component Description
    subnet Specify the CIDR of the external subnet from which requests to the worker nodes are sent, such as a subnet in an on-premises network.

    The external subnet cannot be in the following reserved ranges:
    • 10.0.0.0/8
    • 172.16.0.0/16
    • 172.18.0.0/16
    • 172.19.0.0/16
    • 172.20.0.0/16
    • 192.168.255.0/24 **Note**: The device interconnect range, 198.18.0.0/15, is permitted.
    gateway If your gateway IP address exists on the same subnet as your worker nodes, specify the gateway IP address.
    If your gateway IP address exists on another subnet in your IBM Cloud private network, do not include this field. In this case, worker nodes send responses to the private network's backend router, and the router sends the response to the gateway on the other subnet. When the static route is created, the backend router's IP address in the `10.0.0.0/8` range is automatically assigned as a default gateway.
    selectors To create the static route only on certain worker nodes based on worker node labels, include the `key` and `values` for the label.
  2. Create the static routes by applying the YAML file to your cluster.

kubectl apply -f <route_name>.yaml

{: pre}

  1. Verify that the static route is created. In the output, check the node_status for each worker node that the static route is applied to.
kubectl get staticroute <route_name> -o yaml

{: pre}

Example output:

apiVersion: static-route.ibm.com/v1
kind: StaticRoute
metadata:
  annotations:
    kubectl.kubernetes.io/last-applied-configuration: |
      {"apiVersion":"static-route.ibm.com/v1","kind":"StaticRoute","metadata":{"annotations":{},"name":"mystaticroute"},"spec":{"selectors":[{"key":"kubernetes.io/arch","operator":"In","values":["amd64"]}],"subnet":"10.94.227.46/24"}}
  creationTimestamp: "2020-05-20T16:43:12Z"
  finalizers:
  - finalizer.static-route.ibm.com
  generation: 1
  name: mystaticroute
  resourceVersion: "3753886"
  selfLink: /apis/static-route.ibm.com/v1/staticroutes/mystaticroute
  uid: f284359f-9d13-4e27-9d3a-8fb38cbc7a5c
spec:
  selectors:
  - key: kubernetes.io/arch
    operator: In
    values:
    - amd64
  subnet: 10.94.227.46/24
status:
  nodeStatus:
  - error: ""
    hostname: 10.94.227.19
    state:
      gateway: 10.94.227.1
      selectors:
      - key: kubernetes.io/arch
        operator: In
        values:
        - amd64
      subnet: 10.94.227.46/24
  - error: ""
    hostname: 10.94.227.22
    state:
      gateway: 10.94.227.1
      selectors:
      - key: kubernetes.io/arch
        operator: In
        values:
        - amd64
      subnet: 10.94.227.46/24

{: screen}