Documentation fix for kuryr-kubernetes retirement

The following is a summary of the fixes for this patch.
* The description of k8s environment construction in kuryr-kubernetes
  was changed to the description of using devstack-plugin-container.
* Updated k8s support version to 1.30.
* Updated helm support version to 3.15.

This patch also contains the following fixes:

coredns pods not in RUNNING state:
- modified file: roles/restart-kubelet-service/tasks/main.yaml
- The coredns pods did not go into RUNNING state after reconfiguring
  the "cni0" interface. Restarting the coredns pods fixed the problem.

Change-Id: Id6d9b3279780a88b15c38f008d1e68e1ae466976
This commit is contained in:
Yoshiro Watanabe 2024-10-17 08:10:49 +00:00
parent 844a6f84e8
commit 690def7386
7 changed files with 86 additions and 69 deletions

View File

@ -51,32 +51,29 @@ enable_service n-cauth
disable_service tempest disable_service tempest
# Enable kuryr-kubernetes, crio, octavia # Enable devstack-plugin-container, crio
KUBERNETES_VIM=True
# "KUBERNETES_VIM=True" is not available now. As kuryr-kubernetes project will
# retire, the procedure when "KUBERNETES_VIM=True" will be changed to deploy
# with not kuryr-kubernetes but devstack-plugin-container in future updates.
# KUBERNETES_VIM=True
# It is necessary to specify the patch version # It is necessary to specify the patch version
# because it is the version used when executing "apt-get install" command. # because it is the version used when executing "apt-get install" command.
KURYR_KUBERNETES_VERSION="1.26.8" K8S_VERSION="1.30.5"
K8S_TOKEN="9agf12.zsu5uh2m4pzt3qba"
CONTAINER_ENGINE="crio" CONTAINER_ENGINE="crio"
# It is not necessary to specify the patch version CRIO_VERSION="1.30.5"
# because it is the version used when adding the apt repository.
CRIO_VERSION="1.26"
enable_plugin kuryr-kubernetes https://opendev.org/openstack/kuryr-kubernetes master
enable_plugin octavia https://opendev.org/openstack/octavia master
enable_plugin devstack-plugin-container https://opendev.org/openstack/devstack-plugin-container master
#KURYR_K8S_CLUSTER_IP_RANGE="10.0.0.0/24"
enable_service kubernetes-master enable_plugin devstack-plugin-container https://opendev.org/openstack/devstack-plugin-container master
enable_service kuryr-kubernetes
enable_service kuryr-daemon enable_service k8s-master
enable_service container
[[post-config|/etc/neutron/dhcp_agent.ini]] [[post-config|/etc/neutron/dhcp_agent.ini]]
[DEFAULT] [DEFAULT]
enable_isolated_metadata = True enable_isolated_metadata = True
[[post-config|$OCTAVIA_CONF]]
[controller_worker]
amp_active_retries=9999
# NOTE: workaround for Cinder image volume cache problem. # NOTE: workaround for Cinder image volume cache problem.
# https://bugs.launchpad.net/cinder/+bug/1953704 # https://bugs.launchpad.net/cinder/+bug/1953704
[[post-config|/etc/cinder/cinder.conf]] [[post-config|/etc/cinder/cinder.conf]]

View File

@ -119,7 +119,7 @@ So the first step of installing tacker is to clone Devstack and prepare your
#. Openstack and Kubernetes as VIM. #. Openstack and Kubernetes as VIM.
The difference between all-in-one mode with Kubernetes is The difference between all-in-one mode with Kubernetes is
to deploy kuryr-kubernetes and octavia. to deploy devstack-plugin-container.
The example ``local.conf`` for all-in-one mode with Kubernetes is The example ``local.conf`` for all-in-one mode with Kubernetes is
available at ``${TACKER_ROOT}/devstack/local.conf.kubernetes`` available at ``${TACKER_ROOT}/devstack/local.conf.kubernetes``
@ -128,12 +128,29 @@ So the first step of installing tacker is to clone Devstack and prepare your
.. literalinclude:: ../../../devstack/local.conf.kubernetes .. literalinclude:: ../../../devstack/local.conf.kubernetes
:language: ini :language: ini
:emphasize-lines: 60-65 :emphasize-lines: 56-71
Run the following commands to reconfigure the CNI network for
devstack-plugin-container after running stack.sh.
.. code-block:: console
$ ip link set cni0 down && ip link set flannel.1 down
$ ip link delete cni0 && ip link delete flannel.1
$ systemctl restart kubelet
$ kubectl delete pod -n kube-system $(kubectl get pod -n kube-system --no-headers \
-o custom-columns=":metadata.name" | grep coredns | tr -s '\n' ' ')
.. note:: .. note::
The above local.conf.kubernetes does not work on CentOS8. This operation is required to build a Kubernetes cluster with
Because docker-ce is not supported on CentOS8. devstack-plugin-container.
.. note::
The above local.conf.kubernetes only works on Ubuntu.
Because Devstack-plugin-container only supports building Kubernetes clusters on Ubuntu.
#. Standalone mode #. Standalone mode

View File

@ -19,29 +19,33 @@
Kubernetes VIM Installation Kubernetes VIM Installation
=========================== ===========================
Tacker uses kuryr-kubernetes for deploying Kubernetes cluster and sets up Tacker uses devstack-plugin-container to deploy a Kubernetes cluster.
native Neutron-based network among Kubernetes and OpenStack VIMs.
It deploys VMs and Kubernetes resources on the same network.
#. Edit ``local.conf`` for Kubernetes #. Edit ``local.conf`` for Kubernetes
Add following plugin configurations for kuryr-kubernetes. Add following plugin configurations for devstack-plugin-container.
.. code-block:: console .. code-block:: console
# Enable kuryr-kubernetes, crio, octavia # Enable devstack-plugin-container, crio
KUBERNETES_VIM=True
# "KUBERNETES_VIM=True" is not available now. As kuryr-kubernetes project will
# retire, the procedure when "KUBERNETES_VIM=True" will be changed to deploy
# with not kuryr-kubernetes but devstack-plugin-container in future updates.
# KUBERNETES_VIM=True
# It is necessary to specify the patch version # It is necessary to specify the patch version
# because it is the version used when executing "apt-get install" command. # because it is the version used when executing "apt-get install" command.
KURYR_KUBERNETES_VERSION="1.26.8" K8S_VERSION="1.30.5"
K8S_TOKEN="9agf12.zsu5uh2m4pzt3qba"
CONTAINER_ENGINE="crio" CONTAINER_ENGINE="crio"
# It is not necessary to specify the patch version CRIO_VERSION="1.30.5"
# because it is the version used when adding the apt repository.
CRIO_VERSION="1.26"
enable_plugin kuryr-kubernetes https://opendev.org/openstack/kuryr-kubernetes master
enable_plugin octavia https://opendev.org/openstack/octavia master
enable_plugin devstack-plugin-container https://opendev.org/openstack/devstack-plugin-container master enable_plugin devstack-plugin-container https://opendev.org/openstack/devstack-plugin-container master
enable_service k8s-master
enable_service container
Public network is used to launch LoadBalancer for Services in Kubernetes. Public network is used to launch LoadBalancer for Services in Kubernetes.
Setting public subnet is described in [#first]_. Setting public subnet is described in [#first]_.
@ -83,6 +87,24 @@ It deploys VMs and Kubernetes resources on the same network.
$ ./stack.sh $ ./stack.sh
#. Reconfiguring the CNI network for devstack-plugin-container
**Command:**
.. code-block:: console
$ ip link set cni0 down && ip link set flannel.1 down
$ ip link delete cni0 && ip link delete flannel.1
$ systemctl restart kubelet
$ kubectl delete pod -n kube-system $(kubectl get pod -n kube-system --no-headers \
-o custom-columns=":metadata.name" | grep coredns | tr -s '\n' ' ')
.. note::
This operation is required to build a Kubernetes cluster with
devstack-plugin-container, but will no longer be required for
user operations in a future update.
#. Setup Kubernetes VIM configuration #. Setup Kubernetes VIM configuration
Now you are ready to register Kubernetes VIM if you complete devstack Now you are ready to register Kubernetes VIM if you complete devstack
@ -287,38 +309,6 @@ It deploys VMs and Kubernetes resources on the same network.
``--cacert <path/to/ssl_ca_cert_file>`` option to use ssl_ca_cert ``--cacert <path/to/ssl_ca_cert_file>`` option to use ssl_ca_cert
in the verification of API server's SSL certificate. in the verification of API server's SSL certificate.
#. Check Kubernetes cluster installation
By default, after set ``KUBERNETES_VIM=True``, Devstack creates a
public network called net-k8s, and two extra ones for the Kubernetes
services and pods under the project k8s:
**Command:**
.. code-block:: console
$ openstack network list
**Result:**
.. code-block:: console
+--------------------------------------+-----------------+----------------------------------------------------------------------------+
| ID | Name | Subnets |
+--------------------------------------+-----------------+----------------------------------------------------------------------------+
| 060b32dc-c720-432a-967c-e29d01c2734c | k8s-pod-net | 792ad14d-42a6-4be0-a5f2-6cdb5395bcdc |
| 49829476-b297-4d43-bd86-9d7e81bcaebe | k8s-service-net | fdcf3012-37cf-4bbf-9035-2f9bbb99c007 |
| 6a6d19a5-0ff2-4573-aa98-688b9976d3a5 | net_mgmt | 2ae0e175-54d4-4a6d-b00c-1609bc205f5f |
| 920520a7-7235-4a20-a4c4-b6955dffa90d | public | 2e375eca-ad17-4f36-88a5-332a5e380323, 9d83c498-ba57-4615-b81c-578afd1d5020 |
| 9736903e-adb2-47dc-9a27-46302b4c4e56 | net1 | 843e24c1-3cc0-4d09-8e39-09a0471b6e0a |
| ad5dd7dd-eb86-49de-937a-fbbd799c5ecf | net0 | 91ed8b41-f8d6-4ddd-9927-912bf7e342e9 |
| c827ecc6-0a13-415b-9954-e20984cb0a4f | lb-mgmt-net | e33011da-bde3-4483-9e93-9e654b395be3 |
| dab05a83-cf70-4b93-9fc6-9252748ae46c | private | cc06f27c-1504-401b-b976-895702dac9fa, ffd64f3f-907d-4629-8d63-d9295650a8a1 |
+--------------------------------------+-----------------+----------------------------------------------------------------------------+
To check Kubernetes cluster works well, please see some tests in
kuryr-kubernetes to get more information [#fourth]_.
#. Register Kubernetes VIM #. Register Kubernetes VIM
In ``vim_config.yaml``, project_name is fixed as "default", that will use In ``vim_config.yaml``, project_name is fixed as "default", that will use
@ -463,4 +453,3 @@ References
.. [#first] https://github.com/openstack-dev/devstack/blob/master/doc/source/networking.rst#shared-guest-interface .. [#first] https://github.com/openstack-dev/devstack/blob/master/doc/source/networking.rst#shared-guest-interface
.. [#second] https://docs.openstack.org/tacker/latest/install/devstack.html .. [#second] https://docs.openstack.org/tacker/latest/install/devstack.html
.. [#third] https://opendev.org/openstack/tacker/src/branch/master/devstack/local.conf.kubernetes .. [#third] https://opendev.org/openstack/tacker/src/branch/master/devstack/local.conf.kubernetes
.. [#fourth] https://docs.openstack.org/kuryr-kubernetes/latest/installation/testing_connectivity.html

View File

@ -1064,7 +1064,7 @@ we can append ``-A`` to the command line.
$ kubectl get deploy -A $ kubectl get deploy -A
NAMESPACE NAME READY UP-TO-DATE AVAILABLE AGE NAMESPACE NAME READY UP-TO-DATE AVAILABLE AGE
default curry-probe-test001 1/1 1 1 11m default curry-probe-test001 1/1 1 1 11m
kube-system kuryr-controller 1/1 1 1 42d kube-system coredns 2/2 2 2 28h
.. note:: .. note::

View File

@ -950,7 +950,7 @@ we can append ``-A`` to the command line.
$ kubectl get deploy -A $ kubectl get deploy -A
NAMESPACE NAME READY UP-TO-DATE AVAILABLE AGE NAMESPACE NAME READY UP-TO-DATE AVAILABLE AGE
default vdu1 2/2 2 2 8m46s default vdu1 2/2 2 2 8m46s
kube-system kuryr-controller 1/1 1 1 10d kube-system coredns 2/2 2 2 28h
.. note:: .. note::

View File

@ -1168,7 +1168,7 @@ we can append ``-A`` to the command line.
NAMESPACE NAME READY UP-TO-DATE AVAILABLE AGE NAMESPACE NAME READY UP-TO-DATE AVAILABLE AGE
default vdu1-vnff082149ac20f43dfbc711fde035a1197 1/1 1 1 6m42s default vdu1-vnff082149ac20f43dfbc711fde035a1197 1/1 1 1 6m42s
default vdu2-vnff082149ac20f43dfbc711fde035a1197 1/1 1 1 6m42s default vdu2-vnff082149ac20f43dfbc711fde035a1197 1/1 1 1 6m42s
kube-system kuryr-controller 1/1 1 1 31d kube-system coredns 2/2 2 2 28h
.. note:: .. note::

View File

@ -18,6 +18,20 @@
state: restarted state: restarted
become: yes become: yes
- name: Get coredns name
shell: >
kubectl get pod -n kube-system --no-headers -o custom-columns=":metadata.name"
| grep coredns | tr -s '\n' ' '
register: coredns_name
become: yes
become_user: stack
- name: Restart coredns pod
shell: >
kubectl delete pod -n kube-system {{ coredns_name.stdout }}
become: yes
become_user: stack
when: when:
- inventory_hostname == 'controller-k8s' - inventory_hostname == 'controller-k8s'
- k8s_api_url is defined - k8s_api_url is defined