Angenommen, der Kubernetes-Cluster wurde konfiguriert, erstellen wir eine virtuelle Maschine für Nginx basierend auf CentOS.
Hier sind die Details der Einstellungen im Experiment:
Nginx (CenOS8 Minimal) – 192.168.1.50
Kube Master – 192.168.1.40
Kube Worker 1 & ndash; 1.41.
[root@nginxlb ~]# dnf install epel-release -y
[root@nginxlb ~]# dnf install nginx -y
Überprüfen Sie die Nginx-Paketdetails mit dem rpm-Befehl:[root@nginxlb ~]# rpm -qi nginx
[root@nginxlb ~]# firewall-cmd --permanent --add-service=http[root@nginxlb ~]# firewall-cmd --permanent --add-service=https[root@nginxlb ~]# firewall-cmd –reload
[root@nginxlb ~]# sed -i s/^SELINUX=.*$/SELINUX=permissive/ /etc/selinux/config[root@nginxlb ~]# reboot
Schritt 3) Holen Sie sich die NodePort-Details der Anwendung von Kubernetes
[kadmin@k8s-master ~]$ kubectl get all -n ingress-nginx
Schritt 4) Nginx für den Lastausgleich konfigurieren
Bearbeiten Sie die Nginx-Konfigurationsdatei und fügen Sie Folgendes hinzu:
[root@nginxlb ~]# vim /etc/nginx/nginx.conf
upstream backend { server 192.168.1.41:32760; server 192.168.1.42:32760; } server { listen 80; location / { proxy_read_timeout 1800; proxy_connect_timeout 1800; proxy_send_timeout 1800; send_timeout 1800; proxy_set_header Accept-Encoding ""; proxy_set_header X-Forwarded-By $server_addr:$server_port; proxy_set_header X-Forwarded-For $remote_addr; proxy_set_header X-Forwarded-Proto $scheme; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_pass http://backend; } location /nginx_status { stub_status; } }
Speichern Sie die Konfigurationsdatei und beenden Sie den Vorgang.
Gemäß den oben genannten Änderungen werden alle Anfragen an Port 80 von Nginx an den NodePort (32760)-Port des Kubernetes-Worker-Knotens (192.168.1.41 und 192.168.1.42) weitergeleitet.
Aktivieren Sie den Nginx-Dienst mit dem folgenden Befehl:
[root@nginxlb ~]# systemctl start nginx[root@nginxlb ~]# systemctl enable nginx
Testen Sie den TCP-Load-Balancer von Nginx.
Um zu testen, ob Nginx als TCP-Load-Balancer für Kubernetes ordnungsgemäß funktioniert, stellen Sie eine Nginx-basierte Bereitstellung bereit und stellen Sie den Port der Bereitstellung bereit 80-Port und definieren Sie Einstiegsressourcen für die Nginx-Bereitstellung. Ich habe den folgenden Befehl verwendet, um diese Kubernetes-Objekte bereitzustellen:[kadmin@k8s-master ~]$ kubectl create deployment nginx-deployment --image=nginx deployment.apps/nginx-deployment created [kadmin@k8s-master ~]$ kubectl expose deployments nginx-deployment --name=nginx-deployment --type=NodePort --port=80 service/nginx-deployment exposed
[root@localhost ~]# echo "192.168.1.50 nginx-lb.example.com" >> /etc/hosts
Das obige ist der detaillierte Inhalt vonSo konfigurieren Sie den TCP-Lastausgleich in Nginx. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!