Lab10.1 - Error creating ingress rule: "pathType must be specified"
Hi there,
I am working through the LFS258 course and have properly gone through all the labs in sequence successfully up to Lab10.1 so far.
Now, in that Lab exercise, the step 9 (Ingest the ingress rule) fails:
student@lfs258-master:~$ kubectl create -f ingress.rule.yaml error: error validating "ingress.rule.yaml": error validating data: [ValidationError(Ingress.spec.rules[0].http.paths[0].backend): unknown field "serviceName" in io.k8s.api.networking.v1.IngressBackend, ValidationError(Ingress.spec.rules[0].http.paths[0].backend): unknown field "servicePort" in io.k8s.api.networking.v1.IngressBackend]; if you choose to ignore these errors, turn validation off with --validate=false
When I add the mentioned --validate=false Flag, there is another error:
student@lfs258-master:~$ kubectl create -f ingress.rule.yaml --validate=false The Ingress "ingress-test" is invalid: spec.rules[0].http.paths[0].pathType: Required value: pathType must be specified
I am running on Kubernetes 1.19.6 ... got anything deprecated here?
Thanks for help ..
Comments
-
Hi @wodecker,
There may be several aspects to cause these errors.
The course is asking for Kubernetes v1.19.0 - to keep it aligned with the CKA certification exam environment, and it has not been tested against v1.19.6.
The easiest method to fix your first error and move forward would be to update the
apiVersionin theingress.rule.yamlfile withapiVersion: networking.k8s.io/v1beta1, as it is presented in the YAML code on Step 8 of the lab manual. Upgrading theIngressresource from beta (v1beta1) to stable (v1) requires some of the YAML fields to be re-formatted according to the latest documentation, but this method has not been tested and validated against the exercise.For the second error, inspect carefully the YAML code in Step 15, where each
path: /is followed bypathType: ImplementationSpecificline. Adding thepathTypeshould eliminate this error.Between Kubernetes v1.19 and 1.20 the
Ingressobject matured from beta to stable, it introduced changes in the YAML formatting, resulting in inconsistent behaviors betweenIngressobject deployments. This type of behavior is often encountered as objects mature between Kubernetes releases.Regards,
-Chris0 -
Hi @chrispokorni ,
thanks for the quick response. Indeed I discovered that the pathType parameter has been added to the yaml in step 15, but unfortunately it was not yet there in step 8, so I didn't get aware of this on first try ..
But also with that parameter added, there was still an error:
student@lfs258-master:~$ kubectl create -f ingress.rule.yaml --validate=false The Ingress "ingress-test" is invalid: spec.rules[0].http.paths[0].backend: Invalid value: "": resource or service backend is required
I then checked kubernetes documentation here: https://kubernetes.io/docs/concepts/services-networking/ingress/#the-ingress-resource
Based on that, I changed the backend configuration to probably newer syntax:
spec: rules: - host: www.example.com http: paths: - backend: service: name: secondapp port: number: 80 path: / pathType: ImplementationSpecificWith that spec, I succeeded in creating the Ingress Rule ...
BTW, I upgraded to 1.19.6 instead of 1.19.0 in Lab4.1 because I got some message in step 7 there asking me to upgrade to the latest 1.19 version (which was 1.19.6 then)
Thanks and kind Regards,
Wolfgang1 -
During the upgrade you can pick any version in the process, you are not required to upgrade to the latest version.
If the apiVersion is
v1, then the new syntax needs to be followed, however, I have seen some issues when theIngressresource would jump back and forth between the two versions. The most stable at the time was also the easiest way, with the least amount of typing, to stay onv1beta1instead.Regards,
-Chris0
Categories
- All Categories
- 177 LFX Mentorship
- 177 LFX Mentorship: Linux Kernel
- 750 Linux Foundation IT Professional Programs
- 373 Cloud Engineer IT Professional Program
- 169 Advanced Cloud Engineer IT Professional Program
- 74 DevOps IT Professional Program - Discontinued
- 4 DevOps & GitOps IT Professional Program
- 99 Cloud Native Developer IT Professional Program
- 7.6K Training Courses & Learning Paths
- 1 AI & ML Training
- 1 Blockchain & Decentralized Identity Training
- 4 Cloud & Containers Training
- 1 Cybersecurity Training
- 2 DevOps & Site-Reliability Training
- 1 Linux Kernel Development Training
- 1 Networking Training
- 2 Open Source Best Practice Training
- 1 System Administration Training
- 1 System Engineering Training
- 1 Web & Application Development Training
- 792 Hardware
- 202 Drivers
- 68 I/O Devices
- 37 Monitors
- 95 Multimedia
- 173 Networking
- 91 Printers & Scanners
- 87 Storage
- 769 Linux Distributions
- 81 Debian
- 68 Fedora
- 22 Linux Mint
- 13 Mageia
- 24 openSUSE
- 150 Red Hat Enterprise
- 31 Slackware
- 13 SUSE Enterprise
- 356 Ubuntu
- 465 Linux System Administration
- 31 Cloud Computing
- 73 Command Line/Scripting
- Github systems admin projects
- 98 Linux Security
- 78 Network Management
- 101 System Management
- 46 Web Management
- 106 Mobile Computing
- 18 Android
- 73 Development
- 1.2K New to Linux
- 1K Getting Started with Linux
- 392 Off Topic
- 121 Introductions
- 181 Small Talk
- 29 Study Material
- 955 Programming and Development
- 310 Kernel Development
- 627 Software Development
- 984 Software
- 376 Applications
- 182 Command Line
- 5 Compiling/Installing
- 68 Games
- 317 Installation
- Archived
- 2 LFD140 Class Forum
- 1.4K LFS258 Class Forum
Upcoming Training
-
August 20, 2018
Kubernetes Administration (LFS458)
-
August 20, 2018
Linux System Administration (LFS301)
-
August 27, 2018
Open Source Virtualization (LFS462)
-
August 27, 2018
Linux Kernel Debugging and Security (LFD440)