This project serves a weather prediction model using Ray Serve and FastAPI, developed as part of a cloud computing university course (RSO).
To run the application locally, follow these steps:
-
Install Dependencies:
pip install -r requirements.txt
-
Set Google Application Credentials:
export GOOGLE_APPLICATION_CREDENTIALS=/path/to/your/credentials.json
-
Start Ray Serve Application:
serve run rayserve_model:model_predictor
To build and run a Docker image (note: this functionality is currently not operational):
# Build the Docker image
# docker build -t weather-pred-ray .
# Run the Docker container on port 8000
# docker run -p 8000:8000 weather-pred-ray
For detailed setup commands, see GKE Commands.
Also refer to Ray.Io docs for more info:
- RayServe Kubernetes Deployment Guide
- RayServe Kubernetes Ingress Guide
- Kuberay GitHub Repository - Samples
-
List Google Cloud Projects:
gcloud projects list --sort-by=projectId --limit=5
-
Set Desired Project:
gcloud config set project balmy-apogee-404909
-
Check Existing Kubernetes Clusters or Create a New One:
gcloud container clusters list # Create a new cluster if necessary
-
Get Credentials for Kubernetes Cluster:
gcloud container clusters get-credentials rayserve-cluster --zone europe-central2
-
Install Helm and Configure Ray Helm Chart Repository:
helm repo add kuberay https://ray-project.github.io/kuberay-helm/ helm repo update
-
Install KubeRay Operator:
helm install kuberay-operator kuberay/kuberay-operator --version 1.0.0
-
Verify Operator is Running:
kubectl get pods
-
Install RayCluster:
helm install raycluster kuberay/ray-cluster --version 1.0.0
-
Verify RayCluster Status:
kubectl get rayclusters
-
Apply RayService Configuration:
kubectl apply -f gke-deploy/ray-service.weather-prediction.yaml
-
Create and Annotate a Service Account for Workload Identity:
kubectl create serviceaccount k8s-drejc kubectl annotate serviceaccount k8s-drejc "iam.gke.io/gcp-service-account=drejc-rso-new@balmy-apogee-404909.iam.gserviceaccount.com"
-
Add IAM Policy Binding for Service Account:
gcloud iam service-accounts add-iam-policy-binding \ drejc-rso-new@balmy-apogee-404909.iam.gserviceaccount.com \ --role roles/iam.workloadIdentityUser \ --member "serviceAccount:balmy-apogee-404909.svc.id.goog[default/k8s-drejc]"
-
Create a Proxy-Only Subnet if Required:
gcloud compute networks subnets create proxy-only-subnet-01 \ --purpose=REGIONAL_MANAGED_PROXY \ --role=ACTIVE \ --region=europe-central2 \ --network=default \ --range=10.10.0.0/23
-
Apply BackendConfig for Health Checks:
kubectl apply -f gke-deploy/ray-hc-backendconfig.yaml
-
Annotate the Service for BackendConfig:
kubectl annotate service rvice-weather-prediction-raycluster-5phmv-head-svc beta.cloud.google.com/backend-config='{"default": "ray-serve-backend-config"}'
-
Apply Ingress Configuration:
kubectl apply -f gke-deploy/ray-cluster-gclb-ingress.yaml
-
Check All Pods are Running:
kubectl get pods
-
Verify Services and Their ClusterIP:
kubectl get svc
-
Inspect Ingress and Ensure External IP if Public Access is Desired:
kubectl get ingress ray-cluster-ingress
-
Troubleshooting: Use
kubectl describe
and GCP Console to check load balancers, firewall rules, quotas, etc.
- Order of operations is crucial. Ensure BackendConfig is applied before annotating the service and then applying the Ingress configuration.
- Make sure that pods have status "running" after executing kubectl commands it might take up to 15 minutes to spin up some of these pods.
- For public access, use the
gce
ingress class in your Ingress configuration to create an external HTTP(S) load balancer. - Ensure your application is secured appropriately when exposed publicly.