K8s基于资源定义创建haproxy

编写测试web镜像

[root@master ~]# cat Dockerfile 
FROM busybox

RUN mkdir /data && echo 'hello,this is a xaw' > /data/index.html

CMD ["/bin/httpd","-f","-h","/data"]

[root@master ~]# docker build -t my922/apache:v1.0 .
Sending build context to Docker daemon  3.486MB
Step 1/3 : FROM busybox
latest: Pulling from library/busybox
3cb635b06aa2: Pull complete 
Digest: sha256:b5cfd4befc119a590ca1a81d6bb0fa1fb19f1fbebd0397f25fae164abe1e8a6a
Status: Downloaded newer image for busybox:latest
 ---> ffe9d497c324
Step 2/3 : RUN mkdir /data && echo 'hello,this is a xaw' > /data/index.html
 ---> Running in c7d3780508ae
Removing intermediate container c7d3780508ae
 ---> 6ad4398c8f56
Step 3/3 : CMD ["/bin/httpd","-f","-h","/data"]
 ---> Running in c91474156b62
Removing intermediate container c91474156b62
 ---> ed997eb4e1b8
Successfully built ed997eb4e1b8
Successfully tagged my922/apache:v1.0

[root@master apache]# cat Dockerfile 
FROM busybox

RUN mkdir /data && echo 'hello,this is a my' > /data/index.html

CMD ["/bin/httpd","-f","-h","/data"]

[root@master apache]# docker build -t my922/apache:v2.0 .
Sending build context to Docker daemon  2.048kB
Step 1/3 : FROM busybox
 ---> ffe9d497c324
Step 2/3 : RUN mkdir /data && echo 'hello,this is a my' > /data/index.html
 ---> Running in e679e19f3f83
Removing intermediate container e679e19f3f83
 ---> b696232ef844
Step 3/3 : CMD ["/bin/httpd","-f","-h","/data"]
 ---> Running in 7a77d317fdba
Removing intermediate container 7a77d317fdba
 ---> e36c29e6c5d1
Successfully built e36c29e6c5d1
Successfully tagged my922/apache:v2.0

用这两个镜像做出两个pod并做出两个service

[root@master ~]# cat httpd1.yaml 
---
apiVersion: apps/v1
kind: Deployment
metadata:
  labels:
    app: httpd1
  name: httpd1
spec:
  replicas: 1
  selector:
    matchLabels:
      app: httpd1
  template:
    metadata:
      labels:
        app: httpd1
    spec:
      containers:
      - image: my922/apache:v1.0
        name: httpd1        
---
apiVersion: v1
kind: Service
metadata:
  name: httpd1
spec:
  ports:
  - port: 80
    targetPort: 80
  selector:
    app: httpd1

[root@master ~]# kubectl create -f httpd1.yaml
deployment.apps/httpd1 created
service/httpd1 created

[root@master ~]# cat httpd2.yaml 
---
apiVersion: apps/v1
kind: Deployment
metadata:
  labels:
    app: httpd2
  name: httpd2
spec:
  replicas: 1
  selector:
    matchLabels:
      app: httpd2
  template:
    metadata:
      labels:
        app: httpd2
    spec:
      containers:
      - image: my922/apache:v2.0
        name: httpd2
---
apiVersion: v1
kind: Service
metadata:
  name: httpd2
spec:
  ports:
  - port: 80
    targetPort: 80
  selector:
    app: httpd2


[root@master ~]# kubectl create -f httpd2.yaml
deployment.apps/httpd2 created
service/httpd2 created

查看创建的deployment以及service

[root@master ~]# kubectl get pods,svc
NAME                          READY   STATUS              RESTARTS   AGE
pod/httpd1-7c658c599f-prxkp   0/1     ContainerCreating   0          19s
pod/httpd2-679cf98bc8-nvls7   0/1     ContainerCreating   0          14s

NAME                 TYPE        CLUSTER-IP     EXTERNAL-IP   PORT(S)   AGE
service/httpd1       ClusterIP   10.107.38.25   <none>        80/TCP    19s
service/httpd2       ClusterIP   10.97.201.78   <none>        80/TCP    14s
service/kubernetes   ClusterIP   10.96.0.1      <none>        443/TCP   21h


编写写资源清单定义haproxy

[root@master ~]# cat haproxy.yaml 
piVersion: apps/v1
kind: Deployment
metadata:
  name: haproxy
  namespace: default
  labels:
    app: haproxy
spec:
  selector:
    matchLabels:
      app: haproxy
  template: 
    metadata:
      labels: 
        app: haproxy 
    spec:
      containers:
        - image: my922/haproxy:latest
          imagePullPolicy: IfNotPresent
          name: haproxy
          env:
            - name: RSIP
              value: "10.107.38.25 10.97.201.78 "


---
apiVersion: v1
kind: Service
metadata:
  name: haproxy
spec:
  ports:
  - port: 80
    protocol: TCP
    targetPort: 80
  selector:
    app: haproxy
  type: NodePort


[root@master ~]# kubectl apply -f haproxy.yml 
deployment.apps/haproxy created
service/haproxy created



测试



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Kubernetes(k8s)是一个开源的容器编排平台,haproxy和keepalived是用于部署高可用k8s集群的常见工具。你可以通过以下步骤来配置k8s集群中的haproxy和keepalived。 1. 首先,你需要在所有的master节点和node2节点上安装haproxy和keepalived。你可以使用以下命令在这些节点上安装haproxy和keepalived: ``` yum install -y haproxy keepalived ``` 2. 安装完成后,你可以使用以下命令启动haproxy服务,并查看其状态: ``` systemctl start haproxy systemctl status haproxy ``` 3. 为了确保haproxy在系统启动时自动启动,你可以使用以下命令将其设置为开机自启动: ``` systemctl enable haproxy ``` 4. 在配置haproxy之前,你需要了解你的k8s集群的网络拓扑和IP地址分配情况。根据你的实际情况,你需要修改haproxy的配置文件以反映正确的后端服务器和负载均衡策略。 5. 打开haproxy的配置文件,通常位于`/etc/haproxy/haproxy.cfg`,并根据你的需求进行编辑。在配置文件中,你需要定义后端服务器的IP和端口以及负载均衡算法。你还可以根据需要定义前端监听器和其他选项。 6. 当你完成haproxy的配置后,重新加载配置文件以使更改生效: ``` systemctl reload haproxy ``` 7. 最后,在k8s集群的master节点上配置keepalived以实现高可用性。这可以通过创建keepalived的配置文件并启动keepalived服务来完成。具体配置取决于你的网络拓扑和需求。 综上所述,你可以通过安装和配置haproxy和keepalived来实现k8s集群的高可用性。这样,你就可以确保你的k8s集群在发生故障时能够继续正常运行。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值