文章目录
- 前言
- 环境
- ingress安装
- 应用案例(ingress-http案例: 基于名称的负载均衡)
前言
这个是nodeport模式下的,如果需要loadbalancer模式下的,看看博主下面以前的博客
链接: k8s学习–负载均衡器matelLB的详细解释与安装
链接: k8s学习–ingress详细解释与应用(nginx ingress controller))
环境
虚拟机
Ip | 主机名 | cpu | 内存 | 硬盘 |
---|---|---|---|---|
192.168.10.11 | master01 | 2cpu双核 | 4G | 100G |
192.168.10.12 | worker01 | 2cpu双核 | 4G | 100G |
192.168.10.13 | worker02 | 2cpu双核 | 4G | 100G |
版本 rockylinux9.2
已部署k8s-1.28.2
ingress安装
因为默认就是nodeport模式,所以直接通过网络路径应用配置文件即可
注: 需要VPN
kubectl apply -f https://raw.githubusercontent.com/kubernetes/ingress-nginx/main/deploy/static/provider/baremetal/deploy.yaml
查看pod状态
kubectl get pod -n ingress-nginx
如果网络不佳,可能过程会较长,耐心等待或者直接下载相关镜像皆可
应用案例(ingress-http案例: 基于名称的负载均衡)
1.创建并进入一个空目录
mkdir nginx && cd nginx
2.创建deployment控制器类型应用
vim nginx.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
name: nginx
namespace: ingress-nginx
spec:
replicas: 2
selector:
matchLabels:
app: nginx
template:
metadata:
labels:
app: nginx
spec:
containers:
- name: c1
image: nginx:1.20
imagePullPolicy: IfNotPresent
应用yaml文件
kubectl apply -f nginx.yaml
查看pod状态
kubectl get pod -n ingress-nginx
3..创建service
vim nginx-service.yaml
apiVersion: v1
kind: Service
metadata:
name: nginx-service
namespace: ingress-nginx
labels:
app: nginx
spec:
ports:
- port: 80
targetPort: 80
selector:
app: nginx
应用yaml文件
kubectl apply -f nginx-service.yaml
查看svc是否被成功创建
kubectl get -n ingress-nginx svc
4.创建ingress对象
vim ingress-nginx.yaml
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
name: ingress-nginx #自定义ingress对象名称
namespace: ingress-nginx
annotations: #注解,声明
ingressclass.kubernetes.io/is-default-class: "true" #ingress控制器由标记的class作为默认class
spec:
ingressClassName: nginx #此处标记出ingressClass为nginx
rules:
- host: www.test.com # 自定义域名
http:
paths:
- pathType: Prefix
path: "/"
backend:
service:
name: nginx-service # 对应上面创建的service名称
port:
number: 80
应用yaml文件
kubectl apply -f ingress-nginx.yaml
查看ingress
kubectl get ingress -n ingress-nginx
查看ingress的详细信息
kubectl get ingress -n ingress-nginx
可以看到对应的规则及podip
查看podip是否一致
这条命令是查看service的服务端点列表,也就是存放他对应pod的ip
kubectl get endpoints -n ingress-nginx nginx-service
可以看出是一致的
为了查看轮询效果,在nginxpod中添加不一样的字母来区分
查看pod名称
kubectl get pod -n ingress-nginx
第一个pod
[root@k8s-master01 nginx]# kubectl exec -it -n ingress-nginx nginx-65799cd94d-qj2xx -- /bin/bash
root@nginx-65799cd94d-qj2xx:/# echo "nginx1 is running" > /usr/share/nginx/html/index.html
root@nginx-65799cd94d-qj2xx:/# exit
第二个pod
[root@k8s-master01 nginx]# kubectl exec -it -n ingress-nginx nginx-65799cd94d-sb5m8 -- /bin/bash
root@nginx-65799cd94d-sb5m8:/# echo "nginx2 is running" > /usr/share/nginx/html/index.html
root@nginx-65799cd94d-sb5m8:/# exit
在宿主机hosts中添加解析
由于是nodeport模式,所以解析写成三个节点的哪个ip都可以,我这里就写12的ip了
192.168.10.12 www.test.com
需要注意的是,由于nodeport模式下开放的端口不固定,所以需要在域名后面加端口号
查看需要的端口号
kubectl get svc -n ingress-nginx
我这里是31868,根据自己的来
访问
可以看到是有轮询的效果的