Nginx Ingress 配置
手动部署Nginx Ingress
通常我们在
定义服务
我们将创建第一个
# vim app1.yaml
apiVersion: apps / v1
kind: Deployment
metadata :
name: app1
spec :
replicas: 2
selector :
matchLabels :
app: app1
template :
metadata :
labels :
app: app1
spec :
containers :
- image: dockersamples/static-site
name: app1
env :
- name: AUTHOR
value: GIROPOPS
ports :
- containerPort: 80
# vim app2.yaml
apiVersion: apps / v1
kind: Deployment
metadata :
name: app2
spec :
replicas: 2
selector :
matchLabels :
app: app2
template :
metadata :
labels :
app: app2
spec :
containers :
- image: dockersamples/static-site
name: app2
env :
- name: AUTHOR
value: STRIGUS
ports :
- containerPort: 80
我们将使用以下命令在集群中创建部署:
$ kubectl create -f app1.yaml
deployment.apps/app1 created
$ kubectl create -f app2.yaml
deployment.apps/app2 created
然后配置服务:
# vim svc-app1.yaml
apiVersion: v1
kind: Service
metadata :
name: appsvc1
spec :
ports :
- port: 80
protocol: TCP
targetPort: 80
selector :
app: app1
# vim svc-app2.yaml
apiVersion: v1
kind: Service
metadata :
name: appsvc2
spec :
ports :
- port: 80
protocol: TCP
targetPort: 80
selector :
app: app2
让我们用以下命令在集群中创建服务:
$ kubectl create -f svc-app1.yaml
service/appsvc1 created
$ kubectl create -f svc-app2.yaml
service/appsvc2 created
我们刚刚从一个静态网站上创建了两个
$ kubectl get deploy
NAME DESIRED CURRENT UP-TO-DATE AVAILABLE AGE
app1 2 2 2 2 3m
app2 2 2 2 2 3m
$ kubectl get services
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
appsvc1 ClusterIP 10.107.228.40 <none> 80/TCP 2m
appsvc2 ClusterIP 10.97.250.131 <none> 80/TCP 2m
kubernetes ClusterIP 10.96.0.1 <none> 443/TCP 11d
让我们列出服务的
$ kubectl get ep
NAME ENDPOINTS AGE
appsvc1 10.44.0.11:80,10.44.0.12:80 4m
appsvc2 10.32.0.4:80,10.44.0.13:80 4m
kubernetes 10.142.0.5:6443 11d
现在让我们访问这些站点,看看我们在
$ curl 10.44.0.11
...
<h1 id="toc_0">Hello GIROPOPS!</h1>
<p>This is being served from a <b>docker</b><br>
container running Nginx.</p>
$ curl 10.32.0.4
h1 id="toc_0">Hello STRIGUS!</h1>
<p>This is being served from a <b>docker</b><br>
container running Nginx.</p>
定义后端
让我们为后台创建一个部署:
$ vim default-backend.yaml
apiVersion: apps/v1
kind: Deployment
metadata :
name: default-backend
spec :
replicas: 2
selector :
matchLabels :
app: default-backend
template :
metadata :
labels :
app: default-backend
spec :
terminationGracePeriodSeconds: 60
containers :
- name: default-backend
image: gcr.io/google_containers/defaultbackend:1.0
livenessProbe :
httpGet :
path: /healthz
port: 8080
scheme: HTTP
initialDelaySeconds: 30
timeoutSeconds: 5
ports :
- containerPort: 8080
resources :
limits :
cpu: 10m
memory: 20Mi
requests :
cpu: 10m
memory: 20Mi
注意前面文件中的以下参数。
terminationGracePeriodSeconds => 在用SIGTERM 信号执行强制终止之前,它将等待pod 完成的时间,以秒为单位。livenessProbe => 检查pod 是否还在运行,如果不在运行,它kubelet 将移除容器并启动另一个容器。readnessProbe => 检查容器是否准备好接收服务的请求。initialDelaySeconds => 告诉kubele 应该等待多少秒来执行第一次livenessProbe 检查。timeoutSeconds => 被认为是探针执行超时的时间(以秒为单位) ,默认值为1 。periodSeconds => 确定检查livenessProbe 的频率。
定义Nginx Ingress
然后创建
$ kubectl create namespace ingress
namespace/ingress created
$ kubectl create -f default-backend.yaml -n ingress
deployment.apps/default-backend created
$ vim default-backend-service.yaml
apiVersion: v1
kind: Service
metadata :
name: default-backend
spec :
ports :
- port: 80
protocol: TCP
targetPort: 8080
selector :
app: default-backend
在命名空间
$ kubectl create -f default-backend-service.yaml -n ingress
service/default-backend created
$ kubectl get deployments.
NAME DESIRED CURRENT UP-TO-DATE AVAILABLE AGE
app1 2 2 2 2 29m
app2 2 2 2 2 28m
$ kubectl get deployments. -n ingress
NAME DESIRED CURRENT UP-TO-DATE AVAILABLE AGE
default-backend 2 2 2 2 27s
$ kubectl get service
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
appsvc1 ClusterIP 10.98.174.69 <none> 80/TCP 28m
appsvc2 ClusterIP 10.96.193.198 <none> 80/TCP 28m
kubernetes ClusterIP 10.96.0.1 <none> 443/TCP 11d
$ kubectl get service -n ingress
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
default-backend ClusterIP 10.99.233.157 <none> 80/TCP 38s
$ kubectl get ep -n ingress
NAME ENDPOINTS AGE
default-backend 10.32.0.14:8080,10.40.0.4:8080 2m
现在创建一个文件来定义一个
$ vim nginx-ingress-controller-config-map.yaml
apiVersion: v1
kind: ConfigMap
metadata :
name: nginx-ingress-controller-conf
labels :
app: nginx-ingress-lb
data :
enable-vts-status: true
然后创建
$ kubectl create -f nginx-ingress-controller-config-map.yaml -n ingress
configmap/nginx-ingress-controller-conf created
$ kubectl get configmaps -n ingress
NAME DATA AGE
nginx-ingress-controller-conf 1 20s
$ kubectl describe configmaps nginx-ingress-controller-conf -n ingress
Name: nginx-ingress-controller-conf
Namespace: ingress
Labels: app=nginx-ingress-lb
Annotations: <none>
Data
====
enable-vts-status:
----
true
Events: <none>
然后创建关联的
$ vim nginx-ingress-controller-service-account.yaml
apiVersion: v1
kind: ServiceAccount
metadata :
name: nginx
namespace: ingress
$ vim nginx-ingress-controller-clusterrole.yaml
kind: ClusterRole
apiVersion: rbac.authorization.k8s.io/v1
metadata :
name: nginx-role
rules :
- apiGroups :
- " "
- " extensions "
resources :
- configmaps
- secrets
- endpoints
- ingresses
- nodes
- pods
verbs :
- list
- watch
- apiGroups :
- " "
resources :
- services
verbs :
- list
- watch
- get
- update
- apiGroups :
- " extensions "
resources :
- ingresses
verbs :
- get
- apiGroups :
- " "
resources :
- events
verbs :
- create
- apiGroups :
- " extensions "
resources :
- ingresses / status
verbs :
- update
- apiGroups :
- " "
resources :
- configmaps
verbs :
- get
- create
$ vim nginx-ingress-controller-clusterrolebinding.yaml
kind: ClusterRoleBinding
apiVersion: rbac.authorization.k8s.io/v1
metadata :
name: nginx-role
namespace: ingress
roleRef :
apiGroup: rbac.authorization.k8s.io
kind: ClusterRole
name: nginx-role
subjects :
- kind: ServiceAccount
name: nginx
namespace: ingress
然后将这些配置作用到
$ kubectl create -f nginx-ingress-controller-service-account.yaml -n ingress
serviceaccount/nginx created
$ kubectl create -f nginx-ingress-controller-clusterrole.yaml -n ingress
clusterrole.rbac.authorization.k8s.io/nginx-role created
$ kubectl create -f nginx-ingress-controller-clusterrolebinding.yaml -n ingress
clusterrolebinding.rbac.authorization.k8s.io/nginx-role created
然后创建另一个部署:
# vim nginx-ingress-controller-deployment.yaml
apiVersion: apps / v1
kind: Deployment
metadata :
name: nginx-ingress-controller
spec :
replicas: 1
selector :
matchLabels :
app: nginx-ingress-lb
revisionHistoryLimit: 3
template :
metadata :
labels :
app: nginx-ingress-lb
spec :
terminationGracePeriodSeconds: 60
serviceAccount: nginx
containers :
- name: nginx-ingress-controller
image: quay.io/kubernetes-ingress-controller/nginx-ingress-controllerContact.9.0
imagePullPolicy: Always
readinessProbe :
httpGet :
path: / healthz
port: 10254
scheme: HTTP
livenessProbe :
httpGet :
path: / healthz
port: 10254
scheme: HTTP
initialDelaySeconds: 10
timeoutSeconds: 5
args :
- / nginx-ingress-controller
- --default-backend-service = ingress/default-backend
- --configmap = ingress/nginx-ingress-controller-conf
- --v=2
env :
- name: POD_NAME
valueFrom :
fieldRef :
fieldPath: metadata.name
- name: POD_NAMESPACE
valueFrom :
fieldRef :
fieldPath: metadata.namespace
ports :
- containerPort: 80
- containerPort: 18080
$ kubectl create -f nginx-ingress-controller-deployment.yaml -n ingress
deployment.apps/nginx-ingress-controller created
最后,我们就来定义
# vim nginx-ingress.yaml
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata :
name: nginx-ingress
spec :
rules :
- host: ec2-54-198-119-88.compute-1.amazonaws.com # Change to your dns address
http :
paths :
- backend :
service :
name: nginx-ingress
port :
number: 18080
path: /nginx_status
pathType: Prefix
现在创建一个文件来定义将重定向到我们在本节开头创建的应用程序的服务的入口。
# vim app-ingress.yaml
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata :
annotations :
nginx.ingress.kubernetes.io/rewrite-target: /
name: app-ingress
spec :
rules :
- host: ec2-54-198-119-88.compute-1.amazonaws.com # Change to your dns address
http :
paths :
- backend :
service :
name: appsvc1
port :
number: 80
path: /app1
pathType: Prefix
- backend :
service :
name: appsvc2
port :
number: 80
path: /app2
pathType: Prefix
$ kubectl create -f nginx-ingress.yaml -n ingress
ingress.networking.k8s.io/nginx-ingress created
$ kubectl create -f app-ingress.yaml
ingress.networking.k8s.io/app-ingress created
$ kubectl get ingresses -n ingress
NAME HOSTS ADDRESS PORTS AGE
nginx-ingress ec2-54-159-116-229.compute-1.amazonaws.com 80 35s
$ kubectl get ingresses
NAME HOSTS ADDRESS PORTS AGE
app-ingress ec2-54-159-116-229.compute-1.amazonaws.com 80 16s
$ kubectl describe ingresses.extensions nginx-ingress -n ingress
Name: nginx-ingress
Namespace: ingress
Address:
Default backend: default-http-backend:80 (<none>)
Rules:
Host Path Backends
---- ---- --------
ec2-54-159-116-229.compute-1.amazonaws.com
/nginx_status nginx-ingress:18080 (<none>)
Annotations:
Events:
Type Reason Age From Message
---- ------ ---- ---- -------
Normal CREATE 50s nginx-ingress-controller Ingress ingress/nginx-ingress
$ kubectl describe ingresses.extensions app-ingress
Name: app-ingress
Namespace: default
Address:
Default backend: default-http-backend:80 (<none>)
Rules:
Host Path Backends
---- ---- --------
ec2-54-159-116-229.compute-1.amazonaws.com
/app1 appsvc1:80 (<none>)
/app2 appsvc2:80 (<none>)
Annotations:
nginx.ingress.kubernetes.io/rewrite-target: /
Events:
Type Reason Age From Message
---- ------ ---- ---- -------
Normal CREATE 1m nginx-ingress-controller Ingress default/app-ingress
然后我们创建一个
# vim nginx-ingress-controller-service.yaml
apiVersion: v1
kind: Service
metadata :
name: nginx-ingress
spec :
type: NodePort
ports :
- port: 80
nodePort: 30000
name: http
- port: 18080
nodePort: 32000
name: http-mgmt
selector :
app: nginx-ingress-lb
$ kubectl create -f nginx-ingress-controller-service.yaml -n=ingress
service/nginx-ingress created
这样我们就可以直接在外部访问到了:
$ curl http://SEU-ENDEREÇO:30000/app1
$ curl http://SEU-ENDEREÇO:30000/app2
$ curl http://SEU-ENDEREÇO:32000/nginx_status