Project

General

Profile

HowTo Install Redmine in Ubuntu » History » Version 56

Recent Coin, 2013-02-12 00:51

1 43 Recent Coin
h1. Step-by-step for Ubuntu 12.04  or Ubuntu 10.04 using Passenger
2 41 Lee Butler
3
[[HowTo_Install_Redmine_on_Ubuntu_step_by_step|A step-by-step guide]] to getting Redmine running on a fresh installation of Ubuntu.
4
5 43 Recent Coin
h2. Assumptions In This Document 
6 36 Anonymous
7 48 Recent Coin
These instructions assume that you have a basic Ubuntu server installation with command line access.  they assume that you have the rights to install a web server (Apache2) and a database (PostgreSQL or MySQL).  They also assume that you have the ability to carry out sudo commands and that you have at least a passing familiarity with the linux OS and file system.  Lines you should type in will be on their own line and will be preceded by a vertical grey bar.
8 36 Anonymous
9 43 Recent Coin
h2. Become root or be prepared to type sudo before every command.  
10 36 Anonymous
11 43 Recent Coin
You can also save yourself a lot of time if you are doing a big install/configuration job by simply becoming 'real root' instead of typing sudo before everything by typing in either of these commands;
12 36 Anonymous
13 43 Recent Coin
>sudo -s
14 1 Umit Uzun
15 43 Recent Coin
 - OR - 
16 1 Umit Uzun
17 43 Recent Coin
>sudo -i
18 1 Umit Uzun
19 43 Recent Coin
Both will ask you to supply your password again and then you will get a # prompt which shows that you are "root" and no longer have to keep typing sudo. 
20 1 Umit Uzun
21 43 Recent Coin
h2. Be sure to run your updates before you start.  
22 1 Umit Uzun
23 43 Recent Coin
Be sure to check your /etc/apt/sources.list  You will probably want to comment out the "backports" and uncomment the extras and partners.  
24
25
>apt-get update
26
27
If you get any key errors for any of the repositories, you can fix them easily.  
28
29
A key error will look something like this:
30
31
W: GPG error: http://extras.ubuntu.com quantal Release: The following signatures couldn't be verified because the public key is not available: NO_PUBKEY 16126D3A3E5C1192
32
33
>gpg --keyserver hkp://subkeys.pgp.net --recv-keys 16126D3A3E5C1192
34
>gpg --export --armor 16126D3A3E5C1192 | sudo apt-key add - 
35
36
Note that the key (16126D3A3E5C1192) is the same in the error message, the key fetch request and the key import request.  What ever key you are missing can be fixed by through this process.  
37
38
39
>apt-get update && apt-get dist-upgrade
40
41
h2. Have your web server and data base installed
42
43
Installing Ubuntu's entire LAMP stack also installs PHP as well as the PHP connectors for apache, mysql, etc. If you are using RoR, installing all of that is probably unnecessary.  As a general rule of practice, it is best not to install anything you don't actually need.  That which isn't installed is not a potential security hole.  The statements below will install apache2 and the proper database.  
44
45 52 Recent Coin
For MySQL: >apt-get install apache2 software-properties-common librmagick-ruby ruby-rmagick mysql-server mysql-client mysql-common 
46
For PostgreSQL:   >apt-get install apache2 software-properties-common librmagick-ruby ruby-rmagick postgresql
47 43 Recent Coin
48
49 44 Recent Coin
If you want to use another web server or data base, that is outside the scope of this document.
50 43 Recent Coin
51
h2. You must install mod_passenger for Apache2. 
52
> apt-get install libapache2-mod-passenger
53
54
Wait for the install to complete then you must enable the module and restart Apache2.
55
56
>a2enmod passenger
57
>service apache2 restart
58
 - OR -
59
>/etc/init.d/apache2 restart
60
61
Mod_passenger should now be enabled and visible to apache.
62
63
h2.Turn off apparmor for a bit so that it doesn't complain while we're installing everything
64
65
> service apparmor stop
66
 - OR -
67
>/etc/init.d/apparmor stop
68
69 44 Recent Coin
You can restart it once everything has been configured.
70 1 Umit Uzun
71 44 Recent Coin
h2. Create your data base and your user for your redmine installation.
72 1 Umit Uzun
73 44 Recent Coin
There are a great many GUI's out there for most databases.  It is strongly recommended never to run your application as your "root" user on your database (e.g. MySQL root for MySQL or 'postgres' user for PostgreSQL).  There are also any number of tutorials on the creation of databases and granting of rights on them, so that it is really outside the scope of this document. These are pretty trivial to find on Google and if you are going to administer database driven applications its very advisable for you to become at least passingly familiar with SQL statements.
74
75
For MySQL:  CREATE 'user'@'hostname' IDENTIFIED BY 'password';  CREATE DATABASE 'myredminedb'; GRANT ALL ON 'myredminedb'.* TO 'user'@'hostname'; FLUSH PRIVILEGES;
76
77
For PostgreSQL: CREATE USER user WITH PASSWORD 'password'; CREATE DATABASE myredminedb;GRANT ALL PRIVILEGES ON DATABASE myredminedb to user;
78
79 46 Recent Coin
NOTE for PostgreSQL Users:  You will have to set the postgres user password before you can connect remotely.  MySQL will force you to set this during the installation but Postgres does not. To so do:
80
81
>su - postgres
82
>psql
83
84
This will take you to the postgres database prompt.  
85
86
>ALTER USER postgres with password 'my-secure-password';
87
88
This will set the password.  You can now proceed to editing the postgres configuration files so that you can connect remotely.
89
90 44 Recent Coin
h2. Install Redmine.
91
92 43 Recent Coin
---If you are happy with the packaged version, the you can use the packages from the Ubuntu repository.   The Ubuntu 10.04 package is stuck in the 0.9.x branch and the Ubuntu 12.04 package is stuck in the 1.3.x branch.
93
94
For MySQL: >apt-get install redmine redmine-mysql
95 47 Recent Coin
For PostgreSQL: >apt-get install redmine redmine-pgsql
96 49 Recent Coin
For SQLite: 
97 43 Recent Coin
98 1 Umit Uzun
99 49 Recent Coin
The PostgreSQL installation will ask for the postgres user password so that it can create its own user, password, database, etc.  
100
101 36 Anonymous
102
The installation process should prompt you for all the interesting details.
103
104 45 Recent Coin
Redmine will now be installed in @/usr/share/redmine@ and the configuration files will be located in @/etc/redmine@
105 36 Anonymous
106
h2. Installing the latest Redmine
107 53 Recent Coin
108 51 Recent Coin
--If you are not happy with the older versions of Redmine that are in the official Ubuntu repositories (10.04 is stuck 0.9.x and 12.04 is stuck at 1.3.x while the current version is 2.2), this section is for you.  You still need to follow the steps in the other sections but this will get you the newer versions from the PPA/Launchpad here: https://launchpad.net/~ondrej/+archive/redmine
109 1 Umit Uzun
110 51 Recent Coin
*NOTE:* If your server is behind a firewall, you will need to export your firewall settings before running add-apt-repository. Otherwise, the command will hang.
111 1 Umit Uzun
112 51 Recent Coin
Run the following commands to export your proxy settings for both http (port 80) and https (port 443):
113
>export http_proxy="http://proxy.your.server:port" 
114
>export https_proxy="http:proxy.your.server:port"
115 1 Umit Uzun
116
117 51 Recent Coin
Otherwise, proceed to add the PPA to the list of repositories for your machine:
118
119
>add-apt-repository ppa:ondrej/redmine
120
>apt-get update
121
122
123
For MySQL: >apt-get install redmine redmine-mysql
124
For PostgreSQL: apt-get install redmine redmine-pgsql
125 36 Anonymous
126 55 Recent Coin
If you cannot use the PPA, as there is currently not a PPA for anything other than Precise Pangolin, you will need to use the "long method".
127
128
Move into your home directory
129
130
>wget http://rubyforge.org/frs/download.php/76722/redmine-2.2.2.tar.gz
131
132
Wait for the file to finish downloading.  
133
134
>tar -zxvf redmine-2.2.2.tar.gz
135
136 54 Recent Coin
h2. Apache Configuration
137 1 Umit Uzun
138 54 Recent Coin
You have two choices.  You can install Redmine as a dedicate server or you can install Redmine for use as a directory on another server.
139
140
h3. *Dedicated Server Configuration*
141
>cd /etc/apache2/sites-available
142
143
edit default with your choice of editor. 
144
ServerAdministrator youremail@email.com
145
ServerName mydomain.com
146
147
Directly under this directive is 
148
<pre>
149
DocumentRoot /var/www
150
        <Directory />
151
                Options FollowSymLinks
152
                AllowOverride None
153
        </Directory>
154
</pre>
155
156
 
157
Change this to
158
<pre>
159
DocumentRoot /var/www
160
        <Directory />
161
                Options FollowSymLinks
162
                RailsBaseURI /
163
                PassengerResolveSymlinksinDocumentRoot on
164
                AllowOverride None
165
        </Directory>
166
</pre>
167
168 56 Recent Coin
> cd /etc/apache2/conf.d
169
170
edit security
171
Change ServerTokens OS to read ServerTokens Prod
172
Save the file
173
174
>cd /var
175
>mv www ww2
176
>ln -s /usr/share/redmine/public www
177
>service apache2 restart
178
179
Go browse your server.  You should be able to log in with the default user of "admin" and the default password of "admin".  
180
Change the user name and password immediately.
181
182 54 Recent Coin
183
184
185
h3. *Shared Server Configuration*
186 36 Anonymous
Symlink @/usr/share/redmine/public@ to your desired web-accessible location. E.g.:
187
188
> $ sudo ln -s /usr/share/redmine/public /var/www/redmine
189
190
By default, passenger runs as 'nobody', so you'll need to fix that. In @/etc/apache2/mods-available/passenger.conf@, add:
191 38 Yu Kobayashi
192 36 Anonymous
<pre>PassengerDefaultUser www-data</pre>
193
194
You'll also need to configure the @/var/www/redmine@ location in @/etc/apache2/sites-available/default@ by adding:
195
196
<pre><Directory /var/www/redmine>
197
RailsBaseURI /redmine
198
PassengerResolveSymlinksInDocumentRoot on
199
</Directory>
200
</pre>
201
202
If you set your AppArmor mysqld profile to complain you ought to set it back to enforce:
203
204
> $ sudo aa-enforce /usr/sbin/mysqld
205
206
Enable passenger:
207
208
> $ sudo a2enmod passenger
209
210
Restart apache2
211
212
> $ sudo service apache2 restart
213
214
and you should be able to access Redmine at: http://redmine.server.ip.address/redmine
215
216
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.
217
218
> $ sudo chmod a+x /usr/share/redmine/public
219
220
h1. Ubuntu 10.04 or 12.04 using WEBrick
221
222
Using Passenger is recommended for the heavy load server. But WEBrick uses less memory.
223 39 Yu Kobayashi
224 38 Yu Kobayashi
Install Redmine: (See also _Installing the latest Redmine_ above)
225
226 36 Anonymous
> $ sudo apt-get install redmine redmine-mysql
227
228
Then, create this for /etc/init/redmine.conf
229
230
<pre>
231
# Redmine
232
233
description "Redmine"
234
235
start on runlevel [2345]
236
stop on runlevel [!2345]
237
238
expect daemon
239
exec ruby /usr/share/redmine/script/server webrick -e production -b 0.0.0.0 -d
240
</pre>
241
242
You can start Redmine by this. You can access by http://example.com:3000/
243
244
> $ sudo service redmine start
245
246
You can stop by this.
247
248
> $ sudo service redmine stop
249
250
h1. Ubuntu 10.04 using mod_cgi
251
252
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:
253
254
> $ sudo tasksel install lamp-server
255
256
Also, the default AppArmor configuration can get in the way, so you may need to set the mysqld profile to complain:
257
258
> $ sudo aa-complain /usr/sbin/mysqld
259
260
As of 10.04, Redmine is available through Ubuntu's package manager, and installation is simple:
261
262
> $ sudo apt-get install redmine redmine-mysql subversion
263
264
The second package, _redmine-mysql_, can be replaced by either _redmine-pgsql_ or _redmine-sqlite_ if you want to use either of those databases.
265
266
The installation process should prompt you for all the interesting details.
267
268
Redmine will now be installed in @/usr/share/redmine@ and @/etc/redmine@
269
270
If you set your AppArmor mysqld profile to complain you ought to set it back to enforce:
271
272
> $ sudo aa-enforce /usr/sbin/mysqld
273
274
h2. Configuration
275
276
> *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 or WEBrick if mod_cgi does not work for you.*
277
278
Symlink @/usr/share/redmine/public@ to your desired web-accessible location. E.g.:
279
280
> $ sudo ln -s /usr/share/redmine/public /var/www/redmine
281 42 Roland Giesler
282
Also symlink @/var/cache/redmine/default/plugin_assets@ to your redmine directory. E.g.:
283
284
> $ sudo ln -s /var/cache/redmine/default/plugin_assets /usr/share/redmine/public/
285
286
This will ensure that any graphics or other resources are displayed in any installed add-ons.
287 36 Anonymous
288
The other files that you need to modify/create are as follows:
289
290
@/etc/redmine/default/database.yml@:
291
292
<pre>
293
production:
294
adapter: mysql
295
database: redmine
296
host: localhost
297
username: redmine
298
password: pa55w0rd
299
encoding: utf8
300
</pre>
301
302
@/usr/share/redmine/public/dispatch.cgi@:
303
304
<pre>
305
#!/usr/bin/ruby
306
307
require File.dirname(__FILE__) + "/../config/environment" unless defined?(RAILS_ROOT)
308
309
require "dispatcher"
310
311
ADDITIONAL_LOAD_PATHS.reverse.each { |dir| $:.unshift(dir) if File.directory?(dir) } if defined?(Apache::RubyRun)
312
Dispatcher.dispatch
313
</pre>
314
315
@/usr/share/redmine/public/.htaccess@:
316
317
<pre>
318
RewriteEngine On
319
RewriteBase /redmine
320
RewriteRule ^$ index.html [QSA]
321
RewriteRule ^([^.]+)$ $1.html [QSA]
322
RewriteCond %{REQUEST_FILENAME} !-f
323
RewriteRule ^(.*)$ dispatch.cgi [QSA,L]
324
</pre>
325
326
And that's it! If these instructions didn't work for you, please expand them to include whatever is needed.
327
328
h1. Redmine Installation on Virtual or Normal Ubuntu < 10.04
329
330
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.
331
332
h2. Step 1: Install Ubuntu
333
334
If you are installing on a non-virtual Ubuntu instance, please skip this section.
335
336
*Installing VirtualBox:*
337
338
1.Download the latest version of Sun VirtualBox (version 3.0.10 or newer).
339
2.Install VirtualBox by following the instructions.
340
341
*Installing Ubuntu on VirtualBox:*
342
343
1.Download the latest version of Ubuntu (version 9.10 or newer).
344
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.
345
346
3.While installing Ubuntu you should enter the following configuration:
347
(This suggested configuration is optional, you can enter any names you want.)
348
Q: What is your name? A: Redmine Server
349
Q: What name do you want to use to login? A: redmine
350
Q: Choose to password to keep your account safe? A: redmine
351
Q: What is the name of this computer? A: redmine-server
352
Choose “Log in automatically.” radio button.
353
354
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:
355
> sudo apt-get update
356
> sudo apt-get upgrade
357
358
*Configuring VirtualBox:*
359
360
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.
361
362
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.
363
364
h2. Step 2: Install Redmine
365
366
Once you have a functioning Ubuntu operating system up and running, you can continue with installing Redmine.
367
368
h3. Install dependencies
369
370
The following packages are required to install and run Redmine. Please install them by running @apt-get@ as root:
371
372
>sudo apt-get install package-name
373
374
where @package-name@ is each of:
375
* apache2
376
* apache2-threaded-dev
377
* build-essential
378
* libapache-dbi-perl
379
* libapache2-mod-perl2
380
* libapache2-svn
381
* libdigest-sha1-perl
382
* libgemplugin-ruby
383
* libgemplugin-ruby1.8
384
* libruby-extras
385
* libruby1.8-extras
386
* mongrel
387
* mysql-server
388
* rails
389
* rake
390
* ruby
391
* rubygems
392
* rubygems1.8
393
* ruby1.8-dev
394
* subversion
395
396
_(Could someone please clean up this list?)_
397
398
h3. Package Installation and Setup
399
400
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:
401
> sudo apt-get install
402
> sudo apt-get install
403
(_Surely some missing package names above?_)
404
405
The packages we’re installing above are MySQL, phpMyAdmin, Rails, Ruby Gems, Mongrel and Ruby Dev environment.
406
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”.
407
408
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:
409
> sudo mkdir /opt/redmine
410
> sudo cd /opt/redmine
411
> sudo wget http://rubyforge.org/frs/download.php/66633/redmine-0.8.6.tar.gz
412
> tar -xvf redmine-0.8.6.tar.gz
413
414
h3. Database Setup
415
416
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.
417
Type in “root” and the MySQL “password” you created when installing MySQL.
418
419
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”.
420
421
3.Now, go back to the home screen and click on:
422
“Privileges”
423
“Add a new User”
424
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.
425
In the “Database for user” section, check “Create database with same name and grant all privileges” and click on the “Go” button.
426
427
4.Log out of phpMyAdmin.
428
429
h3. Redmine Database Connection Configuration
430
431
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:
432
> sudo cd /opt/redmine/redmine-0.8.6/config
433
434
2.So now, assuming you’re in the “/opt/redmine/redmine-0.8.6/config” directory, issue:
435
> sudo cp database.yml.example database.yml
436
437
3.Then, open the “database.yml” file, issue:
438
> sudo gedit database.yml
439
… and edit it as in the example for a MySQL database below:
440
441
production:
442
adapter: mysql
443
socket: /var/run/mysqld/mysqld.sock
444
database: redmine
445
host: localhost
446
username: redmine
447
password: [password]
448
449
Then save the “database.yml” file and exit to the command prompt.
450
On Ubuntu the “mysql.sock” is located in /var/run/mysqld/mysqld.sock, as noted in the “config” above.
451
(The standard Redmine installation assumes the socket is located in “/opt/redmine/redmine-0.8.6/tmp/mysqld.sock”.)
452
453
4.Create the database structure, by running the following command under the application root directory (I mean “/opt/redmine/redmine-0.8.6”):
454
> sudo rake db:migrate RAILS_ENV="production"
455
It will create the necessary tables in the redmine database you created earlier and an administrator account.
456
457
5.Insert the default configuration data in to the database, by issuing:
458
> sudo rake redmine:load_default_data RAILS_ENV="production"
459
(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.)
460
461
h3. Setting up Permissions
462
463
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:
464
> sudo mkdir /opt/redmine/redmine-0.8.6
465
466
2.If you haven’t created a Redmine user, do it now by issuing:
467
> sudo useradd redmine
468
469
3.Now, assuming you run Redmine with a redmine user, from your /opt/redmine/redmine-0.8.6 directory issue:
470
> sudo chown -R redmine:redmine files log tmp
471
> sudo chmod -R 755 files log tmp
472
473
h3. Testing the Installation
474
475
1.It should all be working now. Test the installation by running the WEBrick web server issue:
476
> sudo cd /opt/redmine/redmine-0.8.6
477
> sudo ruby script/server -e production
478
479
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.
480
481
*Log in:*
482
483
1.Use default administrator account to log in:
484
Login : admin
485
Password : admin
486
487
2.You can go to Admin & Settings to modify application settings.
488
489
h3. Setting Up Static IP
490
491
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.
492
493
2.Or you should determine the configuration parameters given below, and then you can configure your system to have a static IP address:
494
The desired IP address
495
Network mask and broadcast address
496
Gateway address
497
Your local DNS server address(es)
498
499
h3. Assigning Host Name and Domain for VirtualBox OS
500
501
1.An easier method for adding your IP address - Host name pair configuration to your DNS server . Consult your network administrator.
502
503
h2. Configuring the Passenger Apache module
504
505
Passenger is a module for apache2 that allows Apache to run Ruby on Rails applications. Install it thus:
506
507
>$ sudo gem install passenger
508
509
Then go to the passenger apache2 module installation directory and run @passenger-install-apache2-module@
510
511
> $ cd /var/lib/gems/1.X/gems/passenger-X.X.X/
512
513
> $ sudo bin/passenger-install-apache2-module
514
515
Next, configure Apache:
516
517
In /etc/apache2/mods-available/passenger.load we will add next line
518
519
> LoadModule passenger_module /var/lib/gems/1.X/gems/passenger-X.X.X/ext/apache2/mod_passenger.so
520
521
We have to edit the conf of the passenger apache2 module in /etc/apache2/mods-available/passenger.conf
522
523
> PassengerRoot /var/lib/gems/1.X/gems/passenger-X.X.X
524
> PassengerRuby /usr/bin/ruby1.X
525
526
And now we activate the module
527
528
> $ sudo a2enmod passenger
529
530
Apache virtualhost for redmine web app
531
532
<pre>
533
<VirtualHost *:80>
534
ServerName redmine.server.com
535
536
DocumentRoot /var/www/redmine/public
537
538
ServerAdmin user@server.com
539
LogLevel warn
540
ErrorLog /var/log/apache2/redmine_error
541
CustomLog /var/log/apache2/redmine_access combined
542
543
<Directory /var/www/redmine/public>
544
Options Indexes FollowSymLinks MultiViews
545
AllowOverride None
546
Order allow,deny
547
allow from all
548
</Directory>
549
</VirtualHost>
550
</pre>
551
552
subversion server config in apache
553
554
<pre>
555
<VirtualHost *:80>
556
ServerName svn.server.com
557
ServerAdmin user@server.com
558
ErrorLog /var/log/apache2/svn_error
559
CustomLog /var/log/apache2/svn_access combined
560
<Location /project>
561
DAV svn
562
SVNPath /var/lib/svn/project
563
564
AuthType Basic
565
AuthName "Trac system for Server projects"
566
AuthUserFile "/var/lib/svn/.htpasswd"
567
Require valid-user
568
<LimitExcept GET PROPFIND OPTIONS REPORT>
569
Require valid-user
570
</LimitExcept>
571
</Location>
572
</Virtualhost>
573
</pre>
574
575
h2. Sendmail Server Configuration
576
577
1.Before configuring email support for Redmine, we should download the sendmail application for Ubuntu, issue:
578
579
> sudo apt-get install sendmail
580
581
> sudo sendmailconfig
582
583
(Answer Yes to all questions which you will be asked)
584
585
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:
586
> sudo cd /opt/redmine/redmine-0.8.6/config
587 37 João Lencart e Silva
588
589 36 Anonymous
590
3.So now, assuming you’re in the “/config” directory, issue:
591
> sudo cp email.yml.example email.yml
592
593
4.Then, open the “email.yml” file, issue:
594
> sudo gedit email.yml
595
… and edit it as in the example for sendmail configuration below:
596
597
production:
598
delivery_method: :sendmail
599
sendmail_settings:
600
location: /usr/sbin/sendmail
601
arguments: -i -t
602
address: smtp.example.net
603
port: 25
604
domain: example.net
605
authentication: :none
606
user_name: redmine@example.net
607
password: redmine
608
609
Then save “email.yml” file and exit to the command prompt.
610
611 37 João Lencart e Silva
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”.
612
613
h2. Email configuration for Ubuntu 12.04 with redmine >v1.4.3
614
615
1. Instead of creating an email.yml, edit config/configuration.yml and add a section
616
<pre>
617
production:
618
   email_delivery:
619
     delivery_method: :smtp
620
...</pre>
621
622
or
623
624
<pre>production:
625
   email_delivery:
626
     delivery_method: :sendmail
627
...</pre>
628
629
Please see http://www.redmine.org/projects/redmine/wiki/EmailConfiguration for the correct format of the full email block.
630
631
2. **DO NOT CHANGE** environment.rb config.action_mailer.perform_deliveries. The correct way is changing configuration.yml and leaving the default config.action_mailer.perform_deliveries setting to false:
632
@config.action_mailer.perform_deliveries = false@
633
634
635
636 36 Anonymous
637
638
h2. Subversion Installation and Configuration
639
640
1.Before configuring Subversion support for Redmine, we should download the Subversion application for Ubuntu, issue:
641
> sudo apt-get install subversion
642
643
2.If your Redmine can't find the “subversion” command you can help to find by issuing:
644
· > sudo cd /opt/redmine/redmine-0.8.6/config
645
· > sudo gedit environment.rb
646
· Add ENV['PATH'] = "#{ENV['PATH']}:/subversion/path" line in it.
647
· Save and close the “environment.rb”
648
649
h2. Start Application at Boot Time
650
651
1.To automatically start the application on booting your server you need to modify your “crontab”, issue:
652
> export EDITOR=gedit
653
> crontab -e
654
655
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):
656
@reboot cd /opt/redmine/redmine-0.8.6 ; rm -f log/mongrel.pid ; mongrel_rails start -e production -p 3000 -d
657
658
h2. Backup
659
660
1.Running backups is always a good idea. Redmine backups should include:
661
* data (stored in your redmine database)
662
/usr/bin/mysqldump -u -p | gzip > /path/to/redmine/backup/db/redmine_`date +%y_%m_%d`.gz
663
* attachments (stored in the files directory of your Redmine install)
664
rsync -a /path/to/redmine/files /path/to/redmine/backup/files
665
666
2.Or you can use the bash shell to automate this kind of operation, issue:
667
> sudo cd /opt/redmine/redmine-0.8.6
668
> sudo mkdir backup
669
> sudo mkdir backup/db
670
> sudo mkdir backup/files
671
> sudo gedit backup/runRedmineBackup.bash
672
673
And after open “runRedmineBackup.bash” with gedit, write all commands below:
674
<pre>
675
#!/bin/bash
676
data=`date -I`
677
mysqldump --user=root --password="redmine" --all-databases | gzip > db/backup-$data.sql.gz
678
cd db
679
ftp -i -n << EOF
680
open ftpserver.example.net
681
user username password
682
bin
683
mput backup-$data.sql.gz
684
bye
685
EOF
686
</pre>
687
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:
688
689
> export EDITOR=gedit
690
> crontab -e
691
Add 0 0 * * 0 cd /opt/redmine/redmine-0.8.6/backup ; sh runRedmineBackup.bash commands to crontab to backup database weekly.
692
693
For this to work without any permission problems you have to change the permissions of the files to maximum, issue:
694
695
> sudo chmod -R 777 backup
696
> sudo chown -R redmine:redmine backup
697
698
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..!
699
700
h2. Sources & contributors.
701
702
* Ümit Uzun 06/11/2009.
703
* 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.
704
* Sam Wilson 2010-05-26, formatting changes.
705
* 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.*+
706
707
h2. Additional Sources
708 40 Mohd Shakir Zakaria
709 1 Umit Uzun
* http://docs.oseems.com/general/web/redmine/install-in-ubuntu