Quick way to run a Ruby script in Kubernetes

Sometimes I find myself in need of running a Ruby script on a live Kubernetes cluster. In today's example, it had to do with generating load on MySQL, which was tricker to do from my laptop. The script had to run close to the workload in the cluster.

I'm lazy and having to build and push a Docker container with my script would be a lot of extra work.

Luckily, thanks to K8S config maps and to Bundler inline mode, this can be achieved without having to build a custom container.

First, let's create a config map with our code:

apiVersion: v1
kind: ConfigMap
metadata:
  name: load-generator
data:
  writer.rb: |
    require 'bundler/inline'
    gemfile do
      source 'https://rubygems.org'
      gem 'mysql2'
    end

    require 'mysql2'
    client = Mysql2::Client.new(database: 'commerce')
    loop { client.query("select * from orders") }
    # more code follows...

And then the deployment that pulls ruby:2.7 image and runs the file from our config map.

apiVersion: apps/v1
kind: Deployment
metadata:
  labels:
    app: load-generator
  name: load-generator
spec:
  replicas: 1
  selector:
    matchLabels:
      app: load-generator
  template:
    metadata:
      labels:
        app: load-generator
    spec:
      containers:
      - image: ruby:2.7
        name: ruby
        command: ["ruby"]
        args: ["/app/writer.rb"]
        volumeMounts:
          - name: load-generator
            mountPath: /app/writer.rb
            subPath: writer.rb
      restartPolicy: Always
      volumes:
        - name: load-generator
          configMap:
            name: load-generator

All you need is kubectl apply -f YAMLs above and you'll have your script running.

Written in July 2021.
Kir Shatrov

Kir Shatrov helps businesses to grow by scaling the infrastructure. He writes about software, scalability and the ecosystem. Follow him on Twitter to get the latest updates.