Ruby (AlmaLinux 8)

Ruby (AlmaLinux 8)

  • OS: almalinux 8

Description

Ruby is a high-level, interpreted, object-oriented programming language. It is designed to be easy to read and write and has been used for programming web applications, server scripts, automated tests, data processing scripts, and more. Ruby is a dynamic language that allows for dynamic linking of methods and variables, making it incredibly flexible and powerful.

Software included

Package Version
Ruby 3.2
Docker 3.20.10
Docker compose 2.12.2
containerd.io 1.6.10

Initial start of the service

This application uses Docker to provide faster startup of the underlying software (Ruby) and direct use of it. This eliminates the need to familiarize yourself with its specifics in terms of configuration and installation. To start working directly with the application, all you have to do is upload the content that you want Ruby to serve to the /opt/ruby/data/ directory.

Quick settings and frequently asked questions

  • Logging into the cloud service is done using an SSH key or password that you have specified.
  • Docker is installed as recommended by the official docker documentation.
  • The standard docker and docker compose commands are now available in this application.
  • When the virtual machine is first started, it takes a few minutes before a Docker container containing Ruby is started.
  • The ruby data where you should deploy your application is located in /opt/ruby/data/.
  • The port the service is running on is 3000.

Additional helpful tips

  • If you want to use the Ruby CLI, you can do it with the quick command docker exec -ti docker-ruby-ruby-1 ruby <COMMAND>.
  • If you often use the Ruby CLI, you can also make a quick shortcut by adding an alias as follows:
echo "alias ruby='docker exec -ti docker-ruby-ruby-1 ruby'" >> ~/.bashrc

Working with Docker

The organization of this application is entirely done using Docker. In this way, we can provide you with ready-made applications faster. In addition, their configuration is more flexible and quite controllable. To be able to control this application, however, you need to know some basic Docker functionalities and features.

Restarting all services

Restarting the database and the Docker container that contains Ruby itself, along with the rest of the software, can be done in two ways:

  1. By restarting the entire virtual machine
  2. Restarting the Docker containers, which is the faster option. To do this, access your machine via SSH, and run the following commands:
sudo su -
cd /opt/docker-ruby/
docker compose restart

Recreating Docker containers

Recreation of a docker container may be necessary if you've changed the configuration inside the docker-compose.yml file. If there are changes, please follow these steps:

cd /opt/docker-ruby/
docker compose stop
docker compose up -d

Checking the status of the Docker application

To check, you need to run the following commands:

sudo su -
docker ps -a

Please pay attention to the STATUS column. It should show how long the service has been running, for example Up X minutes. If the status is Restarting then you need to check what is wrong with the application. In such a case, you can check by following the application logs as follows:

  1. Get the application name that you can see in the NAMES column from the output of the docker ps -a command. View the logs with the docker logs <NAME> command, where is the name of the container.