nginx负载均衡k8s中的service

[root@master ~]# cat web01.yaml 
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: web1
  namespace: default
spec:
  replicas: 1
  selector:
    matchLabels:
      app: web1
  template:  
    metadata:
      labels:
        app: web1
    spec:
      containers:
      - name: web1
        image: jiejiehao/httpd:v1
---
apiVersion: v1
kind: Service
metadata:
  name: web1
  namespace: default
spec:
  ports:
  - port: 80
    protocol: TCP
    targetPort: 80
    nodePort: 30000
  selector:
    app: web1
  type: NodePort

[root@master ~]# cat web02.yaml 
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: web2
  namespace: default
spec:
  replicas: 1
  selector:
    matchLabels:
      app: web2
  template:  
    metadata:
      labels:
        app: web2
    spec:
      containers:
      - name: httpd
        image: jiejiehao/httpd:v2
---
apiVersion: v1
kind: Service
metadata:
  name: web2
  namespace: default
spec:
  ports:
  - port: 80
    protocol: TCP
    targetPort: 80
    nodePort: 31000
  selector:
    app: web2
  type: NodePort

[root@master ~]# kubectl apply -f web01.yaml 
deployment.apps/web1 unchanged
service/web1 unchanged

[root@master ~]# kubectl apply -f web02.yaml 
deployment.apps/web2 unchanged
service/web2 unchanged


[root@master ~]# kubectl get svc
NAME         TYPE        CLUSTER-IP      EXTERNAL-IP   PORT(S)        AGE
kubernetes   ClusterIP   10.96.0.1       <none>        443/TCP        9d
web1         NodePort    10.105.63.49    <none>        80:30000/TCP   35m
web2         NodePort    10.99.141.3     <none>        80:31000/TCP   60m



[root@master ~]# kubectl get node -o wide
NAME     STATUS     ROLES                  AGE   VERSION   INTERNAL-IP      EXTERNAL-IP   OS-IMAGE                               KERNEL-VERSION          CONTAINER-RUNTIME
master   Ready      control-plane,master   9d    v1.20.0   192.168.47.115   <none>        Red Hat Enterprise Linux 8.2 (Ootpa)   4.18.0-193.el8.x86_64   docker://20.10.12
node1    Ready      <none>                 9d    v1.20.0   192.168.47.120   <none>        Red Hat Enterprise Linux 8.2 (Ootpa)   4.18.0-193.el8.x86_64   docker://20.10.12
node2    Ready      <none>                 9d    v1.20.0   192.168.47.121   <none>        Red Hat Enterprise Linux 8.2 (Ootpa)   4.18.0-193.el8.x86_64   docker://20.10.12



[root@master ~]# curl 192.168.47.120:30000
test page on v1
[root@master ~]# curl 192.168.47.121:31000
test page on v2



yum -y install nginx

[root@docker ~]# curl 192.168.47.120:30000
test page on v1
[root@docker ~]# curl 192.168.47.121:31000
test page on v2

systemctl start nginx

vim /etc/nginx/nginx.conf
    upstream webservers {
        server 192.168.47.120:30000;
        server 192.168.47.121:31000;
   }
    server{
        listen       80;
        server_name  localhost;
        location / {
            proxy_pass http://webservers;
        }
        
systemctl restart nginx
Kubernetes (k8s) 是一个开源的容器编排平台,用于自动化容器化应用程序的部署、扩展和管理。在 k8s 负载均衡是一个核心功能,用于处理多个节点间的流量分发,确保服务的高可用性和性能。以下是 Kubernetes 实现负载均衡的基本方法: 1. **内置服务(Service)**: 使用 k8s 的 `Service` 对象,它可以将流量路由到后端的 pod。服务支持多种类型的负载均衡,如: - **ClusterIP**: 内部 IP,仅对集群内部可见,适合不需要外部访问的应用场景。 - **NodePort**: 配置端口映射,允许从外部直接访问服务。 - **LoadBalancer** 或 **ExternalName**: 如果集群支持云提供商的负载均衡器,可以创建外部负载均衡器来处理流量。 2. **Ingress**: 一个高级别资源,用于定义网络规则并可以关联到多个服务。Ingress 提供了更灵活的配置选项,如路径、SSL/TLS终止等,并可以使用第三方控制器(如 NGINX Ingress Controller)来实现更复杂的负载均衡策略。 3. **Envoy**: 在 Istio 或其他类似的服务网格解决方案,Envoy 作为一个高性能的边缘代理被用作负载均衡器,它能提供细粒度的路由控制和可扩展性。 4. **自定义负载均衡器**: 用户可以通过部署自己的部署或使用 Helm charts 安装第三方负载均衡器,如 HAProxy、Traefik 等。 相关问题--: 1. Kubernetes 的哪些服务类型支持负载均衡? 2. 如何通过 Ingress 实现更复杂的路由策略? 3. Envoy 在 Kubernetes 的角色是什么? 4. Kubernetes 负载均衡如何考虑高可用性?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值