RubyRBEnv: Unterschied zwischen den Versionen
Tim (Diskussion | Beiträge) |
Tim (Diskussion | Beiträge) |
||
Zeile 46: | Zeile 46: | ||
== Ruby Web Applikation mit Passenger == | == Ruby Web Applikation mit Passenger == | ||
Zur Integration der eigenen Ruby-Installation in den Apache erfolgt über das Apache-Modul "Passenger". | |||
Vor der Nutzung dieses Moduls bitte unbedingt die | |||
[[Phusion Passenger|Hinweise zur Nutzung beachten]]. | |||
Um eine Beispielanwendung zu installieren, orientieren wir uns an https://github.com/phusion/passenger-ruby-sinatra-demo/tree/end_result | |||
Im Verzeichnis "/home/pacs/xyz00/users/example/doms/example.com/app-ssl/" legen wir folgende Dateien und Verzeichnisse an: | |||
Gemfile: | |||
<pre> | |||
source 'https://rubygems.org/' | |||
gem 'sinatra' | |||
gem 'tilt' | |||
gem 'base64', '0.1.1' | |||
</pre> | |||
app.rb: | |||
<pre> | |||
require 'sinatra/base' | |||
require 'tilt/erb' | |||
class ExampleApp < Sinatra::Base | |||
get '/' do | |||
erb :index | |||
end | |||
end | |||
</pre> | |||
views/index.erb: | |||
<pre> | |||
<!DOCTYPE html> | |||
<html> | |||
<head><title>Hello</title></head> | |||
<body> | |||
<h1>Hello world!</h1> | |||
<% if defined?(PhusionPassenger) %> | |||
<p>Congratulations, you are running this app in Passenger!<br/> | |||
You are running Ruby Version: <%= RUBY_VERSION %> | |||
</p> | |||
<% else %> | |||
<p>You are not running this app in Passenger.</p> | |||
<% end %> | |||
</body> | |||
</html> | |||
</pre> | |||
Im Verzeichnis "/home/pacs/xyz00/users/example/doms/example.com/app-ssl/" führen wir aus: | |||
bundle config set --local path vendor/bundle | |||
bundle install | |||
---- | ---- | ||
[[Kategorie:Installationsanleitungen]] | [[Kategorie:Installationsanleitungen]] | ||
[[Kategorie:Software]] | [[Kategorie:Software]] |
Version vom 17. Januar 2024, 16:40 Uhr
Eigene Ruby Installation
Oft ist die vorinstallierte Version der Programmiersprache Ruby (die in Debian enthaltene Version) zu alt für die eingesetze Software.
Hier eine kurze Anleitung, mit der man eine eigene Ruby-Umgebung für einen User einrichten kann.
Installation von rbenv
Konfiguration für einen User mit "/bin/bash" als Shell. Die Umgebungsvariablen werden in ".bash_profile" hinterlegt.
$ git clone https://github.com/sstephenson/rbenv.git ~/.rbenv $ echo 'export PATH="$HOME/.rbenv/bin:$PATH"' >> ~/.bash_profile $ echo 'eval "$(rbenv init -)"' >> ~/.bash_profile $ source ~/.bash_profile
Der Befehl
$ type rbenv
sollte eine Ausgabe erzeugen, die beginnt: "rbenv is a function"
Installation von ruby-build
$ git clone https://github.com/sstephenson/ruby-build.git ~/.rbenv/plugins/ruby-build
Installation von ruby
Mit dem Kommando
$ rbenv install --list
erhält man eine Liste der aktuell untersützten Ruby-Versionen
Installation mit (hier Version 3.1.3):
$ rbenv install 3.1.3 $ rbenv global 3.1.3 $ gem install bundler $ rbenv rehash
Der Befehl
$ ruby -v
liefert die Ausgabe "ruby 3.1.3p185 (2022-11-24 revision 1a6b16756e) [x86_64-linux]"
Ruby Web Applikation mit Passenger
Zur Integration der eigenen Ruby-Installation in den Apache erfolgt über das Apache-Modul "Passenger". Vor der Nutzung dieses Moduls bitte unbedingt die Hinweise zur Nutzung beachten.
Um eine Beispielanwendung zu installieren, orientieren wir uns an https://github.com/phusion/passenger-ruby-sinatra-demo/tree/end_result
Im Verzeichnis "/home/pacs/xyz00/users/example/doms/example.com/app-ssl/" legen wir folgende Dateien und Verzeichnisse an:
Gemfile:
source 'https://rubygems.org/' gem 'sinatra' gem 'tilt' gem 'base64', '0.1.1'
app.rb:
require 'sinatra/base' require 'tilt/erb' class ExampleApp < Sinatra::Base get '/' do erb :index end end
views/index.erb:
<!DOCTYPE html> <html> <head><title>Hello</title></head> <body> <h1>Hello world!</h1> <% if defined?(PhusionPassenger) %> <p>Congratulations, you are running this app in Passenger!<br/> You are running Ruby Version: <%= RUBY_VERSION %> </p> <% else %> <p>You are not running this app in Passenger.</p> <% end %> </body> </html>
Im Verzeichnis "/home/pacs/xyz00/users/example/doms/example.com/app-ssl/" führen wir aus:
bundle config set --local path vendor/bundle bundle install