Project

General

Profile

HowTo Install Redmine in Ubuntu » History » Version 26

Caner Candan, 2011-04-21 13:45
minor: install parameter missing with apt-get command

1 1 Umit Uzun
{{>toc}}
2
3 22 Anthony C
h1. Ubuntu 10.04 (and 10.04.1) using Passenger
4
5
The installation assumes that the web server and database are already in place, so you probably want to install the LAMP stack first if you don't already have it:
6
7
> $ sudo tasksel install lamp-server
8
9
Also, the default AppArmor configuration can get in the way, so you may need to set the mysqld profile to complain:
10
11
> $ sudo aa-complain /usr/sbin/mysqld
12
13 14 allen yeh
As of 10.04, Redmine is available through Ubuntu's package manager, and installation is simple:
14 3 Sam Wilson
15 14 allen yeh
> $ sudo apt-get install redmine redmine-mysql subversion
16 3 Sam Wilson
17 1 Umit Uzun
The second package, _redmine-mysql_, can be replaced by either _redmine-pgsql_ or _redmine-sqlite_ if you want to use either of those databases.
18
19 22 Anthony C
The installation process should prompt you for all the interesting details.
20
21 1 Umit Uzun
Redmine will now be installed in @/usr/share/redmine@ and @/etc/redmine@
22
23 24 John Hogenmiller
Note:  The package with Ubuntu is stuck in the 0.9.x branch for now.  A PPA exists that has the 1.1 branch here: https://launchpad.net/~ondrej/+archive/redmine
24
25
To install redmine using the PPA:
26
27
  sudo add-apt-repository ppa:ondrej/redmine
28
sudo apt-get update
29
sudo apt-get install redmine 
30
31 22 Anthony C
If you set your AppArmor mysqld profile to complain you ought to set it back to enforce:
32
33
> $ sudo aa-enforce /usr/sbin/mysqld
34
35 1 Umit Uzun
h2. Configuration
36
37 22 Anthony C
Symlink @/usr/share/redmine/public@ to your desired web-accessible location.  E.g.:
38
39
> $ sudo ln -s /usr/share/redmine/public /var/www/redmine
40
41
By default, passenger runs as 'nobody', so you'll need to fix that. In @/etc/apache2/mods-available/passenger.conf@, add:
42
43
> PassengerDefaultUser www-data
44
45
You'll also need to configure the @/var/www/redmine@ location in @/etc/apache2/sites-available/default@ by adding:
46
47
<pre><Directory /var/www/redmine>
48
    RailsBaseURI /redmine
49
    PassengerResolveSymlinksInDocumentRoot on
50
</Directory>
51
</pre>
52
53
Enable passenger:
54
55
> $ sudo a2enmod passenger
56
57 25 Maxim Nikolaevich
Restart apache2
58
59
> $ sudo /etc/init.d/apache2 restart
60
61
and you should be able to access Redmine at: http://redmine.server.ip.address/redmine
62 22 Anthony C
63
If you receive a "403: Forbidden" error after setting up Redmine, the Redmine 'public' folder may have incorrect permissions set. The executable bit on the public folder must be enabled or you will receive a "403: Forbidden" error when attempting to access Redmine.
64
65
> $ sudo chmod a+x /usr/share/redmine/public
66
67
h1. Ubuntu 10.4 using mod_cgi
68
69
The installation assumes that the web server and database are already in place, so you probably want to install the LAMP stack first if you don't already have it:
70
71
> $ sudo tasksel install lamp-server
72
73
Also, the default AppArmor configuration can get in the way, so you may need to set the mysqld profile to complain:
74
75
> $ sudo aa-complain /usr/sbin/mysqld
76
77
As of 10.04, Redmine is available through Ubuntu's package manager, and installation is simple:
78
79
> $ sudo apt-get install redmine redmine-mysql subversion
80
81
The second package, _redmine-mysql_, can be replaced by either _redmine-pgsql_ or _redmine-sqlite_ if you want to use either of those databases.
82
83
The installation process should prompt you for all the interesting details.
84
85
Redmine will now be installed in @/usr/share/redmine@ and @/etc/redmine@
86
87
If you set your AppArmor mysqld profile to complain you ought to set it back to enforce:
88
89
> $ sudo aa-enforce /usr/sbin/mysqld
90
91
h2. Configuration
92
93 3 Sam Wilson
> Using Ubuntu Server 10.04.1, configuring Redmine via mod_cgi as described in this section does not seem to work. If you can successfully make this work, please update these instructions! Otherwise follow the instructions in the next section for installing on Ubuntu 10.04 using Passenger if mod_cgi does not work for you.
94
95
Symlink @/usr/share/redmine/public@ to your desired web-accessible location.  E.g.:
96
97
> $ sudo ln -s /usr/share/redmine/public /var/www/redmine
98
99
The other files that you need to modify/create are as follows:
100
101
@/etc/redmine/default/database.yml@:
102 1 Umit Uzun
103 14 allen yeh
<pre>
104 6 Roger Lipscombe
production:
105
  adapter: mysql
106 5 Roger Lipscombe
  database: redmine
107 14 allen yeh
  host: localhost
108 5 Roger Lipscombe
  username: redmine
109
  password: pa55w0rd
110
  encoding: utf8
111
</pre>
112
113
@/usr/share/redmine/public/dispatch.cgi@:
114
115
<pre>
116
#!/usr/bin/ruby
117
118
require File.dirname(__FILE__) + "/../config/environment" unless defined?(RAILS_ROOT)
119 20 Peter Hobor
120 5 Roger Lipscombe
require "dispatcher"
121
122
ADDITIONAL_LOAD_PATHS.reverse.each { |dir| $:.unshift(dir) if File.directory?(dir) } if defined?(Apache::RubyRun)
123
Dispatcher.dispatch
124
</pre>
125
126
@/usr/share/redmine/public/.htaccess@:
127 15 Spenser Gilliland
128 5 Roger Lipscombe
<pre>
129
RewriteEngine On
130
RewriteBase /redmine
131
RewriteRule ^$ index.html [QSA]
132
RewriteRule ^([^.]+)$ $1.html [QSA]
133
RewriteCond %{REQUEST_FILENAME} !-f
134 17 Tim M
RewriteRule ^(.*)$ dispatch.cgi [QSA,L]
135
</pre>
136
137
And that's it!  If these instructions didn't work for you, please expand them to include whatever is needed.
138 5 Roger Lipscombe
139 14 allen yeh
h1. Redmine Installation on Virtual or Normal Ubuntu < 10.04
140 1 Umit Uzun
141 21 Graham King
This page is a guide to installing Redmine on either a virtual or actual installation of the Ubuntu operating system.  If you follow all instructions correctly you will have installed your Redmine server successfully in almost an hour.
142 1 Umit Uzun
143 2 Sam Wilson
h2. Step 1: Install Ubuntu
144 1 Umit Uzun
145 2 Sam Wilson
If you are installing on a non-virtual Ubuntu instance, please skip this section.
146 1 Umit Uzun
147 2 Sam Wilson
*Installing VirtualBox:*
148
149 21 Graham King
1.Download the latest version of Sun VirtualBox (version 3.0.10 or newer).
150
2.Install VirtualBox by following the instructions.
151 1 Umit Uzun
152
*Installing Ubuntu on VirtualBox:*
153
154 21 Graham King
1.Download the latest version of Ubuntu (version 9.10 or newer).
155
2.After installing VirtualBox you will create a new virtual operating which will be Linux type and Ubuntu subtype. If you don't know anything about VirtualBox and/or its usage please refer to Google.
156 1 Umit Uzun
157 21 Graham King
3.While installing Ubuntu you should enter the following configuration:
158
(This suggested configuration is optional, you can enter any names you want.)
159 1 Umit Uzun
Q: What is your name? A: Redmine Server
160
Q: What name do you want to use to login? A: redmine
161
Q: Choose to password to keep your account safe? A: redmine
162
Q: What is the name of this computer? A: redmine-server
163
Choose “Log in automatically.” radio button.
164
165 21 Graham King
4.When you've finished the installation, open up your new VirtualBox Ubuntu OS and open up a terminal (console) screen and issue these commands:
166 1 Umit Uzun
> sudo apt-get update
167
> sudo apt-get upgrade
168
169
*Configuring VirtualBox:*
170
171 21 Graham King
1.If you want to reach your VirtualBox Ubuntu OS from a different machine, you have to configure VirtualBox Ubuntu OS's network settings to Bridged Adapter. So you can reach your VirtualBox Ubuntu from an internal IP address easily. Because it get's the same IP block as you from DHCP easily. I mean your guest and host computer is same IP block as different network client.
172 1 Umit Uzun
173 21 Graham King
2.If you had assigned a static IP to your Network Consult by giving your static ethernet MAC address, you have to assign the unique MAC address your VirtualBox Ubuntu OS by Setting->Network->MAC address initialization box. By this MAC address, you can get a static IP easily or you can configure your Ubuntu system to not use DHCP, instead of that you can assign a static IP manually.
174 1 Umit Uzun
175 2 Sam Wilson
h2. Step 2: Install Redmine
176 1 Umit Uzun
177 2 Sam Wilson
Once you have a functioning Ubuntu operating system up and running, you can continue with installing Redmine.
178 1 Umit Uzun
179 2 Sam Wilson
h3. Install dependencies
180
181
The following packages are required to install and run Redmine.  Please install them by running @apt-get@ as root:
182
183 26 Caner Candan
>sudo apt-get install package-name
184 2 Sam Wilson
185
where @package-name@ is each of:
186
* apache2 
187
* apache2-threaded-dev 
188
* build-essential
189
* libapache-dbi-perl 
190
* libapache2-mod-perl2 
191
* libapache2-svn
192
* libdigest-sha1-perl 
193
* libgemplugin-ruby 
194
* libgemplugin-ruby1.8 
195
* libruby-extras 
196
* libruby1.8-extras 
197
* mongrel 
198
* mysql-server
199
* rails
200
* rake 
201
* ruby
202
* rubygems
203
* rubygems1.8
204 1 Umit Uzun
* ruby1.8-dev
205 2 Sam Wilson
* subversion
206 1 Umit Uzun
207
_(Could someone please clean up this list?)_
208 2 Sam Wilson
209
h3. Package Installation and Setup
210 16 Ian Epperson
211 1 Umit Uzun
1.Once you’ve installed the VirtualBox Ubuntu OS and updated it, you need to install a bunch of packages that we will prepare the server for the Redmine installation. So, as root, install the following packages by issuing: 
212
> sudo apt-get install 
213 2 Sam Wilson
> sudo apt-get install 
214 21 Graham King
(_Surely some missing package names above?_)
215 1 Umit Uzun
216
The packages we’re installing above are MySQL, phpMyAdmin, Rails, Ruby Gems, Mongrel and Ruby Dev environment.
217 21 Graham King
During the installation of the packages, when MySQL is installed, it will prompt you to	create a password. Make sure you remember it. You will need it later to log in to phpMyAdmin. To make things simple you can set all passwords to “redmine”.
218 1 Umit Uzun
219 21 Graham King
2.Create a new directory for Redmine. I put mine in /opt/redmine. And download the latest version of Redmine in to it with the wget command line downloader and extract it by issuing:
220 1 Umit Uzun
> sudo mkdir /opt/redmine
221
> sudo cd /opt/redmine
222
> sudo wget http://rubyforge.org/frs/download.php/66633/redmine-0.8.6.tar.gz
223
> tar -xvf redmine-0.8.6.tar.gz
224
225 16 Ian Epperson
h3. Database Setup
226 1 Umit Uzun
227
1.Now it’s time to create an empty database for Redmine. As you may have noticed, we installed phpMyAdmin earlier. phpMyAdmin will come in handy now. Head over to http://localhost/phpmyadmin. You should be presented with the phpMyAdmin login screen.
228
Type in “root” and the MySQL “password” you created when installing MySQL.
229
230 21 Graham King
2.First, click on “Databases” then, at the bottom of the screen, in the “Create new database” text box create a new database called “redmine” and set “Collation” to “utf8_general_ci”.
231 1 Umit Uzun
232
3.Now, go back to the home screen and click on:
233
“Privileges”
234
“Add a new User” 
235
Fill out the “Login Information” boxes. Call your user “redmine”. Make sure you remember password you create here. It will be used when you set up the database connection details in Redmine.
236
In the “Database for user” section, check “Create database with same name and grant all privileges” and click on the “Go” button.
237
238
4.Log out of phpMyAdmin.
239
240 16 Ian Epperson
h3. Redmine Database Connection Configuration
241 1 Umit Uzun
242
1.It’s time to configure the database connection. If you installed Redmine as I did above, then copy “config/database.yml.example” to “config/database.yml” and edit this file in order to configure your database settings for “production” environment. You’ll find the “database.yml.example” issuing:
243
> sudo cd /opt/redmine/redmine-0.8.6/config
244
245
2.So now, assuming you’re in the “/opt/redmine/redmine-0.8.6/config” directory, issue:
246
> sudo cp database.yml.example database.yml 
247
248
3.Then, open the “database.yml” file, issue:
249
> sudo gedit database.yml
250
… and edit it as in the example for a MySQL database below:
251
252
production:
253
adapter: mysql
254
socket: /var/run/mysqld/mysqld.sock
255
database: redmine
256
host: localhost
257
username: redmine
258
password: [password]
259
260 21 Graham King
Then save the “database.yml” file and exit to the command prompt.
261 1 Umit Uzun
On Ubuntu the “mysql.sock” is located in /var/run/mysqld/mysqld.sock, as noted in the “config” above. 
262
(The standard Redmine installation assumes the socket is located in “/opt/redmine/redmine-0.8.6/tmp/mysqld.sock”.)
263
264 21 Graham King
4.Create the database structure, by running the following command under the application root directory (I mean “/opt/redmine/redmine-0.8.6”):
265 1 Umit Uzun
> sudo rake db:migrate RAILS_ENV="production" 
266 21 Graham King
It will create the necessary tables in the redmine database you created earlier and an administrator account.
267 1 Umit Uzun
268 21 Graham King
5.Insert the default configuration data in to the database, by issuing:
269 1 Umit Uzun
> sudo rake redmine:load_default_data RAILS_ENV="production" 
270 21 Graham King
(This step is optional but highly recommended, as you can define your own configuration from scratch. It will load default roles, trackers, statuses, work flows and enumerations. While loading default data command prompt wants to given language selection by you.) 
271 1 Umit Uzun
272 16 Ian Epperson
h3.  Setting up Permissions
273 1 Umit Uzun
274
1.The user who runs Redmine must have write permission on the following sub directories: “files”, “log”, “tmp” (create the last one if not present). You probably already have a “tmp” directory in /opt/redmine/redmine-0.8.6, but if you don’t, create one now by issuing:
275
> sudo mkdir /opt/redmine/redmine-0.8.6
276
277
2.If you haven’t created a Redmine user, do it now by issuing:
278
> sudo useradd redmine
279
280
3.Now, assuming you run Redmine with a redmine user, from your /opt/redmine/redmine-0.8.6 directory issue:
281
> sudo chown -R redmine:redmine files log tmp
282
> sudo chmod -R 755 files log tmp
283
284 16 Ian Epperson
h3.  Testing the Installation
285 1 Umit Uzun
286
1.It should all be working now. Test the installation by running the WEBrick web server issue:
287
> sudo cd /opt/redmine/redmine-0.8.6
288
> sudo ruby script/server -e production
289
	
290 21 Graham King
Once WEBrick has started, point your browser to http://localhost:3000/. Or, if you are using a browser on a computer other than the one you installed Redmine on, point your browser to http://192.168.1.10:3000/ (if that’s the IP address you gave your Redmine server). You should now see the application welcome page. 
291 1 Umit Uzun
292
*Log in:*
293
294
1.Use default administrator account to log in:
295
Login : admin
296
Password : admin
297
298
2.You can go to Admin & Settings to modify application settings.
299
300 16 Ian Epperson
h3.  Setting Up Static IP
301 1 Umit Uzun
302 21 Graham King
1.An easier method for configuring a static IP address is to use your local DHCP server to assign a permanent IP to the VirtualBox OS mac address. That way you will not have to do anything inside VBS. Consult your network administrator. 
303 1 Umit Uzun
304 21 Graham King
2.Or you should determine the configuration parameters given below, and then you can configure your system to have a static IP address:
305 1 Umit Uzun
The desired IP address
306
Network mask and broadcast address
307
Gateway address
308
Your local DNS server address(es)
309
310 16 Ian Epperson
h3.  Assigning Host Name and Domain for VirtualBox OS
311 1 Umit Uzun
312 21 Graham King
1.An easier method for adding your IP address - Host name pair configuration to your DNS server . Consult your network administrator.
313 1 Umit Uzun
314 2 Sam Wilson
h2. Configuring the Passenger Apache module
315 1 Umit Uzun
316 21 Graham King
Passenger is a module for apache2 that allows Apache to run Ruby on Rails applications.  Install it thus:
317 2 Sam Wilson
318
>$ sudo gem install passenger
319
320
Then go to the passenger apache2 module installation directory and run @passenger-install-apache2-module@
321
322
> $ cd /var/lib/gems/1.X/gems/passenger-X.X.X/
323
324
> $ sudo bin/passenger-install-apache2-module
325
326
Next, configure Apache:
327
328
In /etc/apache2/mods-available/passenger.load we will add next line
329
330
> LoadModule passenger_module /var/lib/gems/1.X/gems/passenger-X.X.X/ext/apache2/mod_passenger.so
331
332
We have to edit the conf of the passenger apache2 module in /etc/apache2/mods-available/passenger.conf
333
334
> PassengerRoot /var/lib/gems/1.X/gems/passenger-X.X.X
335
> PassengerRuby /usr/bin/ruby1.X
336
337 21 Graham King
And now we activate the module
338 2 Sam Wilson
339
> $ sudo a2enmod passenger
340
341
Apache virtualhost for redmine web app
342
343
<pre>
344
    <VirtualHost *:80>
345
        ServerName redmine.server.com
346
347
        DocumentRoot /var/www/redmine/public
348
349
        ServerAdmin user@server.com
350
        LogLevel warn
351
        ErrorLog /var/log/apache2/redmine_error
352
        CustomLog /var/log/apache2/redmine_access combined
353
354
        <Directory /var/www/redmine/public>
355
            Options Indexes FollowSymLinks MultiViews
356
            AllowOverride None
357
            Order allow,deny
358
            allow from all
359
        </Directory>
360
    </VirtualHost>
361
</pre>
362
363 1 Umit Uzun
subversion server config in apache
364
365 2 Sam Wilson
<pre>
366
    <VirtualHost *:80>
367
	ServerName svn.server.com
368
	ServerAdmin user@server.com
369
	ErrorLog /var/log/apache2/svn_error
370
       	CustomLog /var/log/apache2/svn_access combined
371
        <Location /project>
372
           DAV svn
373
           SVNPath /var/lib/svn/project
374
375
           AuthType Basic
376
           AuthName "Trac system for Server projects"
377
           AuthUserFile "/var/lib/svn/.htpasswd"
378
           Require valid-user 
379
	   <LimitExcept GET PROPFIND OPTIONS REPORT>
380
               Require valid-user
381
           </LimitExcept>
382
       </Location>
383
    </Virtualhost>
384
</pre>
385
386 16 Ian Epperson
h2. Sendmail Server Configuration
387 2 Sam Wilson
388 21 Graham King
1.Before configuring email support for Redmine, we should download the sendmail application for Ubuntu, issue:
389 1 Umit Uzun
> sudo apt-get install sendmail
390 21 Graham King
> sudo sendmailconfig (Answer Yes to all questions which you will be asked)
391 1 Umit Uzun
392
2.It’s time to configure the server connection. Copy “config/email.yml.example” to “config/email.yml” and edit this file in order to configure your database settings for “production” environment. You’ll find the “email.yml.example” issue:
393
> sudo cd /opt/redmine/redmine-0.8.6/config
394
395
3.So now, assuming you’re in the “/config” directory, issue:
396
> sudo cp email.yml.example email.yml 
397
398
4.Then, open the “email.yml” file, issue:
399
> sudo gedit email.yml
400
… and edit it as in the example for sendmail configuration below:
401
402
production:
403
delivery_method: :sendmail
404
sendmail_settings:
405
location: /usr/sbin/sendmail
406
arguments: -i -t
407
address: smtp.example.net
408
port: 25
409
domain: example.net
410
authentication: :none
411
user_name: redmine@example.net
412
password: redmine
413
414
Then save “email.yml” file and exit to the command prompt.
415
416
5.It’s time to configure the “environmet.rb” configuration. Open up the “environment.rb” and change “config.action_mailer.perform_deliveries = false” to “config.action_mailer.perform_deliveries = true” then save and close the “environment.rb”.
417
418
h2.  Subversion Installation and Configuration
419
420 21 Graham King
1.Before configuring Subversion support for Redmine, we should download the Subversion application for Ubuntu, issue:
421 1 Umit Uzun
> sudo apt-get install subversion
422
423
2.If your Redmine can't find the “subversion” command you can help to find by issuing:
424
· > sudo cd /opt/redmine/redmine-0.8.6/config
425
· > sudo gedit environment.rb
426
· Add ENV['PATH'] = "#{ENV['PATH']}:/subversion/path" line in it.
427
· Save and close the “environment.rb”
428
429 16 Ian Epperson
h2.  Start Application at Boot Time
430 1 Umit Uzun
431
1.To automatically start the application on booting your server you need to modify your “crontab”, issue:
432
> export EDITOR=gedit
433
> crontab -e
434
435
2.Your “crontab” file will be presented. This is the list of programs that start at certain times or at boot. Add the following to the “crontab” (all on one line):
436
@reboot cd /opt/redmine/redmine-0.8.6 ; rm -f log/mongrel.pid ; mongrel_rails start -e production -p 3000 -d
437
438 16 Ian Epperson
h2.  Backup
439 1 Umit Uzun
440
1.Running backups is always a good idea. Redmine backups should include:
441 16 Ian Epperson
* data (stored in your redmine database) 
442 1 Umit Uzun
/usr/bin/mysqldump -u -p | gzip > /path/to/redmine/backup/db/redmine_`date +%y_%m_%d`.gz
443 16 Ian Epperson
* attachments (stored in the files directory of your Redmine install)
444 1 Umit Uzun
rsync -a /path/to/redmine/files /path/to/redmine/backup/files
445
446 21 Graham King
2.Or you can use the bash shell to automate this kind of operation, issue:
447 1 Umit Uzun
> sudo cd /opt/redmine/redmine-0.8.6
448
> sudo mkdir backup
449
> sudo mkdir backup/db
450
> sudo mkdir backup/files
451
> sudo gedit backup/runRedmineBackup.bash
452
453 21 Graham King
And after open “runRedmineBackup.bash” with gedit, write all commands below:
454 16 Ian Epperson
<pre>
455 1 Umit Uzun
#!/bin/bash
456
data=`date -I`
457
mysqldump --user=root --password="redmine" --all-databases | gzip > db/backup-$data.sql.gz
458
cd db
459
ftp -i -n << EOF
460
open ftpserver.example.net
461
user username password
462
bin
463
mput backup-$data.sql.gz
464
bye
465
EOF
466 16 Ian Epperson
</pre>
467 21 Graham King
Then save the “runRedmineBackup.bash” file and exit to the command prompt. After creation of runRedmineBackup.bash you can add this bash script to run continually between specified periods. Issue:
468 1 Umit Uzun
469
> export EDITOR=gedit
470
> crontab -e
471
Add 0 0 * * 0 cd /opt/redmine/redmine-0.8.6/backup ; sh runRedmineBackup.bash commands to crontab to backup database weekly.
472
	
473 21 Graham King
For this to work without any permission problems you have to change the permissions of the files to maximum, issue:
474 1 Umit Uzun
475
> sudo chmod -R 777 backup
476
> sudo chown -R redmine:redmine backup
477
478 21 Graham King
That's all. Now we have completely installed Redmine on our virtual Ubuntu OS and can reach it from any machine in our network easily. Congratulations..!
479 1 Umit Uzun
480
h2. Sources & contributors.
481 2 Sam Wilson
482
* Ümit Uzun 06/11/2009.
483
* Some of the above material comes from Macada's wiki, licenced under the GNU Free Documentation License 1.2.  See "Redmine in Ubuntu Jaunty 9.04":http://wiki.ousli.org/index.php/Redmine_in_Ubuntu_Jaunty_9.04 by David 'macada', last modified 2010-02-08, accessed 2010-05-26.
484
* Sam Wilson 2010-05-26, formatting changes.
485 14 allen yeh
* Allen Yeh 2010-09-08, Added apt-get install subversion into instructions for 10.04 otherwise  once redmine is setup an error like this will result this error -> +*The entry or revision was not found in the repository.*+
486 18 Glenn Gould
487
h2. Additional Sources
488
489
* http://www.techrecipes.net/web/redmine/install-in-ubuntu