deploy metabase
This commit is contained in:
parent
c9f681e44b
commit
f6c5aa12e4
126
cluster/manifests/freeleaps-data-platform/metabase/README.md
Normal file
126
cluster/manifests/freeleaps-data-platform/metabase/README.md
Normal file
@ -0,0 +1,126 @@
|
||||
# Metabase Deployment
|
||||
|
||||
## Overview
|
||||
This directory contains Kubernetes manifests for deploying Metabase, a business intelligence and analytics platform, along with its PostgreSQL database.
|
||||
|
||||
## Components
|
||||
|
||||
### 1. metabase-postgres.yaml
|
||||
PostgreSQL database deployment:
|
||||
- Persistent storage for data
|
||||
- ConfigMap for database configuration
|
||||
- Secret for database password
|
||||
- Service for internal communication
|
||||
|
||||
### 2. metabase-deployment.yaml
|
||||
Metabase application deployment:
|
||||
- Metabase container with latest image
|
||||
- Persistent storage for application data
|
||||
- Environment variables for database connection
|
||||
- Health checks and resource limits
|
||||
- Service for internal communication
|
||||
|
||||
### 3. metabase-ingress.yaml
|
||||
Ingress configuration for external access:
|
||||
- Nginx ingress class
|
||||
- Multiple host support (metabase.freeleaps.cluster, metabase.local)
|
||||
- SSL redirect disabled for development
|
||||
|
||||
## Deployment Steps
|
||||
|
||||
### 1. Deploy PostgreSQL Database
|
||||
```bash
|
||||
kubectl apply -f metabase-postgres.yaml
|
||||
```
|
||||
|
||||
### 2. Wait for PostgreSQL to be Ready
|
||||
```bash
|
||||
kubectl wait --for=condition=ready pod -l app=metabase-postgres -n metabase --timeout=300s
|
||||
```
|
||||
|
||||
### 3. Deploy Metabase Application
|
||||
```bash
|
||||
kubectl apply -f metabase-deployment.yaml
|
||||
```
|
||||
|
||||
### 4. Deploy Ingress (Optional)
|
||||
```bash
|
||||
kubectl apply -f metabase-ingress.yaml
|
||||
```
|
||||
|
||||
### 5. Monitor Deployment
|
||||
```bash
|
||||
kubectl get pods -n metabase
|
||||
kubectl get services -n metabase
|
||||
kubectl get ingress -n metabase
|
||||
```
|
||||
|
||||
## Configuration
|
||||
|
||||
### Database Connection
|
||||
- **Type**: PostgreSQL
|
||||
- **Host**: metabase-postgres
|
||||
- **Port**: 5432
|
||||
- **Database**: metabase
|
||||
- **User**: metabase
|
||||
- **Password**: metabasepassword
|
||||
|
||||
### Storage
|
||||
- **Metabase Data**: 10Gi persistent storage
|
||||
- **PostgreSQL Data**: 5Gi persistent storage
|
||||
- **Storage Class**: azure-disk-std-ssd-lrs
|
||||
|
||||
### Resources
|
||||
- **Metabase**: 512Mi-1Gi memory, 250m-500m CPU
|
||||
- **PostgreSQL**: 256Mi-512Mi memory, 250m-500m CPU
|
||||
|
||||
## Access
|
||||
|
||||
### Internal Access
|
||||
- **Metabase**: http://metabase.metabase.svc.cluster.local:3000
|
||||
- **PostgreSQL**: metabase-postgres.metabase.svc.cluster.local:5432
|
||||
|
||||
### External Access (with Ingress)
|
||||
- **Primary**: http://metabase.freeleaps.cluster
|
||||
- **Alternative**: http://metabase.local
|
||||
|
||||
## Initial Setup
|
||||
|
||||
1. **First Access**: Navigate to the Metabase URL
|
||||
2. **Setup Wizard**: Follow the initial setup wizard
|
||||
3. **Database Connection**: Use the internal PostgreSQL connection
|
||||
4. **Admin User**: Create the first admin user
|
||||
5. **Data Sources**: Connect to your data sources
|
||||
|
||||
## Troubleshooting
|
||||
|
||||
### Check Pod Status
|
||||
```bash
|
||||
kubectl get pods -n metabase
|
||||
kubectl describe pod <pod-name> -n metabase
|
||||
```
|
||||
|
||||
### Check Logs
|
||||
```bash
|
||||
kubectl logs <pod-name> -n metabase
|
||||
kubectl logs <pod-name> -n metabase -c postgres # for PostgreSQL
|
||||
```
|
||||
|
||||
### Check Services
|
||||
```bash
|
||||
kubectl get services -n metabase
|
||||
kubectl describe service metabase -n metabase
|
||||
```
|
||||
|
||||
### Check Storage
|
||||
```bash
|
||||
kubectl get pvc -n metabase
|
||||
kubectl describe pvc metabase-data -n metabase
|
||||
```
|
||||
|
||||
## Notes
|
||||
|
||||
- **Initial Startup**: Metabase may take 2-3 minutes to start up on first deployment
|
||||
- **Database**: Ensure PostgreSQL is fully ready before deploying Metabase
|
||||
- **Storage**: Both Metabase and PostgreSQL use persistent storage for data persistence
|
||||
- **Security**: Default password is base64 encoded, consider changing for production use
|
||||
@ -0,0 +1,145 @@
|
||||
apiVersion: v1
|
||||
kind: Namespace
|
||||
metadata:
|
||||
name: metabase
|
||||
labels:
|
||||
name: metabase
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: ServiceAccount
|
||||
metadata:
|
||||
name: metabase
|
||||
namespace: metabase
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: PersistentVolumeClaim
|
||||
metadata:
|
||||
name: metabase-data
|
||||
namespace: metabase
|
||||
spec:
|
||||
accessModes:
|
||||
- ReadWriteOnce
|
||||
resources:
|
||||
requests:
|
||||
storage: 10Gi
|
||||
storageClassName: azure-disk-std-ssd-lrs
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: ConfigMap
|
||||
metadata:
|
||||
name: metabase-config
|
||||
namespace: metabase
|
||||
data:
|
||||
MB_DB_TYPE: "postgres"
|
||||
MB_DB_DBNAME: "metabase"
|
||||
MB_DB_PORT: "5432"
|
||||
MB_DB_USER: "metabase"
|
||||
MB_DB_HOST: "metabase-postgres"
|
||||
---
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
name: metabase
|
||||
namespace: metabase
|
||||
labels:
|
||||
app: metabase
|
||||
spec:
|
||||
replicas: 1
|
||||
selector:
|
||||
matchLabels:
|
||||
app: metabase
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app: metabase
|
||||
spec:
|
||||
serviceAccountName: metabase
|
||||
containers:
|
||||
- name: metabase
|
||||
image: metabase/metabase:latest
|
||||
ports:
|
||||
- containerPort: 3000
|
||||
name: http
|
||||
env:
|
||||
- name: MB_DB_TYPE
|
||||
valueFrom:
|
||||
configMapKeyRef:
|
||||
name: metabase-config
|
||||
key: MB_DB_TYPE
|
||||
- name: MB_DB_DBNAME
|
||||
valueFrom:
|
||||
configMapKeyRef:
|
||||
name: metabase-config
|
||||
key: MB_DB_DBNAME
|
||||
- name: MB_DB_PORT
|
||||
valueFrom:
|
||||
configMapKeyRef:
|
||||
name: metabase-config
|
||||
key: MB_DB_PORT
|
||||
- name: MB_DB_USER
|
||||
valueFrom:
|
||||
configMapKeyRef:
|
||||
name: metabase-config
|
||||
key: MB_DB_USER
|
||||
- name: MB_DB_HOST
|
||||
valueFrom:
|
||||
configMapKeyRef:
|
||||
name: metabase-config
|
||||
key: MB_DB_HOST
|
||||
- name: MB_DB_PASS
|
||||
valueFrom:
|
||||
secretKeyRef:
|
||||
name: metabase-db-secret
|
||||
key: password
|
||||
volumeMounts:
|
||||
- name: metabase-data
|
||||
mountPath: /metabase-data
|
||||
resources:
|
||||
requests:
|
||||
memory: "512Mi"
|
||||
cpu: "250m"
|
||||
limits:
|
||||
memory: "1Gi"
|
||||
cpu: "500m"
|
||||
livenessProbe:
|
||||
httpGet:
|
||||
path: /api/health
|
||||
port: 3000
|
||||
initialDelaySeconds: 120
|
||||
periodSeconds: 30
|
||||
readinessProbe:
|
||||
httpGet:
|
||||
path: /api/health
|
||||
port: 3000
|
||||
initialDelaySeconds: 30
|
||||
periodSeconds: 10
|
||||
volumes:
|
||||
- name: metabase-data
|
||||
persistentVolumeClaim:
|
||||
claimName: metabase-data
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
name: metabase
|
||||
namespace: metabase
|
||||
labels:
|
||||
app: metabase
|
||||
spec:
|
||||
type: ClusterIP
|
||||
ports:
|
||||
- port: 3000
|
||||
targetPort: 3000
|
||||
protocol: TCP
|
||||
name: http
|
||||
selector:
|
||||
app: metabase
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: Secret
|
||||
metadata:
|
||||
name: metabase-db-secret
|
||||
namespace: metabase
|
||||
type: Opaque
|
||||
data:
|
||||
password: bWV0YWJhc2VwYXNzd29yZA== # metabasepassword in base64
|
||||
@ -0,0 +1,32 @@
|
||||
apiVersion: networking.k8s.io/v1
|
||||
kind: Ingress
|
||||
metadata:
|
||||
name: metabase-ingress
|
||||
namespace: metabase
|
||||
annotations:
|
||||
kubernetes.io/ingress.class: "nginx"
|
||||
nginx.ingress.kubernetes.io/ssl-redirect: "false"
|
||||
nginx.ingress.kubernetes.io/rewrite-target: /
|
||||
nginx.ingress.kubernetes.io/proxy-body-size: "50m"
|
||||
spec:
|
||||
rules:
|
||||
- host: metabase.freeleaps.cluster
|
||||
http:
|
||||
paths:
|
||||
- path: /
|
||||
pathType: Prefix
|
||||
backend:
|
||||
service:
|
||||
name: metabase
|
||||
port:
|
||||
number: 3000
|
||||
- host: metabase.local
|
||||
http:
|
||||
paths:
|
||||
- path: /
|
||||
pathType: Prefix
|
||||
backend:
|
||||
service:
|
||||
name: metabase
|
||||
port:
|
||||
number: 3000
|
||||
@ -0,0 +1,119 @@
|
||||
apiVersion: v1
|
||||
kind: PersistentVolumeClaim
|
||||
metadata:
|
||||
name: metabase-postgres-data
|
||||
namespace: metabase
|
||||
spec:
|
||||
accessModes:
|
||||
- ReadWriteOnce
|
||||
resources:
|
||||
requests:
|
||||
storage: 5Gi
|
||||
storageClassName: azure-disk-std-ssd-lrs
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: ConfigMap
|
||||
metadata:
|
||||
name: metabase-postgres-config
|
||||
namespace: metabase
|
||||
data:
|
||||
POSTGRES_DB: "metabase"
|
||||
POSTGRES_USER: "metabase"
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: Secret
|
||||
metadata:
|
||||
name: metabase-postgres-secret
|
||||
namespace: metabase
|
||||
type: Opaque
|
||||
data:
|
||||
POSTGRES_PASSWORD: bWV0YWJhc2VwYXNzd29yZA== # metabasepassword in base64
|
||||
---
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
name: metabase-postgres
|
||||
namespace: metabase
|
||||
labels:
|
||||
app: metabase-postgres
|
||||
spec:
|
||||
replicas: 1
|
||||
selector:
|
||||
matchLabels:
|
||||
app: metabase-postgres
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app: metabase-postgres
|
||||
spec:
|
||||
containers:
|
||||
- name: postgres
|
||||
image: postgres:15
|
||||
ports:
|
||||
- containerPort: 5432
|
||||
name: postgres
|
||||
env:
|
||||
- name: POSTGRES_DB
|
||||
valueFrom:
|
||||
configMapKeyRef:
|
||||
name: metabase-postgres-config
|
||||
key: POSTGRES_DB
|
||||
- name: POSTGRES_USER
|
||||
valueFrom:
|
||||
configMapKeyRef:
|
||||
name: metabase-postgres-config
|
||||
key: POSTGRES_USER
|
||||
- name: POSTGRES_PASSWORD
|
||||
valueFrom:
|
||||
secretKeyRef:
|
||||
name: metabase-postgres-secret
|
||||
key: POSTGRES_PASSWORD
|
||||
- name: PGDATA
|
||||
value: "/var/lib/postgresql/data/pgdata"
|
||||
volumeMounts:
|
||||
- name: postgres-data
|
||||
mountPath: /var/lib/postgresql/data
|
||||
resources:
|
||||
requests:
|
||||
memory: "256Mi"
|
||||
cpu: "250m"
|
||||
limits:
|
||||
memory: "512Mi"
|
||||
cpu: "500m"
|
||||
livenessProbe:
|
||||
exec:
|
||||
command:
|
||||
- pg_isready
|
||||
- -U
|
||||
- metabase
|
||||
initialDelaySeconds: 30
|
||||
periodSeconds: 10
|
||||
readinessProbe:
|
||||
exec:
|
||||
command:
|
||||
- pg_isready
|
||||
- -U
|
||||
- metabase
|
||||
initialDelaySeconds: 5
|
||||
periodSeconds: 5
|
||||
volumes:
|
||||
- name: postgres-data
|
||||
persistentVolumeClaim:
|
||||
claimName: metabase-postgres-data
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
name: metabase-postgres
|
||||
namespace: metabase
|
||||
labels:
|
||||
app: metabase-postgres
|
||||
spec:
|
||||
type: ClusterIP
|
||||
ports:
|
||||
- port: 5432
|
||||
targetPort: 5432
|
||||
protocol: TCP
|
||||
name: postgres
|
||||
selector:
|
||||
app: metabase-postgres
|
||||
Loading…
Reference in New Issue
Block a user