Redis®*: Używanie z Ruby

Jak połączyć Redis z Ruby

👋 Witamy w dokumentacji Stackhero!

Stackhero oferuje gotowe do użycia rozwiązanie Redis cloud, które zapewnia wiele korzyści, w tym:

  • Włączony web UI Redis Commander.
  • Nieograniczona wielkość i transfer wiadomości.
  • Bezproblemowe aktualizacje za pomocą jednego kliknięcia.
  • Optymalna wydajność i solidne zabezpieczenia dzięki prywatnej i dedykowanej VM.

Oszczędzaj czas i upraszczaj sobie życie: wystarczy 5 minut, aby wypróbować rozwiązanie hostingu Redis cloud Stackhero!

Redis, czyli Remote Dictionary Server, to otwartoźródłowa baza danych w pamięci, oferująca wyjątkową wydajność i elastyczność.

Często określany jako baza danych NoSQL, Redis obsługuje szeroki zakres struktur danych, takich jak ciągi znaków, hashe, listy, zbiory i zbiory uporządkowane, między innymi. Dzięki szybkim operacjom i zdolności do obsługi dużych ilości danych, Redis stał się popularnym wyborem do cache'owania, analizy w czasie rzeczywistym, przesyłania wiadomości i różnych innych zastosowań.

Redis można bezproblemowo zintegrować z Ruby i Ruby on Rails, aby zwiększyć wydajność, skalowalność i elastyczność. Wykorzystując Redis, programiści Ruby mogą wdrażać różne funkcje, takie jak cache'owanie, zarządzanie sesjami, przetwarzanie danych w czasie rzeczywistym i przetwarzanie zadań w tle, między innymi.

Oto kilka powszechnych sposobów użycia Redis z Ruby i Ruby on Rails:

  1. Cache'owanie: Redis może być używany jako magazyn cache w aplikacjach Rails, aby przyspieszyć czasy odpowiedzi i zmniejszyć obciążenie bazy danych.
  2. Przetwarzanie zadań w tle: Redis służy jako backend dla popularnych bibliotek przetwarzania zadań w tle, takich jak Sidekiq i Resque, poprawiając wydajność i niezawodność zadań w tle w aplikacjach Rails.
  3. Funkcje w czasie rzeczywistym: Funkcjonalność Pub/Sub Redis pozwala aplikacjom Rails wdrażać funkcje w czasie rzeczywistym, takie jak powiadomienia, systemy czatu i analizy w czasie rzeczywistym, ułatwiając szybkie i efektywne przesyłanie wiadomości między różnymi komponentami aplikacji.

Stackhero oferuje gotowe do użycia rozwiązanie Ruby cloud, które zapewnia wiele korzyści, w tym:

  • Wdrażaj swoją aplikację w kilka sekund za pomocą prostego git push.
  • Używaj własnej nazwy domeny i korzystaj z automatycznej konfiguracji certyfikatów HTTPS dla zwiększonego bezpieczeństwa.
  • Ciesz się spokojem dzięki automatycznym kopiom zapasowym, aktualizacjom jednym kliknięciem i prostemu, przejrzystemu oraz przewidywalnemu cennikowi.
  • Uzyskaj optymalną wydajność i solidne bezpieczeństwo dzięki prywatnej i dedykowanej VM.

Oszczędzaj czas i upraszczaj swoje życie: wypróbowanie rozwiązania Stackhero Ruby cloud hosting zajmuje tylko 5 minut.

Aby rozpocząć, możesz zainstalować gem "redis":

bundle add redis

Następnie możesz edytować plik config/environments/production.rb i dodać tę linię:

config.cache_store = :redis_cache_store, { url: ENV["REDIS_URL"] }

Na koniec zdefiniuj zmienną środowiskową REDIS_URL. Możesz użyć tego URL i po prostu zastąpić <yourPassword> i <XXXXXX> swoimi informacjami:

REDIS_URL="rediss://default:<yourPassword>@<XXXXXX>.stackhero-network.com:<PORT_TLS>"

Więcej informacji na temat konfigurowania Redis jako systemu cache dla Ruby on Rails można znaleźć w oficjalnej dokumentacji Rails tutaj.

Sidekiq automatycznie użyje serwera Redis zdefiniowanego w zmiennej środowiskowej REDIS_URL.

Możesz ustawić zmienną środowiskową REDIS_URL w ten sposób, zastępując <password> i <XXXXXX> swoimi informacjami:

REDIS_URL="rediss://default:<password>@<XXXXXX>.stackhero-network.com:<PORT_TLS>"

Domyślnie Sidekiq jest skonfigurowany w sposób, który nie toleruje zakłóceń sieciowych. Aby to poprawić, sugerujemy modyfikację konfiguracji klienta Sidekiq w config/initializers/sidekiq.rb, aby zwiększyć stabilność:

# Plik config/initializers/sidekiq.rb
Sidekiq.configure_client do |config|
  config.redis = {
    network_timeout: 5, # Ustaw timeout na 5 sekund
    pool_timeout: 5, # Ustaw timeout na 5 sekund
    reconnect_attempts: Array.new(240, 0.5) # Próbuj ponownie połączyć się 240 razy, co 0,5 sekundy (120 sekund/2 minuty łącznie) przed wywołaniem błędu
  }
end

Ta konfiguracja zapewnia, że jeśli Twój serwer Redis stanie się niedostępny, klient podejmie próby ponownego połączenia przez 2 minuty przed zgłoszeniem błędu. Daje to czas na ponowne uruchomienie serwera Redis, na przykład. W zależności od użycia Sidekiq, możesz dostosować to ustawienie, aby lepiej odpowiadało Twoim specyficznym wymaganiom.

Więcej informacji na temat Sidekiq i Redis można znaleźć w oficjalnej dokumentacji tutaj.

Resque automatycznie użyje serwera Redis zdefiniowanego w zmiennej środowiskowej REDIS_URL.

Możesz ustawić zmienną środowiskową REDIS_URL w ten sposób, zastępując <yourPassword> i <XXXXXX> swoimi informacjami:

REDIS_URL="rediss://default:<yourPassword>@<XXXXXX>.stackhero-network.com:<PORT_TLS>"

Więcej informacji na temat Resque i Redis można znaleźć w oficjalnej dokumentacji tutaj.