HowTo Install Redmine on Debian 9 » History » Revision 6
Revision 5 (Fabián Rodríguez, 2018-07-19 16:30) → Revision 6/8 (Zer00 CooL, 2018-10-01 15:48)
h1. How to Install Redmine on Debian 9 (Stretch) 
 h2. Installing from Debian packages 
 Official Redmine packages are available for Debian. As of July 2018, stable version 3.3.1 is supported in Debian 9. 
 If you will be using Redmine in a production environment requiring long term support and stability using official packages is recommended. You will be receiving automatic feature and security updates. 
 See "the Redmine documentation on the Debian Wiki":https://wiki.debian.org/Redmine for detailed instructions. 
 h2. Installing from sources 
 If you want the very latest Redmine version and are comfortable doing manual upgrades and system administration, the following steps will guide you through installing Redmine from sources.  
 1. Install the pre-requisites for Redmine and all its packages. 
 <pre> 
 sudo apt install gcc build-essential zlib1g zlib1g-dev zlibc ruby-zip libssl-dev libyaml-dev \ 
 libcurl4-openssl-dev ruby gem libapache2-mod-passenger apache2 apache2-dev libapr1-dev \ 
 libxslt1-dev checkinstall libxml2-dev ruby-dev vim libmagickwand-dev imagemagick sudo rails 
 </pre> 
 2.    Install your database of choice.  
 <pre> 
 apt install postgresql 
 </pre> 
 3. If installing Postgres, install dev. 
 <pre> 
 apt install postgresql-server-dev-9.6 
 </pre> 
 
 4. Choose a directory where to install Redmine.    In this example /opt used.    You can use another location, but you will need to update the following steps as necessary based on your choice. 
 Install Redmine in /opt 
 <pre> 
 cd /opt 
 mkdir redmine 
 cd redmine 
 </pre> 
 Get Redmine    - use the "download":http://www.redmine.org/projects/redmine/wiki/Download page and review the functionality that you need to determine the right version for you.  
 <pre> 
 wget http://www.redmine.org/releases/redmine-3.4.6.tar.gz 
 </pre> 
 Unpack 
 <pre> 
 tar xzf ./redmine-3.4.6.tar.gz 
 </pre> 
 5. Login as the default postgres user and create a new role and database. Use your own password. 
 <pre> 
 sudo -u postgres psql postgres 
 CREATE ROLE redmine LOGIN ENCRYPTED PASSWORD 'your_password' NOINHERIT VALID UNTIL 'infinity'; 
 CREATE DATABASE redmine WITH ENCODING='UTF8' OWNER=redmine; 
 </pre> 
 then press CTRL-D to escape the shell. 
 edit @/etc/postgresql/9.6/main/pg_hba.conf@ and set Postgres to trust :  
 <pre> 
 "local all postgres trust " 
 sudo service postgresql reload  
 </pre> 
 6. Create the @/opt/redmine/redmine-3.4.6/config/database.yml@ file with the following contents… 
 <pre> 
 production: 
   adapter: postgresql 
   database: redmine 
   host: localhost 
   username: redmine 
   password: your_password 
 </pre> 
 Note that the spacing is important in this file. Under the “Production” line, each other line must be indented by two spaces, not tabs.    Replace your_password with the password specified above. Remember to save.    Keep in mind Postgresql passwords can't start with @ character (or other non alpha numerics). 
 7. Next, set up the database schema and load the initial database. 
 <pre> 
 bundle install 
 bundle exec rake generate_secret_token 
 RAILS_ENV=production bundle exec rake db:migrate 
 RAILS_ENV=production bundle exec rake redmine:load_default_data 
 </pre> 
 8.Do a quick test to verify that redmine is working using webrick. 
 <pre> 
 bundle exec ruby /usr/bin/rails server -b your_ip webrick -e production 
 </pre> 
 Now try to connect via browser to @http://your_ip:3000@. Webrick is not for production systems.    It is a good way to check things before getting started with Apache, though. 
 9. Next, let’s set up Apache. 
 <pre> 
 cd /opt/ 
 sudo chown -R www-data:www-data /opt/redmine 
 cd /opt/redmine/redmine-3.4.6 
 sudo chmod -R 755 files log tmp public/plugin_assets 
 sudo chown www-data:www-data Gemfile.lock 
 </pre> 
 9.1 Create a symbolic link which points from the Apache working directory to the Redmine public folder 
 <pre> 
 sudo ln -s /opt/redmine/redmine-3.4.6/public/ /var/www/html/redmine 
 </pre> 
 9.2 Create a new vhost configuration 
 <pre> 
 sudo nano /etc/apache2/sites-available/master.conf 
 </pre> 
 and paste in: 
 <pre> 
 <VirtualHost *:80> 
 ServerAdmin admin@example.com 
 Servername hostname 
 DocumentRoot /var/www/html/ 
 <Location /redmine> 
 RailsEnv production 
 RackBaseURI /redmine 
 Options -MultiViews 
 </Location> 
 </VirtualHost> 
 </pre> 
 Then, run: 
 <pre> 
 sudo a2dissite 000-default.conf 
 sudo a2ensite master.conf 
 </pre> 
 9.3 add this line to @/etc/apache2/mods-available/passenger.conf@ in the body of the document- not just the 1st line. 
 <pre> 
 PassengerUser www-data 
 </pre> 
 Restart the Apache web server: 
 <pre> 
 sudo service apache2 restart 
 </pre> 
 10. Open your browser and navigate to: @http://your-ip-address/redmine@. 
 And hopefully, you're up and running. 
 Sources: 
 * [[HowTo Install Redmine on Debian 8 with Apache2-Passenger|Redmine with Apache and MySQL on Debian 8 jessie]] 
 Additional resources 
 A tutorial updated in 2018 (01/10/2018), in French, which repeats step by step the installation of Redmine since the package proposed in the official repositories of Debian Stretch 9. 
 https://www.visionduweb.eu/wiki/index.php?title=Installer_Redmine_sur_Debian