k8s安装loadbalancer

前言

k8s集群搭建参考:
https://blog.youkuaiyun.com/centrl/article/details/134291473

准备

查看kube-proxy的strictARP模式

kubectl get configmap kube-proxy -n kube-system -o yaml | \
sed -e "s/strictARP: false/strictARP: true/" | \
kubectl diff -f - -n kube-system

修改为true

kubectl get configmap kube-proxy -n kube-system -o yaml | \
sed -e "s/strictARP: false/strictARP: true/" | \
kubectl apply -f - -n kube-system

安装metallb

创建命名空间

kubectl create namespace metallb-system

创建secret

kubectl create secret generic -n metallb-system memberlist --from-literal=secretkey="$(openssl rand -base64 128)"

安装

kubectl apply -f https://raw.githubusercontent.com/metallb/metallb/v0.13.12/config/manifests/metallb-native.yaml

配置L2模式

cat > ip-pool-config.yaml << EOF
apiVersion: metallb.io/v1beta1
kind: IPAddressPool
metadata:
  name: ip-pool01
  namespace: metallb-system
spec:
  addresses:
  - 172.16.16.200-172.16.16.254
---
apiVersion: metallb.io/v1beta1
kind: L2Advertisement
metadata:
  name: l2-ip-pool01
  namespace: metallb-system
spec:
  ipAddressPools:
  - ip-pool01
EOF

创建

kubectl create -f ip-pool-config.yaml

访问测试

创建测试应用

kubectl create deploy nginx --image nginx:latest --port 80 -n default

暴露服务

kubectl expose deployment nginx --name nginx-lb --port 80 --target-port 80 --type LoadBalancer -n default

查看服务

kubectl get svc nginx-lb

集群外访问,打开浏览器访问:

http://${EXTERNAL-IP}:${PORT}
# 依本文环境地址为
http://172.16.16.200:80

删除测试数据

kubectl delete deploy nginx

删除测试服务

kubectl delete svc nginx-lb
Kubernetes中,DNS(Domain Name System)用于解析服务名称到相应的IP地址。要安装DNS,可以按照以下步骤进行操作: 1. 首先,确保你已经安装Kubernetes集群,并且具有足够的权限来进行操作。 2. 使用kubectl命令创建一个DNS配置文件,例如`dns.yaml`,并将以下内容添加到文件中: ```yaml apiVersion: v1 kind: Service metadata: name: kube-dns namespace: kube-system labels: k8s-app: kube-dns spec: selector: k8s-app: kube-dns clusterIP: 10.96.0.10 ports: - name: dns port: 53 protocol: UDP - name: dns-tcp port: 53 protocol: TCP --- apiVersion: v1 kind: ServiceAccount metadata: name: kube-dns namespace: kube-system --- apiVersion: rbac.authorization.k8s.io/v1 kind: ClusterRoleBinding metadata: name: kube-dns roleRef: apiGroup: rbac.authorization.k8s.io kind: ClusterRole name: system:coredns subjects: - kind: ServiceAccount name: kube-dns namespace: kube-system --- apiVersion: apps/v1 kind: Deployment metadata: name: coredns namespace: kube-system labels: k8s-app: kube-dns spec: replicas: 1 selector: matchLabels: k8s-app: kube-dns template: metadata: labels: k8s-app: kube-dns spec: containers: - name: coredns image: k8s.gcr.io/coredns:1.8.0 resources: limits: memory: 170Mi requests: cpu: 100m memory: 70Mi args: ["-conf", "/etc/coredns/Corefile"] volumeMounts: - name: config-volume mountPath: /etc/coredns readOnly: true volumes: - name: config-volume configMap: name: coredns items: - key: Corefile path: Corefile --- apiVersion: v1 kind: ConfigMap metadata: name: coredns namespace: kube-system data: Corefile: | .:53 { errors health { lameduck 5s } ready kubernetes cluster.local in-addr.arpa ip6.arpa { pods insecure upstream fallthrough in-addr.arpa ip6.arpa } prometheus :9153 forward . /etc/resolv.conf { max_concurrent 1000 } cache 30 loop reload loadbalance } ``` 3. 使用kubectl命令创建DNS服务和相关资源: ```shell kubectl apply -f dns.yaml ``` 4. 等待一段时间,直到DNS服务正常运行。你可以使用以下命令检查DNS服务的状态: ```shell kubectl get pods -n kube-system -l k8s-app=kube-dns ``` 如果所有的Pod都处于`Running`状态,表示DNS服务已经安装成功。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值