部署istio環境參考istio官網
建立獨立名稱空間go-admin,自動注入 sidecar
kubectl create namespace go-admin
kubectl label namespace go-admin istio-injection=enabled
建立配置configmap
kubectl create configmap settings-admin --from-file=config/settings.yml -n go-admin
pv及pvc根據自己到需求調整
kubectl apply -f storage.yml -n go-admin
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: go-admin
namespace: go-admin
spec:
accessModes:
- ReadWriteMany
resources:
requests:
storage: "1Mi"
volumeName:
storageClassName: nfs-csi
配置
kubectl apply -f deploy.yml -n go-admin
---
apiVersion: v1
kind: Service
metadata:
name: go-admin
namespace: go-admin
labels:
app: go-admin
service: go-admin
spec:
ports:
- port: 8000
name: http
protocol: TCP
selector:
app: go-admin
---
apiVersion: apps/v1
kind: Deployment
metadata:
name: go-admin-v1
namespace: go-admin
labels:
app: go-admin
version: v1
spec:
replicas: 1
selector:
matchLabels:
app: go-admin
version: v1
template:
metadata:
labels:
app: go-admin
version: v1
spec:
containers:
- name: go-admin
image: registry.cn-shanghai.aliyuncs.com/go-admin-team/go-admin:v1.2.2
imagePullPolicy: IfNotPresent
ports:
- containerPort: 8000
volumeMounts:
- name: go-admin
mountPath: /temp
- name: go-admin
mountPath: /static
- name: go-admin-config
mountPath: /config/
readOnly: true
volumes:
- name: go-admin
persistentVolumeClaim:
claimName: go-admin
- name: go-admin-config
configMap:
name: settings-admin
---
建立前端nginx配置configmap
kubectl create configmap nginx-frontend --from-file=default.conf -n go-admin
server {
listen 80;
listen [::]:80;
server_name localhost;
location / {
root /usr/share/nginx/html;
index index.html index.htm;
}
}
kubectl apply -f deploy.yml
---
apiVersion: v1
kind: Service
metadata:
name: go-admin-ui
namespace: go-admin
labels:
app: go-admin-ui
service: go-admim-ui
spec:
ports:
- port: 80
name: http
protocol: TCP
selector:
app: go-admin-ui
---
apiVersion: apps/v1
kind: Deployment
metadata:
name: go-admin-ui-v1
namespace: go-admin
labels:
app: go-admin-ui
version: v1
spec:
replicas: 1
selector:
matchLabels:
app: go-admin-ui
version: v1
template:
metadata:
labels:
app: go-admin-ui
version: v1
spec:
containers:
- name: go-admin-ui
image: registry.cn-shanghai.aliyuncs.com/go-admin-team/go-admin-ui:v1.2.2
imagePullPolicy: IfNotPresent
ports:
- containerPort: 80
volumeMounts:
- name: frontendconf
mountPath: /etc/nginx/conf.d/default.conf
subPath: default.conf
readOnly: true
volumes:
- name: frontendconf
configMap:
name: nginx-frontend
---
建立dr
kubectl apply -f destination-go-admin.yaml -n go-admin
apiVersion: networking.istio.io/v1alpha3
kind: DestinationRule
metadata:
name: go-admin-ui
namespace: go-admin
spec:
host: go-admin-ui
subsets:
- name: v1
labels:
version: v1
---
apiVersion: networking.istio.io/v1alpha3
kind: DestinationRule
metadata:
name: go-admin
namespace: go-admin
spec:
host: go-admin
subsets:
- name: v1
labels:
version: v1
建立gateway和vs(域名改成實際域名)
kubectl apply -f go-admin-gateway.yml -n go-admin
---
apiVersion: networking.istio.io/v1alpha3
kind: Gateway
metadata:
name: go-admin-gateway
namespace: go-admin
spec:
selector:
istio: ingressgateway
servers:
- port:
number: 80
name: http
protocol: HTTP
hosts:
- "go-admin.xxxxxx.com"
---
apiVersion: networking.istio.io/v1alpha3
kind: VirtualService
metadata:
name: go-admin-ui
namespace: go-admin
spec:
hosts:
- "*"
gateways:
- go-admin-gateway
http:
- match:
- uri:
prefix: /api
- uri:
prefix: /login
route:
- destination:
host: go-admin
subset: v1
port:
number: 8000
- match:
- uri:
prefix: /
route:
- destination:
host: go-admin-ui
subset: v1
port:
number: 80
本作品採用《CC 協議》,轉載必須註明作者和本文連結