Redmine
Redmine is an Open Source, web-based project management and issue tracking service.
It is written using the Ruby on Rails framework and licensed under GNU General Public License v2
This guide explains how to install Redmine on Uberspace.
Error
This guide seems to be broken for all current versions of redmine, we would be happy if you want to work on a solution and create a Pull Request. See also the related issue: https://github.com/Uberspace/lab/issues/1883
Prerequisites
Checkout which version of Ruby is supported by your desired version of Redmine. Redmine version 6 for example expects Ruby 3.1, 3.2 or 3.3.
Run uberspace tools version show ruby
to show which Ruby version is currently
active on your Uberspace and uberspace tools version list ruby
to list all
available ones.
To set Ruby version 3.2 you could run (but there is no need to do so if one of the above is already active):
[isabell@stardust ~]$ uberspace tools version use ruby 3.2
Selected Ruby version 3.2
[isabell@stardust ~]$
Ruby requires a database, so you should create an empty database now.
Note
Use the collation utf8mb4
, otherwise Redmine will crash when users paste
emojis in tickets.
[isabell@stardust ~] mysql -e "CREATE DATABASE ${USER}_redmine CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;"
[isabell@stardust ~]
Your domain needs to be setup:
[isabell@stardust ~]$ uberspace web domain list
isabell.uber.space
[isabell@stardust ~]$
You’ll need your MySQL credentials. Get them with my_print_defaults
:
[isabell@stardust ~]$ my_print_defaults client
--default-character-set=utf8mb4
--user=isabell
--password=MySuperSecretPassword
[isabell@stardust ~]$
Installation
This instruction follows the official installation guide of Redmine for almost all steps, except for the step “Test the installation / Installing web server”.
Download and extract Redmine in the desired version. Ruby should not be stored
into your DocumentRoot. Instead you may create a subfolder redmine
in the
Home Directory and place
all files in there.
[isabell@stardust ~]$ wget https://redmine.org/releases/redmine-6.0.6.tar.gz
[isabell@stardust ~]$ tar xfv redmine-6.0.6.tar.gz
[isabell@stardust ~]$ mv redmine-6.0.6 redmine
[isabell@stardust ~]$ cd redmine
[isabell@stardust redmine]$
Copy the file config/database.yml.example
to config/database.yml
and edit
the new file in order to configure your database settings for the “production” environment. You’ll find your mysql password using my_print_defauls client
.
production:
adapter: mysql2
database: isabell_redmine
host: localhost
username: isabell
password: "my_secure_mysql_password"
Redmine uses Bundler to manage dependencies. Install Bundler running gem install bundler
.
Note
Package installation on recent versions of Redmine crashes because the nokogiri gem requires GLIBC_2.28 which is not available on U7.
To fix the issue one has to modify the nokogiri dependency in the Gemfile as follows:
gem 'nokogiri', '~> 1.18.3', force_ruby_platform: true
Install all dependencies running bundle install --without development test rmagick --path vendor/bundle
:
[isabell@stardust redmine]$ bundle install --without development test rmagick --path vendor/bundle
Bundle complete!
Gems in the groups development, test and rmagick were not installed.
Bundled gems are installed into `./vendor/bundle`
[isabell@stardust redmine]$
Create a secret token running bundle exec rake generate_secret_token
.
Create the database structure with the command RAILS_ENV=production bundle exec rake db:migrate
.
Redmine provides a set of default configuration data like a first admin user,
some access groups, default project settings etc. which may be added running
RAILS_ENV=production bundle exec rake redmine:load_default_data
.
All file permission should be fine automatically on Uberspace.
The installation is now done, what’s missing is the connection to the webserver.
Connecting the webserver
A Ruby specialty is that it requires a so called »appserver« as connector between your application and the webserver. The webserver, like Nginx or Apache, will handle all incoming web request and pass only request for the Ruby app along to the appserver. The appserver will then actually run your Rails app.
Ruby offers many appservers. You may use Puma, which is documented extensively in the UberLab as well.
[isabell@stardust redmine]$ gem install puma
Building native extensions. This could take a while...
Successfully installed puma
1 gem installed
[isabell@stardust redmine]$
Tip
Use the installation with the gem
command above and not with bundler,
as suggested in the Redmine installation guide, since this may trigger a
bug.
Create a configuration file for Puma called config.rb
and add the following
structure. Adapt the highlighted lines to your setup.
#!/usr/bin/env puma
# The directory of your Ruby app
directory '/home/isabell/redmine'
# The path to the Redmine rackup file
rackup '/home/isabell/redmine/config.ru'
Note
puma is running on port 9292.
To make the application accessible from the outside, configure a web backend:
[isabell@stardust ~]$ uberspace web backend set / --http --port <port>
Set backend for / to port <port>; please make sure something is listening!
You can always check the status of your backend using "uberspace web backend list".
[isabell@stardust ~]$
You could now start Puma manually and everything would work. But to start it automatically Uberspace offers the service supervisord.
Create and edit the file ~/etc/services.d/redmine-daemon.ini
and add the following content to it.
[program:redmine-daemon]
command=/opt/uberspace/etc/%(ENV_USER)s/binpaths/ruby/puma --config %(ENV_HOME)s/redmine/config.rb --environment production
autostart=yes
autorestart=yes
The --config
parameter provides the path to the Puma configuration file.
Be aware that the %(ENV_X)s
is a Python syntax, which will expand to
/home/isabell
(so the »s« is part of the syntax, not of your path).
Lastly, tell supervisord to refresh its configuration and start new services by running supervisorctl update
.
Redmine should now be available on your configured domain.
Configuration
If you’ve added the default configuration for Redmine, then you will have a default profile with the following credentials.
Name: admin
Password: admin
Redmine will ask you to change the password right after you login for the first time.
Create some users first. The create some projects. Add members to your projects.
Best practices
Rename the
admin
user to any other usernameSet up groups for teams, and assign new tickets to teams instead of individuals so everybody can see them
Updates
Check for new download versions regularly and follow the Security Advisories to stay informed about important updates.
Follow the Redmine Upgrade Guide to update the application, which consists of the same steps as the installation guide above, plus backup and restore of existing data.
Tested with Redmine 6.0.6, Ruby 3.2, Uberspace 7.16.7
Written by: Dan Untenzu <mail@pixelbrackets.de>