Compare commits
11 Commits
Author | SHA1 | Date |
---|---|---|
Sangmin Kim | b5cd9207d6 | |
Sangmin Kim | b194736d7c | |
Sangmin Kim | 3d3794013f | |
Sangmin Kim | 55d449ed63 | |
Sangmin Kim | b88be070fb | |
Sangmin Kim | fd1d33fe56 | |
Sangmin Kim | af159dff03 | |
Sangmin Kim | a4dd3492fe | |
Sangmin Kim | 5f934c40a0 | |
Sangmin Kim | 6bb64c5601 | |
Sangmin Kim | 907676febe |
150
README.md
150
README.md
|
@ -1,2 +1,152 @@
|
||||||
# akashop
|
# akashop
|
||||||
|
https://origin-akashop.akamai-lab.com
|
||||||
|
|
||||||
|
- akashop was built on [woocommerce](https://woo.com/).
|
||||||
|
- akashop is deployed to **tee-origins** kubernetes cluster.
|
||||||
|
|
||||||
|
## How to deploy
|
||||||
|
1. git clone https://gitea-ptl.akamai-lab.com/akamai/akashop.git
|
||||||
|
2. cd akashop/traefik
|
||||||
|
3. kubectl create namespace traefik
|
||||||
|
4. kubectl apply -f kubernetes-crd-definition-v1.yml -f kubernetes-crd-rbac.yml -f traefik-deployment.yml -f traefik-services.yml -n traefik
|
||||||
|
5. kubectl get pods -n traefik
|
||||||
|
```
|
||||||
|
NAME READY STATUS RESTARTS AGE
|
||||||
|
traefik-deployment-6dbb5f6667-wslph 1/1 Running 0 9m2s
|
||||||
|
```
|
||||||
|
6. kubectl get services -n traefik
|
||||||
|
```
|
||||||
|
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
|
||||||
|
traefik-dashboard-service LoadBalancer 10.128.46.205 172.233.169.40 8080:32174/TCP 18h
|
||||||
|
traefik-web LoadBalancer 10.128.2.58 172.233.168.36 80:31310/TCP,443:32696/TCP 18h
|
||||||
|
```
|
||||||
|
7. Vefiry traefik dashboard.
|
||||||
|
```
|
||||||
|
http://{traefik-dashboard-service-external-ip}:8080
|
||||||
|
```
|
||||||
|
8. cd ../akashop
|
||||||
|
9. kubectl create namespace akashop
|
||||||
|
10. kubectl apply -f pv.yml -f pvc.yml -f deployment.yml -f service.yml -f traefik-ingressR.yml -n akashop
|
||||||
|
11. DNS spoofing test
|
||||||
|
```
|
||||||
|
http http://{traefik-web-external-ip} Host:origin-akashop.akamai-lab.com
|
||||||
|
HTTP/1.1 301 Moved Permanently
|
||||||
|
Content-Length: 0
|
||||||
|
Content-Type: text/html; charset=UTF-8
|
||||||
|
Date: Mon, 08 Apr 2024 00:38:47 GMT
|
||||||
|
Location: https://origin-akashop.akamai-lab.com/
|
||||||
|
Server: Apache/2.4.57 (Debian)
|
||||||
|
X-Powered-By: PHP/8.2.17
|
||||||
|
X-Redirect-By: WordPress
|
||||||
|
```
|
||||||
|
12. Update DNS record
|
||||||
|
```
|
||||||
|
origin-akashop.akamai-lab.com. 600 IN A {traefik-web-external-ip}
|
||||||
|
```
|
||||||
|
13. HTTPS test
|
||||||
|
```
|
||||||
|
http https://origin-akashop.akamai-lab.com -ph
|
||||||
|
HTTP/1.1 200 OK
|
||||||
|
Content-Encoding: gzip
|
||||||
|
Content-Length: 18525
|
||||||
|
Content-Type: text/html; charset=UTF-8
|
||||||
|
Date: Mon, 08 Apr 2024 00:41:25 GMT
|
||||||
|
Link: <https://origin-akashop.akamai-lab.com/wp-json/>; rel="https://api.w.org/", <https://origin-akashop.akamai-lab.com/wp-json/wp/v2/pages/265>; rel="alternate"; type="application/json", <https://origin-akashop.akamai-lab.com/>; rel=shortlink
|
||||||
|
Server: Apache/2.4.57 (Debian)
|
||||||
|
Set-Cookie: _37c01=d5cf5ba194c98167; Path=/; HttpOnly
|
||||||
|
Vary: Accept-Encoding
|
||||||
|
X-Powered-By: PHP/8.2.17
|
||||||
|
```
|
||||||
|
|
||||||
|
## How to use HTTPS ##
|
||||||
|
- traefik/traefik-deployment.yml
|
||||||
|
```yml
|
||||||
|
- --certificatesresolvers.le.acme.email=learn@akamai.com
|
||||||
|
- --certificatesresolvers.le.acme.storage=acme.json
|
||||||
|
- --certificatesresolvers.le.acme.tlschallenge=true
|
||||||
|
- --certificatesresolvers.le.acme.caServer=https://acme-staging-v02.api.letsencrypt.org/directory
|
||||||
|
# - --certificatesresolvers.le.acme.caServer=https://acme-v02.api.letsencrypt.org/directory
|
||||||
|
# change caServer to production https://acme-v02.api.letsencrypt.org/directory
|
||||||
|
```
|
||||||
|
- akashop/traefik-ingressR.yml
|
||||||
|
```yml
|
||||||
|
apiVersion: traefik.io/v1alpha1
|
||||||
|
kind: IngressRoute
|
||||||
|
metadata:
|
||||||
|
name: akashop-https
|
||||||
|
namespace: akashop
|
||||||
|
spec:
|
||||||
|
entryPoints:
|
||||||
|
- websecure
|
||||||
|
tls:
|
||||||
|
certResolver: le
|
||||||
|
```
|
||||||
|
|
||||||
|
## How to redirect HTTP to HTTPS ##
|
||||||
|
- akashop/traefik-ingressR.yml
|
||||||
|
```yml
|
||||||
|
apiVersion: traefik.io/v1alpha1
|
||||||
|
kind: Middleware
|
||||||
|
metadata:
|
||||||
|
name: akashop-redir
|
||||||
|
namespace: akashop
|
||||||
|
spec:
|
||||||
|
redirectScheme:
|
||||||
|
scheme: https
|
||||||
|
permanent: true
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
apiVersion: traefik.io/v1alpha1
|
||||||
|
kind: IngressRoute
|
||||||
|
metadata:
|
||||||
|
name: akashop-http
|
||||||
|
namespace: akashop
|
||||||
|
......
|
||||||
|
middlewares:
|
||||||
|
- name: akashop-redir
|
||||||
|
```
|
||||||
|
|
||||||
|
## How to maintain Session Stickyness ##
|
||||||
|
- akashop/traefik-ingressR.yml
|
||||||
|
```yml
|
||||||
|
apiVersion: traefik.io/v1alpha1
|
||||||
|
kind: IngressRoute
|
||||||
|
metadata:
|
||||||
|
name: akashop-https
|
||||||
|
namespace: akashop
|
||||||
|
......
|
||||||
|
services:
|
||||||
|
- name: wp
|
||||||
|
port: 80
|
||||||
|
sticky:
|
||||||
|
cookie:
|
||||||
|
httpOnly: true
|
||||||
|
```
|
||||||
|
|
||||||
|
## How to use ReadWriteMany pvc ##
|
||||||
|
- akashop/pv.yml
|
||||||
|
```yml
|
||||||
|
apiVersion: v1
|
||||||
|
kind: PersistentVolume
|
||||||
|
metadata:
|
||||||
|
name: wp-data
|
||||||
|
namespace: akashop
|
||||||
|
spec:
|
||||||
|
......
|
||||||
|
nfs:
|
||||||
|
path: /nfs/share/akashop/volumes/wp
|
||||||
|
server: 10.0.0.5
|
||||||
|
```
|
||||||
|
|
||||||
|
- akashop/pvc.yml
|
||||||
|
```yml
|
||||||
|
apiVersion: v1
|
||||||
|
kind: PersistentVolumeClaim
|
||||||
|
metadata:
|
||||||
|
name: wp-data-pvc
|
||||||
|
spec:
|
||||||
|
accessModes:
|
||||||
|
- ReadWriteMany
|
||||||
|
......
|
||||||
|
```
|
||||||
|
|
|
@ -0,0 +1,108 @@
|
||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
name: wp
|
||||||
|
namespace: akashop
|
||||||
|
spec:
|
||||||
|
replicas: 1
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: wp
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: wp
|
||||||
|
spec:
|
||||||
|
containers:
|
||||||
|
- name: wp
|
||||||
|
image: wordpress
|
||||||
|
imagePullPolicy: Always
|
||||||
|
resources:
|
||||||
|
limits:
|
||||||
|
cpu: "2"
|
||||||
|
memory: "2Gi"
|
||||||
|
requests:
|
||||||
|
cpu: "1"
|
||||||
|
memory: "1Gi"
|
||||||
|
ports:
|
||||||
|
- name: http
|
||||||
|
containerPort: 80
|
||||||
|
env:
|
||||||
|
- name: WORDPRESS_DB_HOST
|
||||||
|
value: "db"
|
||||||
|
- name: WORDPRESS_DB_USER
|
||||||
|
value: "wordpress"
|
||||||
|
- name: WORDPRESS_DB_PASSWORD
|
||||||
|
value: "examplepass"
|
||||||
|
- name: WORDPRESS_DB_NAME
|
||||||
|
value: "wordpress"
|
||||||
|
# - name: secret
|
||||||
|
# valueFrom: # Specify value from a secret (more secure)
|
||||||
|
# secretKeyRef:
|
||||||
|
# name: my-secret # Name of the secret containing the variable
|
||||||
|
# key: VAR2_KEY
|
||||||
|
#livenessProbe:
|
||||||
|
#httpGet:
|
||||||
|
#path: /
|
||||||
|
#port: 80
|
||||||
|
#initialDelaySeconds: 5
|
||||||
|
#periodSeconds: 10
|
||||||
|
volumeMounts:
|
||||||
|
- name: wp-data
|
||||||
|
mountPath: /var/www/html
|
||||||
|
volumes:
|
||||||
|
- name: wp-data
|
||||||
|
persistentVolumeClaim:
|
||||||
|
claimName: wp-data-pvc
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
name: db
|
||||||
|
namespace: akashop
|
||||||
|
spec:
|
||||||
|
replicas: 1
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: db
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: db
|
||||||
|
spec:
|
||||||
|
containers:
|
||||||
|
- name: db
|
||||||
|
image: mysql
|
||||||
|
imagePullPolicy: Always
|
||||||
|
resources:
|
||||||
|
limits:
|
||||||
|
cpu: "2"
|
||||||
|
memory: "2Gi"
|
||||||
|
requests:
|
||||||
|
cpu: "0.5"
|
||||||
|
memory: "200Mi"
|
||||||
|
ports:
|
||||||
|
- containerPort: 3306
|
||||||
|
env:
|
||||||
|
- name: MYSQL_DATABASE
|
||||||
|
value: "wordpress"
|
||||||
|
- name: MYSQL_USER
|
||||||
|
value: "wordpress"
|
||||||
|
- name: MYSQL_PASSWORD
|
||||||
|
value: "examplepass"
|
||||||
|
- name: MYSQL_RANDOM_ROOT_PASSWORD
|
||||||
|
value: "1"
|
||||||
|
# - name: secret
|
||||||
|
# valueFrom: # Specify value from a secret (more secure)
|
||||||
|
# secretKeyRef:
|
||||||
|
# name: my-secret # Name of the secret containing the variable
|
||||||
|
# key: VAR2_KEY
|
||||||
|
volumeMounts:
|
||||||
|
- name: db-data
|
||||||
|
mountPath: /var/lib/mysql
|
||||||
|
volumes:
|
||||||
|
- name: db-data
|
||||||
|
persistentVolumeClaim:
|
||||||
|
claimName: db-data-pvc
|
|
@ -0,0 +1,19 @@
|
||||||
|
apiVersion: autoscaling/v2
|
||||||
|
kind: HorizontalPodAutoscaler
|
||||||
|
metadata:
|
||||||
|
name: wp-hpa
|
||||||
|
namespace: akashop
|
||||||
|
spec:
|
||||||
|
scaleTargetRef:
|
||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
name: wp
|
||||||
|
minReplicas: 1
|
||||||
|
maxReplicas: 10
|
||||||
|
metrics:
|
||||||
|
- type: Resource
|
||||||
|
resource:
|
||||||
|
name: cpu
|
||||||
|
target:
|
||||||
|
type: Utilization
|
||||||
|
averageUtilization: 50
|
|
@ -0,0 +1,35 @@
|
||||||
|
apiVersion: v1
|
||||||
|
kind: PersistentVolume
|
||||||
|
metadata:
|
||||||
|
name: wp-data
|
||||||
|
namespace: akashop
|
||||||
|
spec:
|
||||||
|
capacity:
|
||||||
|
storage: 1Gi
|
||||||
|
volumeMode: Filesystem
|
||||||
|
accessModes:
|
||||||
|
- ReadWriteMany
|
||||||
|
persistentVolumeReclaimPolicy: Recycle
|
||||||
|
storageClassName: ""
|
||||||
|
nfs:
|
||||||
|
path: /nfs/share/akashop/volumes/wp
|
||||||
|
server: 10.0.0.2
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
apiVersion: v1
|
||||||
|
kind: PersistentVolume
|
||||||
|
metadata:
|
||||||
|
name: db-data
|
||||||
|
namespace: akashop
|
||||||
|
spec:
|
||||||
|
capacity:
|
||||||
|
storage: 1Gi
|
||||||
|
volumeMode: Filesystem
|
||||||
|
accessModes:
|
||||||
|
- ReadWriteMany
|
||||||
|
persistentVolumeReclaimPolicy: Recycle
|
||||||
|
storageClassName: ""
|
||||||
|
nfs:
|
||||||
|
path: /nfs/share/akashop/volumes/db
|
||||||
|
server: 10.0.0.2
|
|
@ -0,0 +1,29 @@
|
||||||
|
apiVersion: v1
|
||||||
|
kind: PersistentVolumeClaim
|
||||||
|
metadata:
|
||||||
|
name: wp-data-pvc
|
||||||
|
spec:
|
||||||
|
accessModes:
|
||||||
|
- ReadWriteMany
|
||||||
|
volumeMode: Filesystem
|
||||||
|
storageClassName: ""
|
||||||
|
resources:
|
||||||
|
requests:
|
||||||
|
storage: 1Gi
|
||||||
|
volumeName: wp-data
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
apiVersion: v1
|
||||||
|
kind: PersistentVolumeClaim
|
||||||
|
metadata:
|
||||||
|
name: db-data-pvc
|
||||||
|
spec:
|
||||||
|
accessModes:
|
||||||
|
- ReadWriteMany
|
||||||
|
volumeMode: Filesystem
|
||||||
|
storageClassName: ""
|
||||||
|
resources:
|
||||||
|
requests:
|
||||||
|
storage: 1Gi
|
||||||
|
volumeName: db-data
|
|
@ -0,0 +1,29 @@
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
name: wp
|
||||||
|
namespace: akashop
|
||||||
|
spec:
|
||||||
|
selector:
|
||||||
|
app: wp
|
||||||
|
ports:
|
||||||
|
- protocol: TCP
|
||||||
|
port: 80
|
||||||
|
targetPort: http
|
||||||
|
type: ClusterIP
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
name: db
|
||||||
|
namespace: akashop
|
||||||
|
spec:
|
||||||
|
selector:
|
||||||
|
app: db
|
||||||
|
ports:
|
||||||
|
- protocol: TCP
|
||||||
|
port: 3306
|
||||||
|
targetPort: 3306
|
||||||
|
type: ClusterIP
|
|
@ -0,0 +1,78 @@
|
||||||
|
apiVersion: traefik.io/v1alpha1
|
||||||
|
kind: Middleware
|
||||||
|
metadata:
|
||||||
|
name: akashop-ratelimit
|
||||||
|
namespace: akashop
|
||||||
|
spec:
|
||||||
|
rateLimit:
|
||||||
|
average: 30
|
||||||
|
burst: 50
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
apiVersion: traefik.io/v1alpha1
|
||||||
|
kind: Middleware
|
||||||
|
metadata:
|
||||||
|
name: akashop-redir
|
||||||
|
namespace: akashop
|
||||||
|
spec:
|
||||||
|
redirectScheme:
|
||||||
|
scheme: https
|
||||||
|
permanent: true # Set to true for permanent (301) redirect
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
apiVersion: traefik.io/v1alpha1
|
||||||
|
kind: IngressRoute
|
||||||
|
metadata:
|
||||||
|
name: akashop-http
|
||||||
|
namespace: akashop
|
||||||
|
|
||||||
|
spec:
|
||||||
|
entryPoints:
|
||||||
|
- web
|
||||||
|
|
||||||
|
routes:
|
||||||
|
- match: Host(`origin-akashop.akamai-lab.com`) && PathPrefix(`/`)
|
||||||
|
kind: Rule
|
||||||
|
services:
|
||||||
|
- name: wp
|
||||||
|
port: 80
|
||||||
|
|
||||||
|
middlewares:
|
||||||
|
- name: akashop-ratelimit
|
||||||
|
# - name: akashop-redir
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
apiVersion: traefik.io/v1alpha1
|
||||||
|
kind: IngressRoute
|
||||||
|
metadata:
|
||||||
|
name: akashop-https
|
||||||
|
namespace: akashop
|
||||||
|
|
||||||
|
spec:
|
||||||
|
entryPoints:
|
||||||
|
- websecure
|
||||||
|
|
||||||
|
tls:
|
||||||
|
certResolver: le
|
||||||
|
|
||||||
|
routes:
|
||||||
|
- match: Host(`origin-akashop.akamai-lab.com`) && PathPrefix(`/`)
|
||||||
|
kind: Rule
|
||||||
|
services:
|
||||||
|
- name: wp
|
||||||
|
port: 80
|
||||||
|
sticky:
|
||||||
|
cookie:
|
||||||
|
httpOnly: true
|
||||||
|
# name: cookie
|
||||||
|
# secure: true
|
||||||
|
sameSite: strict
|
||||||
|
# strategy: RoundRobin
|
||||||
|
# weight: 10
|
||||||
|
# nativeLB: true
|
||||||
|
|
||||||
|
middlewares:
|
||||||
|
- name: akashop-ratelimit
|
|
@ -1,70 +0,0 @@
|
||||||
version: '3.8'
|
|
||||||
|
|
||||||
services:
|
|
||||||
traefik:
|
|
||||||
image: traefik:latest
|
|
||||||
container_name: "traefik"
|
|
||||||
command:
|
|
||||||
- "--providers.docker=true"
|
|
||||||
- "--api.dashboard=true"
|
|
||||||
- "--api.insecure=true"
|
|
||||||
- "--providers.docker.exposedbydefault=false"
|
|
||||||
- "--entrypoints.web.address=:80"
|
|
||||||
- "--entrypoints.websecure.address=:443"
|
|
||||||
- "--certificatesresolvers.letsencrypt.acme.email=learn@akamai.com"
|
|
||||||
- "--certificatesresolvers.letsencrypt.acme.storage=/etc/traefik/acme/acme.json"
|
|
||||||
- "--certificatesresolvers.letsencrypt.acme.httpchallenge.entrypoint=web"
|
|
||||||
ports:
|
|
||||||
- "80:80"
|
|
||||||
- "443:443"
|
|
||||||
- "8080:8080" # /dashboard/
|
|
||||||
volumes:
|
|
||||||
- "/var/run/docker.sock:/var/run/docker.sock:ro"
|
|
||||||
- "../volumes/acme:/etc/traefik/acme"
|
|
||||||
|
|
||||||
wp:
|
|
||||||
image: wordpress
|
|
||||||
scale: 3
|
|
||||||
restart: always
|
|
||||||
environment:
|
|
||||||
WORDPRESS_DB_HOST: db
|
|
||||||
WORDPRESS_DB_USER: wordpress
|
|
||||||
WORDPRESS_DB_PASSWORD: examplepass
|
|
||||||
WORDPRESS_DB_NAME: wordpress
|
|
||||||
volumes:
|
|
||||||
- wp-data:/var/www/html
|
|
||||||
labels:
|
|
||||||
- "traefik.enable=true" # Enable Traefik
|
|
||||||
- "traefik.http.routers.wp.rule=Host(`origin-akashop.akamai-lab.com`)"
|
|
||||||
- "traefik.http.routers.wp.tls=true"
|
|
||||||
- "traefik.http.routers.wp.tls.certresolver=letsencrypt"
|
|
||||||
- "traefik.http.middlewares.redirect-to-https.redirectscheme.scheme=https" # HTTP to HTTPS redirect
|
|
||||||
- "traefik.http.middlewares.redirect-to-https.redirectscheme.permanent=true"
|
|
||||||
- "traefik.http.routers.redirs.rule=hostregexp(`{host:.+}`)"
|
|
||||||
- "traefik.http.routers.redirs.entrypoints=web"
|
|
||||||
- "traefik.http.routers.redirs.middlewares=redirect-to-https"
|
|
||||||
|
|
||||||
db:
|
|
||||||
image: mysql
|
|
||||||
restart: always
|
|
||||||
environment:
|
|
||||||
MYSQL_DATABASE: wordpress
|
|
||||||
MYSQL_USER: wordpress
|
|
||||||
MYSQL_PASSWORD: examplepass
|
|
||||||
MYSQL_RANDOM_ROOT_PASSWORD: '1'
|
|
||||||
volumes:
|
|
||||||
- db-data:/var/lib/mysql
|
|
||||||
|
|
||||||
volumes:
|
|
||||||
wp-data:
|
|
||||||
driver: local
|
|
||||||
driver_opts:
|
|
||||||
type: nfs
|
|
||||||
o: addr=10.0.0.2,nolock,soft,rw
|
|
||||||
device: ":/nfs/share/akashop/wp"
|
|
||||||
db-data:
|
|
||||||
driver: local
|
|
||||||
driver_opts:
|
|
||||||
type: nfs
|
|
||||||
o: addr=10.0.0.2,nolock,soft,rw
|
|
||||||
device: ":/nfs/share/akashop/db"
|
|
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,75 @@
|
||||||
|
# Check the latest version at https://doc.traefik.io/traefik/providers/kubernetes-crd/#configuration-requirements
|
||||||
|
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: ClusterRole
|
||||||
|
metadata:
|
||||||
|
name: traefik-ingress-controller
|
||||||
|
|
||||||
|
rules:
|
||||||
|
- apiGroups:
|
||||||
|
- ""
|
||||||
|
resources:
|
||||||
|
- services
|
||||||
|
- endpoints
|
||||||
|
- secrets
|
||||||
|
verbs:
|
||||||
|
- get
|
||||||
|
- list
|
||||||
|
- watch
|
||||||
|
- apiGroups:
|
||||||
|
- extensions
|
||||||
|
- networking.k8s.io
|
||||||
|
resources:
|
||||||
|
- ingresses
|
||||||
|
- ingressclasses
|
||||||
|
verbs:
|
||||||
|
- get
|
||||||
|
- list
|
||||||
|
- watch
|
||||||
|
- apiGroups:
|
||||||
|
- extensions
|
||||||
|
- networking.k8s.io
|
||||||
|
resources:
|
||||||
|
- ingresses/status
|
||||||
|
verbs:
|
||||||
|
- update
|
||||||
|
- apiGroups:
|
||||||
|
- traefik.io
|
||||||
|
- traefik.containo.us
|
||||||
|
resources:
|
||||||
|
- middlewares
|
||||||
|
- middlewaretcps
|
||||||
|
- ingressroutes
|
||||||
|
- traefikservices
|
||||||
|
- ingressroutetcps
|
||||||
|
- ingressrouteudps
|
||||||
|
- tlsoptions
|
||||||
|
- tlsstores
|
||||||
|
- serverstransports
|
||||||
|
verbs:
|
||||||
|
- get
|
||||||
|
- list
|
||||||
|
- watch
|
||||||
|
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: ClusterRoleBinding
|
||||||
|
metadata:
|
||||||
|
name: traefik-ingress-controller
|
||||||
|
|
||||||
|
roleRef:
|
||||||
|
apiGroup: rbac.authorization.k8s.io
|
||||||
|
kind: ClusterRole
|
||||||
|
name: traefik-ingress-controller
|
||||||
|
subjects:
|
||||||
|
- kind: ServiceAccount
|
||||||
|
name: traefik-ingress-controller
|
||||||
|
namespace: traefik
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
apiVersion: v1
|
||||||
|
kind: ServiceAccount
|
||||||
|
metadata:
|
||||||
|
name: traefik-ingress-controller
|
||||||
|
namespace: traefik
|
|
@ -0,0 +1,62 @@
|
||||||
|
kind: Deployment
|
||||||
|
apiVersion: apps/v1
|
||||||
|
metadata:
|
||||||
|
name: traefik-deployment
|
||||||
|
namespace: traefik
|
||||||
|
labels:
|
||||||
|
app: traefik
|
||||||
|
|
||||||
|
spec:
|
||||||
|
replicas: 1
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: traefik
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: traefik
|
||||||
|
spec:
|
||||||
|
# serviceAccountName: traefik-account
|
||||||
|
serviceAccountName: traefik-ingress-controller
|
||||||
|
containers:
|
||||||
|
- name: traefik
|
||||||
|
image: traefik:latest
|
||||||
|
args:
|
||||||
|
- --api.insecure
|
||||||
|
- --log.level=DEBUG
|
||||||
|
|
||||||
|
# access log - https://doc.traefik.io/traefik/observability/access-logs/#limiting-the-fieldsincluding-headers
|
||||||
|
- --accesslog.filepath=/root/traefik/access.log
|
||||||
|
- --accesslog.fields.headers.names.X-Forwarded-For=keep
|
||||||
|
- --accesslog.fields.headers.names.User-Agent=keep
|
||||||
|
|
||||||
|
# - --providers.kubernetesingress
|
||||||
|
# - --providers.kubernetesingress.allowexternalnameservices=true
|
||||||
|
- --providers.kubernetescrd
|
||||||
|
- --providers.kubernetescrd.allowCrossNamespace=true
|
||||||
|
|
||||||
|
- --entrypoints.web.address=:80
|
||||||
|
- --entrypoints.websecure.address=:443
|
||||||
|
|
||||||
|
# Get real client IP using proxy protocol
|
||||||
|
# https://doc.traefik.io/traefik/routing/entrypoints/#proxyprotocol
|
||||||
|
- --entryPoints.web.proxyProtocol.trustedIPs=127.0.0.1/32,10.2.0.0/16,172.233.0.0/16
|
||||||
|
- --entryPoints.websecure.proxyProtocol.trustedIPs=127.0.0.1/32,10.2.0.0/16,172.233.0.0/16
|
||||||
|
|
||||||
|
# Get real client IP from X-Forwarded-For
|
||||||
|
# - --entrypoints.web.forwardedHeaders.trustedIPs=127.0.0.1/32,10.2.0.0/16
|
||||||
|
# - --entryPoints.websecure.forwardedHeaders.trustedIPs=127.0.0.1/32,172.233.168.36/32
|
||||||
|
|
||||||
|
- --certificatesresolvers.le.acme.email=learn@akamai.com
|
||||||
|
- --certificatesresolvers.le.acme.storage=acme.json
|
||||||
|
- --certificatesresolvers.le.acme.tlschallenge=true
|
||||||
|
- --certificatesresolvers.le.acme.caServer=https://acme-staging-v02.api.letsencrypt.org/directory
|
||||||
|
# - --certificatesresolvers.le.acme.caServer=https://acme-v02.api.letsencrypt.org/directory
|
||||||
|
# change caServer to production https://acme-v02.api.letsencrypt.org/directory
|
||||||
|
ports:
|
||||||
|
- name: web
|
||||||
|
containerPort: 80
|
||||||
|
- name: websecure
|
||||||
|
containerPort: 443
|
||||||
|
- name: dashboard
|
||||||
|
containerPort: 8080
|
|
@ -0,0 +1,30 @@
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
name: traefik-dashboard-service
|
||||||
|
|
||||||
|
spec:
|
||||||
|
type: LoadBalancer
|
||||||
|
ports:
|
||||||
|
- port: 8080
|
||||||
|
targetPort: dashboard
|
||||||
|
selector:
|
||||||
|
app: traefik
|
||||||
|
---
|
||||||
|
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
name: traefik-web
|
||||||
|
|
||||||
|
spec:
|
||||||
|
type: LoadBalancer
|
||||||
|
ports:
|
||||||
|
- name: http
|
||||||
|
targetPort: web
|
||||||
|
port: 80
|
||||||
|
- name: https
|
||||||
|
targetPort: websecure
|
||||||
|
port: 443
|
||||||
|
selector:
|
||||||
|
app: traefik
|
Loading…
Reference in New Issue