Die vorliegende Übersetzung wurde maschinell erstellt. Im Falle eines Konflikts oder eines Widerspruchs zwischen dieser übersetzten Fassung und der englischen Fassung (einschließlich infolge von Verzögerungen bei der Übersetzung) ist die englische Fassung maßgeblich.
Bereitstellen einer Rails-Anwendung in Elastic Beanstalk
Rails ist ein Open-Source-Framework model-view-controller (MVC) für Ruby. Dieses Tutorial führt Sie durch den Prozess der Generierung einer Rails-Anwendung und deren Bereitstellung in einer AWS Elastic Beanstalk Umgebung.
Sections
Voraussetzungen
Anmerkung
AWS Konten, die nach dem 1. Oktober 2024 erstellt wurden, müssen vorübergehend eine Option festlegen, um erfolgreich eine neue Umgebung zu erstellen. Wie bei neuen Konten, aber nur für Regionen, in denen das Konto noch keine Umgebung hat, müssen bestehende Konten die gleichen Maßnahmen ergreifen. Weitere Informationen finden Sie unter Startvorlagen.
Grundkenntnisse zu Elastic Beanstalk
In diesem Tutorial wird davon ausgegangen, dass Sie die grundlegenden Elastic Beanstalk-Operationen und die Elastic Beanstalk-Konsole kennen. Sofern noch nicht geschehen, starten Sie anhand der Anleitung in Erste Schritte mit Elastic Beanstalk die erste Elastic-Beanstalk-Umgebung.
Befehlszeile
Um die Verfahren in diesem Leitfaden zu befolgen, benötigen Sie ein Befehlszeilen-Terminal oder eine Shell für die Ausführung der Befehle. Befehle werden ggf. in Auflistungen mit einem vorangestellten Eingabeaufforderungssymbol ($) und dem Namen des aktuellen Verzeichnisses angezeigt.
~/eb-project$ this is a command
this is output
In Linux und macOS können Sie Ihren bevorzugten Shell- und Paket-Manager verwenden. Unter Windows können Sie das Windows-Subsystem für Linux installieren
Rails-Abhängigkeiten
Das Rails-Framework 6.1.4.1 hat die folgenden Abhängigkeiten. Stellen Sie sicher, dass Sie alle installiert haben.
-
Ruby 2.5.0 oder höher – Installationsanweisungen finden Sie unter Einrichtung Ihrer Ruby-Entwicklungsumgebung für Elastic Beanstalk.
In diesem Tutorial verwenden wir Ruby 3.0.2 und die entsprechende Elastic Beanstalk-Plattformversion.
-
Node.js – Anweisungen zur Installation finden Sie unter Installieren von Node.js über den Package Manager
. -
Yarn – Anweisungen zur Installation finden Sie unter Installation
auf der Yarn-Website.
Starten einer Elastic Beanstalk-Umgebung
Erstellen Sie mit der Elastic Beanstalk-Konsole, eine Elastic Beanstalk-Umgebung. Wählen Sie die Plattform Ruby und übernehmen Sie die Standardeinstellungen und den Beispielcode.
So starten Sie eine Umgebung (Konsole)
-
Wählen Sie unter Platform (Plattform) die Plattform und die Plattformvariante aus, die mit der Sprache Ihrer Anwendung übereinstimmen.
-
Wählen Sie unter Application code (Anwendungscode) die Option Sample application (Beispielanwendung) aus.
-
Klicken Sie auf Review and launch (Überprüfen und starten).
-
Sehen Sie sich die verfügbaren Optionen an. Wählen Sie die gewünschte verfügbare Option aus und wählen Sie Create App (App erstellen) aus.
Das Erstellen der Umgebung benötigt etwa fünf Minuten. Dabei werden die folgenden Ressourcen erstellt:
-
EC2Instanz — Eine virtuelle Maschine von Amazon Elastic Compute Cloud (AmazonEC2), die für die Ausführung von Web-Apps auf der von Ihnen ausgewählten Plattform konfiguriert ist.
Jede Plattform führt eine spezifische Gruppe von Software, Konfigurationsdateien und Skripts zur Unterstützung einer bestimmten Sprachversion, eines Frameworks, Webcontainers oder einer Kombination daraus aus. Die meisten Plattformen verwenden entweder Apache oder NGINX als Reverse-Proxy, der sich vor Ihrer Web-App befindet, Anfragen an diese weiterleitet, statische Ressourcen bereitstellt und Zugriffs- und Fehlerprotokolle generiert.
-
Instance-Sicherheitsgruppe — Eine EC2 Amazon-Sicherheitsgruppe, die so konfiguriert ist, dass sie eingehenden Datenverkehr auf Port 80 zulässt. Diese Ressource ermöglicht es dem HTTP Datenverkehr vom Load Balancer, die EC2 Instance zu erreichen, auf der Ihre Web-App ausgeführt wird. Standardmäßig ist Datenverkehr auf anderen Ports nicht zulässig.
-
Load balancer (Load Balancer)– Ein Elastic Load Balancing Load Balancer ist für die Verteilung von Anforderungen an die Instances, auf denen Ihre Anwendung ausgeführt wird, konfiguriert. Mit einem Load Balancer müssen Ihre Instances nicht mehr direkt für das Internet zugänglich gemacht werden.
-
Load Balancer-Sicherheitsgruppe — Eine EC2 Amazon-Sicherheitsgruppe, die so konfiguriert ist, dass sie eingehenden Verkehr auf Port 80 zulässt. Diese Ressource ermöglicht es dem HTTP Datenverkehr aus dem Internet, den Load Balancer zu erreichen. Standardmäßig ist Datenverkehr auf anderen Ports nicht zulässig.
-
Auto Scaling group (Auto Scaling-Gruppe) – Eine Auto Scaling-Gruppe, die so konfiguriert ist, dass sie eine Instance ersetzt, wenn diese beendet wird oder nicht verfügbar ist.
-
Amazon S3-Bucket – Ein Speicherort für Ihren Quellcode, Protokolle und andere Artefakte, die bei der Verwendung von Elastic Beanstalk erstellt werden.
-
CloudWatch CloudWatch Amazon-Alarme — Zwei Alarme, die die Auslastung der Instances in Ihrer Umgebung überwachen und ausgelöst werden, wenn die Last zu hoch oder zu niedrig ist. Wenn ein Alarm ausgelöst wird, wird Ihre Auto Scaling-Gruppe nach oben oder nach unten skaliert.
-
AWS CloudFormation stack — Elastic Beanstalk verwendet AWS CloudFormation , um die Ressourcen in Ihrer Umgebung zu starten und Konfigurationsänderungen zu propagieren. Die Ressourcen werden in einer Vorlage definiert, die Sie in der AWS CloudFormation -Konsole
anzeigen können. -
Domainname — Ein Domainname, der in der folgenden Form an Ihre Web-App weitergeleitet wird
subdomain
.region
.elasticbeanstalk.com.Domain-Sicherheit
Wenn Sie jemals sensible Cookies im Standard-Domainnamen für Ihre Elastic Beanstalk Beanstalk-Anwendungen einrichten müssen, empfehlen wir Ihnen, Cookies mit einem
__Host-
Präfix zu verwenden, um die Sicherheit zu erhöhen. Diese Vorgehensweise schützt Ihre Domain gegen Versuche zur Fälschung von Cross-Site-Requests (). CSRF Weitere Informationen finden Sie auf der Set-Cookie-Seite im Mozilla Developer Network.
All diese Ressourcen werden von Elastic Beanstalk verwaltet. Wenn Sie die Umgebung beenden, werden alle darin enthaltenen Ressourcen von Elastic Beanstalk beendet.
Anmerkung
Der von Elastic Beanstalk erstellte Amazon S3-Bucket wird von den Umgebungen gemeinsam genutzt und beim Beenden einer Umgebung nicht gelöscht. Weitere Informationen finden Sie unter Verwenden von Elastic Beanstalk mit Amazon S3.
Installieren von Rails und Generieren einer Website
Installieren Sie Rails und seine Abhängigkeiten mit dem Befehl gem
.
~$ gem install rails
Fetching: concurrent-ruby-1.1.9.gem
Successfully installed concurrent-ruby-1.1.9
Fetching: rack-2.2.3.gem
Successfully installed rack-2.2.3
...
Testen Sie Ihre Rails-Installation.
~$ rails --version
Rails 6.1.4.1
Verwenden Sie rails new
mit dem Namen der Anwendung, um ein neues Rails-Projekt zu erstellen.
~$ rails new ~/eb-rails
Rails erstellt ein Verzeichnis mit dem angegebenen Namen, generiert alle Dateien, die für eine lokale Ausführung des Beispielprojekts benötigt werden, und führt anschließend Bundler aus, um alle Abhängigkeiten (Gems) zu installieren, die in der Gemfile-Datei des Projekts definiert sind.
Anmerkung
Dieser Prozess installiert die neueste Puma-Version für das Projekt. Diese Version kann sich von der Version unterscheiden, die Elastic Beanstalk in der Ruby-Plattformversion Ihrer Umgebung bereitstellt. Weitere Informationen zu Puma-Versionen von Elastic Beanstalk finden Sie unter Ruby-Plattformverlauf im Leitfaden für AWS Elastic Beanstalk -Plattformen. Weitere Informationen über die neueste Pumaversion finden Sie unter der Puma.io
Verwenden Sie die Puma-Version, die mit dem vorherigen
rails new
-Befehl installiert wurde. In diesem Fall müssen Sie einProcfile
für die Plattform hinzufügen, um Ihre eigene bereitgestellte Puma-Serverversion zu verwenden. Weitere Informationen finden Sie unter Konfiguration des Bewerbungsprozesses mit einem Profil auf Elastic Beanstalk..Aktualisieren Sie die Puma-Version so, dass sie mit der Version der Ruby-Platform Ihrer Umgebung übereinstimmt. Ändern Sie hierzu die Pumaversion im Gemfile, die sich im Stammverzeichnis des Projekts befindet. Führen Sie dann
bundle update
aus. Weitere Informationen finden Sie auf der Seite Bundle-Updateauf der Bundler.io-Website.
Testen Sie die Rails-Installation, indem Sie das Standardprojekt lokal ausführen.
~$ cd eb-rails
~/eb-rails$ rails server
=> Booting Puma
=> Rails 6.1.4.1 application starting in development
=> Run `bin/rails server --help` for more startup options
Puma starting in single mode...
* Puma version: 5.5.2 (ruby 3.0.2-p107) ("Zawgyi")
* Min threads: 5
* Max threads: 5
* Environment: development
* PID: 77857
* Listening on http://127.0.0.1:3000
* Listening on http://[::1]:3000
Use Ctrl-C to stop
...
Öffnen Sie http://localhost:3000
in einem Webbrowser, um das Standardprojekt in Aktion zu sehen.
Diese Seite ist nur im Entwicklungsmodus sichtbar. Fügen Sie Inhalte auf der Titelseite der Anwendung hinzu, um die Produktionsbereitstellung in Elastic Beanstalk zu unterstützen. Erstellen Sie mit rails generate
einen Controller, eine Route und eine Ansicht für die Willkommensseite.
~/eb-rails$ rails generate controller WelcomePage welcome
create app/controllers/welcome_page_controller.rb
route get 'welcome_page/welcome'
invoke erb
create app/views/welcome_page
create app/views/welcome_page/welcome.html.erb
invoke test_unit
create test/controllers/welcome_page_controller_test.rb
invoke helper
create app/helpers/welcome_page_helper.rb
invoke test_unit
invoke assets
invoke coffee
create app/assets/javascripts/welcome_page.coffee
invoke scss
create app/assets/stylesheets/welcome_page.scss.
Dies gibt Ihnen alles, was Sie brauchen, um auf die Seite unter /welcome_page/welcome
zuzugreifen. Bevor Sie die Änderungen veröffentlichen, sollten Sie die Inhalte der Ansicht ändern und eine Route hinzufügen, damit diese Seite als Top-Level-Objekt der Website angezeigt wird.
Ändern Sie die Inhalte in app/views/welcome_page/welcome.html.erb
mit einem Texteditor. In diesem Beispiel werden die Inhalte der bestehenden Datei einfach mit cat
überschrieben.
Beispiel app/views/welcome_page/welcome.html.erb
<h1>Welcome!</h1>
<p>This is the front page of my first Rails application on Elastic Beanstalk.</p>
Abschließend fügen Sie die folgende Route zu config/routes.rb
hinzu:
Beispiel config/routes.rb
Rails.application.routes.draw do
get 'welcome_page/welcome'
root 'welcome_page#welcome'
Damit wird Rails angewiesen, an den Website-Stamm gerichtete Anforderungen an die Willkommen-Methode des Controllers der Willkommenseite zu leiten, von der die Inhalte in der Willkommen-Ansicht dargestellt werden (welcome.html.erb
).
Damit Elastic Beanstalk die Anwendung erfolgreich auf der Ruby-Plattform bereitstellen kann, aktualisieren Sie Gemfile.lock
. Einige Abhängigkeiten von Gemfile.lock
können plattformspezifisch sein. Deshalb müssen Sie platform ruby
zu Gemfile.lock
hinzufügen, damit alle erforderlichen Abhängigkeiten mit der Bereitstellung installiert werden.
~/eb-rails$ bundle lock --add-platform ruby
Fetching gem metadata from https://rubygems.org/............
Resolving dependencies...
Writing lockfile to /Users/janedoe/EBDPT/RubyApps/eb-rails-doc-app/Gemfile.lock
Konfigurieren von Rails-Einstellungen
Konfigurieren Sie die Rails-Umgebungseigenschaften mit der Elastic Beanstalk-Konsole. Setzen Sie die SECRET_KEY_BASE
-Umgebungseigenschaft auf eine Zeichenfolge mit bis zu 256 alphanumerischen Zeichen.
Rails verwendet diese Eigenschaft, um Schlüssel zu erstellen. Aus diesem Grund sollten Sie sie geheimhalten und nicht als Klartext in der Quellsteuerung speichern. Übergeben Sie sie stattdessen an Rails-Code in Ihrer Umgebung über eine Umgebungseigenschaft.
So konfigurieren Sie Umgebungseigenschaften in der Elastic Beanstalk-Konsole
Öffnen Sie die Elastic Beanstalk Beanstalk-Konsole
und wählen Sie in der Liste Regionen Ihre aus. AWS-Region -
Wählen Sie im Navigationsbereich Environments (Umgebungen) aus und wählen Sie dann in der Liste den Namen Ihrer Umgebung aus.
Anmerkung
Wenn Sie viele Umgebungen haben, verwenden Sie die Suchleiste, um die Umgebungsliste zu filtern.
Wählen Sie im Navigationsbereich Configuration (Konfiguration) aus.
-
Wählen Sie in der Konfigurationskategorie Updates, monitoring and logging (Updates, Überwachung und Protokolle) die Option Edit (Bearbeiten) aus.
-
Scrollen Sie nach unten zu den Umgebungseigenschaften.
-
Wählen Sie Umgebungseigenschaft hinzufügen aus.
-
Geben Sie die Eigenschaftspaare Name und Wert ein.
-
Wenn Sie weitere Variablen hinzufügen müssen, wiederholen Sie Schritt 6 und Schritt 7.
-
Wählen Sie unten auf der Seite die Option Apply (Anwenden) aus, um die Änderungen zu speichern.
Jetzt können Sie die Website in Ihrer Umgebung bereitstellen.
Bereitstellen der Anwendung
Erstellen Sie ein Quell-Bundle mit den Dateien, die von Rails erstellt wurden. Der folgende Befehl erstellt ein Quell-Bundle mit dem Namen rails-default.zip
.
~/eb-rails$ zip ../rails-default.zip -r * .[^.]*
Laden Sie das Quell-Bundle nach Elastic Beanstalk hoch, um Rails in der Umgebung bereitzustellen.
So stellen Sie ein Quell-Bundle bereit
Öffnen Sie die Elastic Beanstalk Beanstalk-Konsole
und wählen Sie in der Liste Regionen Ihre aus. AWS-Region -
Wählen Sie im Navigationsbereich Environments (Umgebungen) aus und wählen Sie dann in der Liste den Namen Ihrer Umgebung aus.
Anmerkung
Wenn Sie viele Umgebungen haben, verwenden Sie die Suchleiste, um die Umgebungsliste zu filtern.
-
Wählen Sie auf der Umgebungsübersichtsseite die Option Upload and deploy (Hochladen und bereitstellen).
-
Verwenden Sie das Dialogfeld auf dem Bildschirm, um das Quellpaket hochzuladen.
-
Wählen Sie Deploy (Bereitstellen) aus.
-
Wenn die Bereitstellung abgeschlossen ist, können Sie die Site auswählen, URL um Ihre Website in einem neuen Tab zu öffnen.
Bereinigen
Wenn Sie nicht mehr mit Elastic Beanstalk arbeiten, können Sie Ihre Umgebung beenden. Elastic Beanstalk beendet alle AWS Ressourcen, die mit Ihrer Umgebung verknüpft sind, wie EC2Amazon-Instances, Datenbank-Instances, Load Balancer, Sicherheitsgruppen und Alarme.
So beenden Sie Ihre Elastic Beanstalk Beanstalk-Umgebung über die Konsole
Öffnen Sie die Elastic Beanstalk Beanstalk-Konsole
und wählen Sie in der Liste Regionen Ihre aus. AWS-Region -
Wählen Sie im Navigationsbereich Environments (Umgebungen) aus und wählen Sie dann in der Liste den Namen Ihrer Umgebung aus.
Anmerkung
Wenn Sie viele Umgebungen haben, filtern Sie Umgebungsliste mit der Suchleiste.
-
Klicken Sie auf Actions (Aktionen) und dann auf Terminate Environment (Umgebung beenden).
-
Verwenden Sie das Dialogfeld auf dem Bildschirm, um die Beendigung der Umgebung zu bestätigen.
Mit Elastic Beanstalk können Sie ganz einfach und jederzeit eine neue Umgebung für Ihre Anwendung erstellen.
Nächste Schritte
Weitere Informationen über Rails finden Sie unter rubyonrails.org
Im weiteren Verlauf der Anwendungsentwicklung können Sie Umgebungen verwalten und Anwendungen bereitstellen, ohne manuell eine ZIP-Datei zu erstellen und diese in die Elastic Beanstalk-Konsole hochzuladen. Das Elastic Beanstalk Command Line Interface (EBCLI) bietet easy-to-use Befehle zum Erstellen, Konfigurieren und Bereitstellen von Anwendungen in Elastic Beanstalk Beanstalk-Umgebungen von der Befehlszeile aus.
Wenn Sie Ihre Anwendung in einer Produktionsumgebung verwenden möchten, sollten Sie schließlich einen benutzerdefinierten Domainnamen für Ihre Umgebung konfigurieren und sichere Verbindungen aktivieren HTTPS.