Files
ai/flink/README.md
2026-03-11 18:47:11 -04:00

78 lines
1.8 KiB
Markdown

# Flink Deployment for K8s Cluster
## Install Flink Kubernetes Operator
```bash
# Add the Flink Helm repository
helm repo add flink-operator-repo https://downloads.apache.org/flink/flink-kubernetes-operator-1.9.0/
helm repo update
# Install the operator
helm install flink-kubernetes-operator flink-operator-repo/flink-kubernetes-operator \
-f values.yaml \
--namespace flink --create-namespace
# Wait for operator to be ready
kubectl wait --for=condition=ready pod -l app.kubernetes.io/name=flink-kubernetes-operator -n flink --timeout=300s
```
## Create Service Account
```bash
kubectl create serviceaccount flink -n default
kubectl create clusterrolebinding flink-role-binding-default \
--clusterrole=edit \
--serviceaccount=default:flink
```
## Deploy Flink Cluster
```bash
# Apply the Flink cluster manifest
kubectl apply -f flink-cluster.yaml
# Check cluster status
kubectl get flinkdeployment -n default
# Check pods
kubectl get pods -n default | grep flink
```
## Access Flink Web UI
```bash
# Port forward to access the UI locally
kubectl port-forward svc/trading-flink-rest 8081:8081 -n default
# Open browser to http://localhost:8081
```
## Prometheus Metrics
Flink exposes metrics on port 9249. Prometheus will automatically discover and scrape these metrics via pod annotations:
- `prometheus.io/scrape: "true"`
- `prometheus.io/port: "9249"`
- `prometheus.io/path: "/metrics"`
To verify metrics are being exported:
```bash
kubectl exec -it <flink-jobmanager-pod> -n default -- curl localhost:9249/metrics
```
## Submit a Job
```bash
# Example: Submit a jar file
kubectl exec -it <jobmanager-pod> -- flink run /path/to/job.jar
```
## Uninstall
```bash
# Delete Flink cluster
kubectl delete flinkdeployment trading-flink -n default
# Delete operator
helm uninstall flink-kubernetes-operator -n flink
```