Redmine in Tomcat installieren: Unterschied zwischen den Versionen

Aus Hostsharing Wiki
Zur Navigation springen Zur Suche springen
KKeine Bearbeitungszusammenfassung
 
(6 dazwischenliegende Versionen von 2 Benutzern werden nicht angezeigt)
Zeile 1: Zeile 1:
{{Textkasten|gelb|veraltet|Wir empfehlen die Installation von Redmine mit Passenger: [[Redmine_im_Webspace]]. "Ruby on Rails"-Anwendungen sind Stand heute nicht mit JRuby lauffähig.}}
== Redmine im Tomcat installieren ==
== Redmine im Tomcat installieren ==


Zeile 15: Zeile 18:
=== Download und Entpacken ===
=== Download und Entpacken ===


  cd
<syntaxhighlight lang=shell>
  mkdir tmp
cd
  cd tmp
mkdir tmp
  wget http://jruby.org.s3.amazonaws.com/downloads/1.7.11/jruby-bin-1.7.11.tar.gz
cd tmp
  wget http://www.redmine.org/releases/redmine-2.5.1.tar.gz
wget http://jruby.org.s3.amazonaws.com/downloads/1.7.11/jruby-bin-1.7.11.tar.gz
  tar xzf jruby-bin-1.7.11.tar.gz
wget http://www.redmine.org/releases/redmine-2.5.1.tar.gz
  tar xzf redmine-2.5.1.tar.gz   
tar xzf jruby-bin-1.7.11.tar.gz
tar xzf redmine-2.5.1.tar.gz   
</syntaxhighlight>


=== Datenbank anlegen und konfigurieren ===
=== Datenbank anlegen und konfigurieren ===
Zeile 29: Zeile 34:
Auf der Kommandozeile könnte das so aussehen:
Auf der Kommandozeile könnte das so aussehen:


  hsscript -u xyz00 -i
<syntaxhighlight lang="yaml">
  Password: ********
hsscript -u xyz00 -i
  xyz00@hsadmin> mysqluser.add({set:{name:'xyz00_dbadmin',password:'geheim'}})
Password: ********
  xyz00@hsadmin> mysqldb.add({set:{name:'xyz00_redmine',user:'xyz00_dbadmin'}})
xyz00@hsadmin> mysqluser.add({set:{name:'xyz00_dbadmin',password:'geheim'}})
  xyz00@hsadmin> bye
xyz00@hsadmin> mysqldb.add({set:{name:'xyz00_redmine',user:'xyz00_dbadmin'}})
xyz00@hsadmin> bye
</syntaxhighlight>


Dann wird die Datenbank in Redmine konfiguriert, indem die "Datei config/database.yml" in der entpackten
Dann wird die Datenbank in Redmine konfiguriert, indem die "Datei config/database.yml" in der entpackten
Redmine-Software angelegt. Inhalt der Datei:
Redmine-Software angelegt. Inhalt der Datei:


  production:
<syntaxhighlight lang="yaml" line>
production:
     adapter: mysql
     adapter: mysql
     database: xyz00_redmine
     database: xyz00_redmine
Zeile 45: Zeile 53:
     password: "geheim"
     password: "geheim"
     encoding: utf8
     encoding: utf8
 
</syntaxhighlight>


=== Bauen der Anwendung ===
=== Bauen der Anwendung ===


  cd $HOME/tmp/redmine-2.5.1
<syntaxhighlight lang="shell">
  export PATH=$HOME/tmp/jruby-1.7.11/bin:$PATH
cd $HOME/tmp/redmine-2.5.1
export PATH=$HOME/tmp/jruby-1.7.11/bin:$PATH
</syntaxhighlight>


Zur Kontrolle (sollte das gem im bin-Verzeichnis der JRuby-Installation liefern):
Zur Kontrolle (sollte das gem im bin-Verzeichnis der JRuby-Installation liefern):


  which gem
<syntaxhighlight lang="shell">
which gem
</syntaxhighlight>


Dann werden mit "bundler" die Abhängigkeiten aufgelöst und die Datenbank initialisiert:
Dann werden mit "bundler" die Abhängigkeiten aufgelöst und die Datenbank initialisiert:


  gem install bundler
<syntaxhighlight lang="shell">
  bundle install --without development test
gem install bundler
  rake generate_secret_token
bundle install --without development test
  RAILS_ENV=production rake db:migrate
rake generate_secret_token
  RAILS_ENV=production REDMINE_LANG=de rake redmine:load_default_data
RAILS_ENV=production rake db:migrate
RAILS_ENV=production REDMINE_LANG=de rake redmine:load_default_data
</syntaxhighlight>


Zum Schluss bauen wir eine Web-Applikation für den Tomcat Server:
Zum Schluss bauen wir eine Web-Applikation für den Tomcat Server:


  gem install warbler
<syntaxhighlight lang="shell">
  warble war
gem install warbler
 
warble war
=== Webapplikation bauen ===
</syntaxhighlight>
 
Als ''normaler'' User baue ich dann die Web-Applikation zusammen:
 
Download und entpacken von redmine in /home/user/redmine-n.n.n
 
  tar xzf redmine-1.1.1.tar.gz
  cd /home/user/redmine-1.1.1
 
Installation einiger Ruby-Gem-Pakete:
 
  mkdir /home/user/.gem
  export GEM_HOME=/home/user/.gem
  gem install -v=0.4.2 i18n
  gem install -v=1.0.1 rack
  gem install jruby-openssl
  gem install activerecord-jdbcpostgresql-adapter
  gem install rake
 
In ''config/environment.rb'' habe ich folgende Zeilen eingefügt:
 
Unmittelbar vor Rails::Initializer.run do |config|
 
    if RUBY_PLATFORM =~ /java/
      require 'rubygems'
      gem 'activerecord-jdbc-adapter'
      require 'arjdbc'
    end
 
Direkt hinter Rails::Initializer.run do |config| dann:
 
    config.action_controller.session = { :key => "_myapp_session", :secret => "ueber-30-zeichen-session-key" }
 
Dann lege ich die Datei ''config/database.yml'' mit folgendem Inhalt an:
 
    production:
      adapter: jdbc
      driver: org.postgresql.Driver
      url: jdbc:postgresql://localhost/redmine
      encoding: unicode
      username: redmine
      password: mein_geheimnis
      host: localhost
      port: 5432
 
Jetzt kann ich die Datenbank initialisieren:
 
    export RAILS_ENV=production
    jruby ~/.gem/bin/rake db:migrate
    jruby ~/.gem/bin/rake redmine:load_default_data
 
Ein erster Test mit:
 
    jruby ./script/server -e production
 
Jetzt sollte Redmine im internen ''WEBrick''-Webserver unter ''http://localhost:3000 '' erreichbar sein. Die Anmeldung mit admin/admin kann man schon ausprobieren...
 
Die letzten Schritte zum Bau der WAR-Datei:


    gem install warbler
=== Installation im Tomcat ===
    ~/.gem/bin/warble config
 
Folgendes in der Datei config/warble.rb hinter Warbler::Config.new do |config| anpassen bzw. ergänzen:
 
    config.dirs = %w(app config lib log vendor tmp extra files lang)
    config.gems += ["activerecord-jdbcpostgresql-adapter", "i18n", "jruby-openssl", "rack"]
    config.gems["i18n"] = "0.4.2"
    config.gems["rack"] = "1.0.1"
 
Der letzte Schritt
 
    ~/.gem/bin/warble
 
erzeugt eine Datei ''redmine-1.1.1.war'', die ich in ''redmine.war'' umbenenne und im Tomcat deploye.
 
=== Installation bei Hostsharing ===


Voraussetzung: Installierter Tomcat-Webserver
Voraussetzung: Installierter Tomcat-Webserver


Bei Hostsharing lege ich einen Postgres-Datenbank-Admin und eine Datenbank mit HSAdmin an.
Die war-Datei nach Wunsch umbennen (z.B. "redmine.war" oder auch "ROOT.war") und ins webapps-Verzeichnis des Tomcat kopieren.
 
In die Datenbank spiele ich über http://phppgadmin.hostsharing.net einen Dump meiner lokalen Datenbank ein.
 
Die ''redmine.war''-Datei kopiere ich auf den Hostsharing-Server. Im ''webapps''-Verzeichnis, das für meine gewünschte Domain konfiguriert ist, lege ich ein Verzeichnis ''redmine'' an. In dieses Verzeichnis entpacke ich die ''redmine.war'' mit dem ''jar''-Befehl. Zuletzt passe ich noch die Datenbank-Zugangsparameter in der Datei ''WEB-INF/config/database.yml'' aus dem ausgepackten Archiv an.


Mit einem Neustart des Tomcat (oder der Redmine-Applikation im Tomcat) kann Redmine dann genutzt werden.


[[Kategorie:HSDoku]]
[[Kategorie:Veraltet]]
[[Kategorie:Installationsanleitungen]]
[[Kategorie:Software]]

Aktuelle Version vom 15. Juli 2024, 10:33 Uhr

veraltet

Wir empfehlen die Installation von Redmine mit Passenger: Redmine_im_Webspace. "Ruby on Rails"-Anwendungen sind Stand heute nicht mit JRuby lauffähig.


Redmine im Tomcat installieren

Redmine ist ein Werkzeug zur Projektverwaltung - in erster Linie für Software-Entwicklungs-Projekte geeignet.

Redmine ist in Ruby mit dem Framework Ruby on Rails programmiert. Es steht unter der General Public License v2 (GPL).

Hier soll es als Beispiel dienen, wie man auf der Hostsharing-Infrastruktur mit der Tomcat-Option Rails-Anwendungen betrieben kann.

Vorbereitungen

Ich brauche:

  1. die aktuelle Redmine Version von redmine.org (zur Zeit Version 2.5.1)
  2. die aktuelle JRuby Version von jruby.org (aktuell Version 1.7.11)

Download und Entpacken

cd
mkdir tmp
cd tmp
wget http://jruby.org.s3.amazonaws.com/downloads/1.7.11/jruby-bin-1.7.11.tar.gz
wget http://www.redmine.org/releases/redmine-2.5.1.tar.gz
tar xzf jruby-bin-1.7.11.tar.gz
tar xzf redmine-2.5.1.tar.gz

Datenbank anlegen und konfigurieren

Die Datenbank wird mit HSAdmin angelegt.

Auf der Kommandozeile könnte das so aussehen:

hsscript -u xyz00 -i
Password: ********
xyz00@hsadmin> mysqluser.add({set:{name:'xyz00_dbadmin',password:'geheim'}})
xyz00@hsadmin> mysqldb.add({set:{name:'xyz00_redmine',user:'xyz00_dbadmin'}})
xyz00@hsadmin> bye

Dann wird die Datenbank in Redmine konfiguriert, indem die "Datei config/database.yml" in der entpackten Redmine-Software angelegt. Inhalt der Datei:

production:
    adapter: mysql
    database: xyz00_redmine
    host: localhost
    username: xyz00_dbadmin
    password: "geheim"
    encoding: utf8

Bauen der Anwendung

cd $HOME/tmp/redmine-2.5.1
export PATH=$HOME/tmp/jruby-1.7.11/bin:$PATH

Zur Kontrolle (sollte das gem im bin-Verzeichnis der JRuby-Installation liefern):

which gem

Dann werden mit "bundler" die Abhängigkeiten aufgelöst und die Datenbank initialisiert:

gem install bundler
bundle install --without development test
rake generate_secret_token
RAILS_ENV=production rake db:migrate
RAILS_ENV=production REDMINE_LANG=de rake redmine:load_default_data

Zum Schluss bauen wir eine Web-Applikation für den Tomcat Server:

gem install warbler
warble war

Installation im Tomcat

Voraussetzung: Installierter Tomcat-Webserver

Die war-Datei nach Wunsch umbennen (z.B. "redmine.war" oder auch "ROOT.war") und ins webapps-Verzeichnis des Tomcat kopieren.