HowTo Install Redmine in Ubuntu » History » Version 4

Sam Wilson, 2010-05-31 07:57

1 3 Sam Wilson
h1. Ubuntu 10.4 LTS
2 3 Sam Wilson
3 3 Sam Wilson
As of 10.4, Redmine is available through Ubuntu's package manager, and installation is simple:
4 3 Sam Wilson
5 3 Sam Wilson
> $ sudo apt-get install redmine redmine-mysql
6 3 Sam Wilson
7 3 Sam Wilson
The second package, _redmine-mysql_, can be replaced by either _redmine-pgsql_ or _redmine-sqlite_ if you want to use either of those databases.
8 3 Sam Wilson
9 3 Sam Wilson
Redmine will now be installed in @/usr/share/redmine@ and @/etc/redmine@
10 3 Sam Wilson
11 3 Sam Wilson
h2. Configuration
12 3 Sam Wilson
13 3 Sam Wilson
Symlink @/usr/share/redmine/public@ to your desired web-accessible location.  E.g.:
14 3 Sam Wilson
15 3 Sam Wilson
> $ ln /usr/share/redmine/public /var/www/redmine
16 3 Sam Wilson
17 3 Sam Wilson
The other files that you need to modify/create are as follows:
18 3 Sam Wilson
19 3 Sam Wilson
@/etc/redmine/database.yml@:
20 3 Sam Wilson
21 3 Sam Wilson
<pre>
22 3 Sam Wilson
production:
23 3 Sam Wilson
  adapter: mysql
24 3 Sam Wilson
  database: redmine
25 3 Sam Wilson
  host: localhost
26 3 Sam Wilson
  username: redmine
27 3 Sam Wilson
  password: pa55w0rd
28 3 Sam Wilson
  encoding: utf8
29 3 Sam Wilson
</pre>
30 3 Sam Wilson
31 3 Sam Wilson
@/user/share/redmine/public/dispatch.cgi@:
32 3 Sam Wilson
33 3 Sam Wilson
<pre>
34 3 Sam Wilson
#!/usr/bin/ruby
35 3 Sam Wilson
36 3 Sam Wilson
require File.dirname(__FILE__) + "/../config/environment" unless defined?(RAILS_ROOT)
37 3 Sam Wilson
38 3 Sam Wilson
require "dispatcher"
39 3 Sam Wilson
40 3 Sam Wilson
ADDITIONAL_LOAD_PATHS.reverse.each { |dir| $:.unshift(dir) if File.directory?(dir) } if defined?(Apache::RubyRun)
41 3 Sam Wilson
Dispatcher.dispatch
42 3 Sam Wilson
</pre>
43 3 Sam Wilson
44 4 Sam Wilson
@/usr/share/redmine/public/.htaccess@:
45 3 Sam Wilson
46 3 Sam Wilson
<pre>
47 3 Sam Wilson
RewriteEngine On
48 3 Sam Wilson
RewriteBase /redmine
49 3 Sam Wilson
RewriteRule ^$ index.html [QSA]
50 3 Sam Wilson
RewriteRule ^([^.]+)$ $1.html [QSA]
51 3 Sam Wilson
RewriteCond %{REQUEST_FILENAME} !-f
52 3 Sam Wilson
RewriteRule ^(.*)$ dispatch.cgi [QSA,L]
53 3 Sam Wilson
</pre>
54 3 Sam Wilson
55 3 Sam Wilson
And that's it!  If these instructions didn't work for you, please expand them to include whatever is needed.
56 3 Sam Wilson
57 3 Sam Wilson
h1. Redmine Installation on Virtual or Normal Ubuntu < 10.4
58 1 Umit Uzun
59 2 Sam Wilson
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 be installed your Redmine server successfully almost an hour.
60 1 Umit Uzun
61 2 Sam Wilson
h2. Step 1: Install Ubuntu
62 1 Umit Uzun
63 2 Sam Wilson
If you are installing on a non-virtual Ubuntu instance, please skip this section.
64 1 Umit Uzun
65 2 Sam Wilson
*Installing VirtualBox:*
66 2 Sam Wilson
67 2 Sam Wilson
1.Download last version of Sun VirtualBox (version 3.0.10 or newer) tool in your system.
68 1 Umit Uzun
2.Install to your system by following the instructions.
69 1 Umit Uzun
70 1 Umit Uzun
*Installing Ubuntu on VirtualBox:*
71 1 Umit Uzun
72 1 Umit Uzun
1.Download last version of Ubuntu(version 9.10 or newer) OS in your system.
73 1 Umit Uzun
2.After installed VirtualBox on your system 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 the google.
74 1 Umit Uzun
75 1 Umit Uzun
3.While installing Ubuntu you should type the related configurations as follows:
76 1 Umit Uzun
(These all configurations are optional, you can give any name what you what.)
77 1 Umit Uzun
Q: What is your name? A: Redmine Server
78 1 Umit Uzun
Q: What name do you want to use to login? A: redmine
79 1 Umit Uzun
Q: Choose to password to keep your account safe? A: redmine
80 1 Umit Uzun
Q: What is the name of this computer? A: redmine-server
81 1 Umit Uzun
Choose “Log in automatically.” radio button.
82 1 Umit Uzun
83 1 Umit Uzun
4.When you finished up installation all of them open up your new VirtualBox Ubuntu OS and open up terminal(console) screen and  issuing these commands:
84 1 Umit Uzun
> sudo apt-get update
85 1 Umit Uzun
> sudo apt-get upgrade
86 1 Umit Uzun
87 1 Umit Uzun
*Configuring VirtualBox:*
88 1 Umit Uzun
89 1 Umit Uzun
1.If you want to reach your VirtualBox Ubuntu OS from different machine, you have to configure VirtualBox Ubuntu OS's network setting to Bridged Adapter. So you can reach your VirtualBox Ubuntu from internal IP address easily. Because it get's same IP block as you from DHCP easily. I mean your guest and host computer is same IP block as different network client.
90 1 Umit Uzun
91 1 Umit Uzun
2.If you had assigned a static IP to your Network Consult by giving your static ethernet MAC address, you have to assign unique MAC address your VirtualBox Ubuntu OS by Setting->Network->MAC address initialization box. By this MAC address, you can get static ip easily or you can configure your Ubuntu system to not use DHCP, instead of that you can assign static IP manually.
92 1 Umit Uzun
93 2 Sam Wilson
h2. Step 2: Install Redmine
94 1 Umit Uzun
95 2 Sam Wilson
Once you have a functioning Ubuntu operating system up and running, you can continue with installing Redmine.
96 1 Umit Uzun
97 2 Sam Wilson
h3. Install dependencies
98 2 Sam Wilson
99 2 Sam Wilson
The following packages are required to install and run Redmine.  Please install them by running @apt-get@ as root:
100 2 Sam Wilson
101 2 Sam Wilson
>sudo apt-get package-name
102 2 Sam Wilson
103 2 Sam Wilson
where @package-name@ is each of:
104 2 Sam Wilson
* apache2 
105 2 Sam Wilson
* apache2-threaded-dev 
106 2 Sam Wilson
* build-essential
107 2 Sam Wilson
* libapache-dbi-perl 
108 2 Sam Wilson
* libapache2-mod-perl2 
109 2 Sam Wilson
* libapache2-svn
110 2 Sam Wilson
* libdigest-sha1-perl 
111 2 Sam Wilson
* libgemplugin-ruby 
112 2 Sam Wilson
* libgemplugin-ruby1.8 
113 2 Sam Wilson
* libruby-extras 
114 2 Sam Wilson
* libruby1.8-extras 
115 2 Sam Wilson
* mongrel 
116 2 Sam Wilson
* mysql-server
117 2 Sam Wilson
* rails
118 2 Sam Wilson
* rake 
119 2 Sam Wilson
* ruby
120 2 Sam Wilson
* rubygems
121 2 Sam Wilson
* rubygems1.8
122 2 Sam Wilson
* ruby1.8-dev
123 2 Sam Wilson
* subversion
124 2 Sam Wilson
125 2 Sam Wilson
_(Could someone please clean up this list?)_
126 2 Sam Wilson
127 1 Umit Uzun
*Package Installation and Setup:*
128 1 Umit Uzun
129 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: 
130 2 Sam Wilson
> sudo apt-get install 
131 2 Sam Wilson
> sudo apt-get install 
132 1 Umit Uzun
133 1 Umit Uzun
The packages we’re installing above are MySQL, phpMyAdmin, Rails, Ruby Gems, Mongrel and Ruby Dev environment.
134 1 Umit Uzun
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 the 	phpMyAdmin. To make simplicity you can set all passwords to “redmine”.
135 1 Umit Uzun
136 1 Umit Uzun
2.Create a new directory for Redmine. I put mine in /opt/redmine. And download last version of Redmine in it with wget command line downloader and extract it by issuing:
137 1 Umit Uzun
> sudo mkdir /opt/redmine
138 1 Umit Uzun
> sudo cd /opt/redmine
139 1 Umit Uzun
> sudo wget http://rubyforge.org/frs/download.php/66633/redmine-0.8.6.tar.gz
140 1 Umit Uzun
> tar -xvf redmine-0.8.6.tar.gz
141 1 Umit Uzun
142 1 Umit Uzun
*Database Setup:*
143 1 Umit Uzun
144 1 Umit Uzun
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.
145 1 Umit Uzun
Type in “root” and the MySQL “password” you created when installing MySQL.
146 1 Umit Uzun
147 1 Umit Uzun
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”.
148 1 Umit Uzun
149 1 Umit Uzun
3.Now, go back to the home screen and click on:
150 1 Umit Uzun
“Privileges”
151 1 Umit Uzun
“Add a new User” 
152 1 Umit Uzun
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.
153 1 Umit Uzun
In the “Database for user” section, check “Create database with same name and grant all privileges” and click on the “Go” button.
154 1 Umit Uzun
155 1 Umit Uzun
4.Log out of phpMyAdmin.
156 1 Umit Uzun
157 1 Umit Uzun
*Redmine Database Connection Configuration:*
158 1 Umit Uzun
159 1 Umit Uzun
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:
160 1 Umit Uzun
> sudo cd /opt/redmine/redmine-0.8.6/config
161 1 Umit Uzun
162 1 Umit Uzun
2.So now, assuming you’re in the “/opt/redmine/redmine-0.8.6/config” directory, issue:
163 1 Umit Uzun
> sudo cp database.yml.example database.yml 
164 1 Umit Uzun
165 1 Umit Uzun
3.Then, open the “database.yml” file, issue:
166 1 Umit Uzun
> sudo gedit database.yml
167 1 Umit Uzun
… and edit it as in the example for a MySQL database below:
168 1 Umit Uzun
169 1 Umit Uzun
production:
170 1 Umit Uzun
adapter: mysql
171 1 Umit Uzun
socket: /var/run/mysqld/mysqld.sock
172 1 Umit Uzun
database: redmine
173 1 Umit Uzun
host: localhost
174 1 Umit Uzun
username: redmine
175 1 Umit Uzun
password: [password]
176 1 Umit Uzun
177 1 Umit Uzun
Then save “database.yml” file and exit to the command prompt.
178 1 Umit Uzun
On Ubuntu the “mysql.sock” is located in /var/run/mysqld/mysqld.sock, as noted in the “config” above. 
179 1 Umit Uzun
(The standard Redmine installation assumes the socket is located in “/opt/redmine/redmine-0.8.6/tmp/mysqld.sock”.)
180 1 Umit Uzun
181 1 Umit Uzun
4.Create the database structure, by running the following command under the application root directory(I mean “/opt/redmine/redmine-0.8.6”):
182 1 Umit Uzun
> sudo rake db:migrate RAILS_ENV="production" 
183 1 Umit Uzun
It will create the necessary tables in the redmine database you created earlier and an 	administrator account.
184 1 Umit Uzun
185 1 Umit Uzun
5.Insert default configuration data in database, by issuing:
186 1 Umit Uzun
> sudo rake redmine:load_default_data RAILS_ENV="production" 
187 1 Umit Uzun
(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.) 
188 1 Umit Uzun
189 1 Umit Uzun
*Setting up Permissions:*
190 1 Umit Uzun
191 1 Umit Uzun
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:
192 1 Umit Uzun
> sudo mkdir /opt/redmine/redmine-0.8.6
193 1 Umit Uzun
194 1 Umit Uzun
2.If you haven’t created a Redmine user, do it now by issuing:
195 1 Umit Uzun
> sudo useradd redmine
196 1 Umit Uzun
197 1 Umit Uzun
3.Now, assuming you run Redmine with a redmine user, from your /opt/redmine/redmine-0.8.6 directory issue:
198 1 Umit Uzun
> sudo chown -R redmine:redmine files log tmp
199 1 Umit Uzun
> sudo chmod -R 755 files log tmp
200 1 Umit Uzun
201 1 Umit Uzun
*Testing the Installation:*
202 1 Umit Uzun
203 1 Umit Uzun
1.It should all be working now. Test the installation by running the WEBrick web server issue:
204 1 Umit Uzun
> sudo cd /opt/redmine/redmine-0.8.6
205 1 Umit Uzun
> sudo ruby script/server -e production
206 1 Umit Uzun
	
207 1 Umit Uzun
Once WEBrick has started, point your browser to http://localhost:3000/. Or, if you are using a browser on another computer than what 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. 
208 1 Umit Uzun
209 1 Umit Uzun
*Log in:*
210 1 Umit Uzun
211 1 Umit Uzun
1.Use default administrator account to log in:
212 1 Umit Uzun
Login : admin
213 1 Umit Uzun
Password : admin
214 1 Umit Uzun
215 1 Umit Uzun
2.You can go to Admin & Settings to modify application settings.
216 1 Umit Uzun
217 1 Umit Uzun
*Setting Up Static IP:*
218 1 Umit Uzun
219 1 Umit Uzun
1.A more easy 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. 
220 1 Umit Uzun
221 1 Umit Uzun
2.Or you should learn configuration parameters as given below, and can configure your system to get static IP address:
222 1 Umit Uzun
The desired IP address
223 1 Umit Uzun
Network mask and broadcast address
224 1 Umit Uzun
Gateway address
225 1 Umit Uzun
Your local DNS server address(es)
226 1 Umit Uzun
227 1 Umit Uzun
*Assigning Host Name and Domain for VirtualBox OS:*
228 1 Umit Uzun
229 1 Umit Uzun
1.A more easy method for adding your IP address - Host name pair configurations to your DNS server . Consult your network administrator.
230 1 Umit Uzun
231 2 Sam Wilson
h2. Configuring the Passenger Apache module
232 1 Umit Uzun
233 2 Sam Wilson
Passenger is a module for apache2 that allow apache to run ruby on rails applications.  Install it thus:
234 2 Sam Wilson
235 2 Sam Wilson
>$ sudo gem install passenger
236 2 Sam Wilson
237 2 Sam Wilson
Then go to the passenger apache2 module installation directory and run @passenger-install-apache2-module@
238 2 Sam Wilson
239 2 Sam Wilson
> $ cd /var/lib/gems/1.X/gems/passenger-X.X.X/
240 2 Sam Wilson
241 2 Sam Wilson
> $ sudo bin/passenger-install-apache2-module
242 2 Sam Wilson
243 2 Sam Wilson
Next, configure Apache:
244 2 Sam Wilson
245 2 Sam Wilson
In /etc/apache2/mods-available/passenger.load we will add next line
246 2 Sam Wilson
247 2 Sam Wilson
> LoadModule passenger_module /var/lib/gems/1.X/gems/passenger-X.X.X/ext/apache2/mod_passenger.so
248 2 Sam Wilson
249 2 Sam Wilson
We have to edit the conf of the passenger apache2 module in /etc/apache2/mods-available/passenger.conf
250 2 Sam Wilson
251 2 Sam Wilson
> PassengerRoot /var/lib/gems/1.X/gems/passenger-X.X.X
252 2 Sam Wilson
> PassengerRuby /usr/bin/ruby1.X
253 2 Sam Wilson
254 2 Sam Wilson
And now we active the module
255 2 Sam Wilson
256 2 Sam Wilson
> $ sudo a2enmod passenger
257 2 Sam Wilson
258 2 Sam Wilson
Apache virtualhost for redmine web app
259 2 Sam Wilson
260 2 Sam Wilson
<pre>
261 2 Sam Wilson
    <VirtualHost *:80>
262 2 Sam Wilson
        ServerName redmine.server.com
263 2 Sam Wilson
264 2 Sam Wilson
        DocumentRoot /var/www/redmine/public
265 2 Sam Wilson
266 2 Sam Wilson
        ServerAdmin user@server.com
267 2 Sam Wilson
        LogLevel warn
268 2 Sam Wilson
        ErrorLog /var/log/apache2/redmine_error
269 2 Sam Wilson
        CustomLog /var/log/apache2/redmine_access combined
270 2 Sam Wilson
271 2 Sam Wilson
        <Directory /var/www/redmine/public>
272 2 Sam Wilson
            Options Indexes FollowSymLinks MultiViews
273 2 Sam Wilson
            AllowOverride None
274 2 Sam Wilson
            Order allow,deny
275 2 Sam Wilson
            allow from all
276 2 Sam Wilson
        </Directory>
277 2 Sam Wilson
    </VirtualHost>
278 2 Sam Wilson
</pre>
279 2 Sam Wilson
280 2 Sam Wilson
subversion server config in apache
281 2 Sam Wilson
282 2 Sam Wilson
<pre>
283 2 Sam Wilson
    <VirtualHost *:80>
284 2 Sam Wilson
	ServerName svn.server.com
285 2 Sam Wilson
	ServerAdmin user@server.com
286 2 Sam Wilson
	ErrorLog /var/log/apache2/svn_error
287 2 Sam Wilson
       	CustomLog /var/log/apache2/svn_access combined
288 2 Sam Wilson
        <Location /project>
289 2 Sam Wilson
           DAV svn
290 2 Sam Wilson
           SVNPath /var/lib/svn/project
291 2 Sam Wilson
292 2 Sam Wilson
           AuthType Basic
293 2 Sam Wilson
           AuthName "Trac system for Server projects"
294 2 Sam Wilson
           AuthUserFile "/var/lib/svn/.htpasswd"
295 2 Sam Wilson
           Require valid-user 
296 2 Sam Wilson
	   <LimitExcept GET PROPFIND OPTIONS REPORT>
297 2 Sam Wilson
               Require valid-user
298 2 Sam Wilson
           </LimitExcept>
299 2 Sam Wilson
       </Location>
300 2 Sam Wilson
    </Virtualhost>
301 2 Sam Wilson
</pre>
302 2 Sam Wilson
303 2 Sam Wilson
h2. Sendmail Server Configuration:
304 2 Sam Wilson
305 1 Umit Uzun
1.Before configure the email support of Redmine, we should download sendmail application for Ubuntu, issue:
306 1 Umit Uzun
> sudo apt-get install sendmail
307 1 Umit Uzun
> sudo sendmailconfig (Answer Yes to all questions which will be asked you)
308 1 Umit Uzun
309 1 Umit Uzun
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:
310 1 Umit Uzun
> sudo cd /opt/redmine/redmine-0.8.6/config
311 1 Umit Uzun
312 1 Umit Uzun
3.So now, assuming you’re in the “/config” directory, issue:
313 1 Umit Uzun
> sudo cp email.yml.example email.yml 
314 1 Umit Uzun
315 1 Umit Uzun
4.Then, open the “email.yml” file, issue:
316 1 Umit Uzun
> sudo gedit email.yml
317 1 Umit Uzun
… and edit it as in the example for sendmail configuration below:
318 1 Umit Uzun
319 1 Umit Uzun
production:
320 1 Umit Uzun
delivery_method: :sendmail
321 1 Umit Uzun
sendmail_settings:
322 1 Umit Uzun
location: /usr/sbin/sendmail
323 1 Umit Uzun
arguments: -i -t
324 1 Umit Uzun
address: smtp.example.net
325 1 Umit Uzun
port: 25
326 1 Umit Uzun
domain: example.net
327 1 Umit Uzun
authentication: :none
328 1 Umit Uzun
user_name: redmine@example.net
329 1 Umit Uzun
password: redmine
330 1 Umit Uzun
331 1 Umit Uzun
Then save “email.yml” file and exit to the command prompt.
332 1 Umit Uzun
333 1 Umit Uzun
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”.
334 1 Umit Uzun
335 1 Umit Uzun
*Subversion Installation and Configuration:*
336 1 Umit Uzun
337 1 Umit Uzun
1.Before configure the subversion support of Redmine, we should download subversion application for Ubuntu, issue:
338 1 Umit Uzun
> sudo apt-get install subversion
339 1 Umit Uzun
340 1 Umit Uzun
2.If your Redmine can't find the “subversion” command you can help to find by issuing:
341 1 Umit Uzun
· > sudo cd /opt/redmine/redmine-0.8.6/config
342 1 Umit Uzun
· > sudo gedit environment.rb
343 1 Umit Uzun
· Add ENV['PATH'] = "#{ENV['PATH']}:/subversion/path" line in it.
344 1 Umit Uzun
· Save and close the “environment.rb”
345 1 Umit Uzun
346 1 Umit Uzun
*Start Application Boot Time:*
347 1 Umit Uzun
348 1 Umit Uzun
1.To automatically start the application on booting your server you need to modify your “crontab”, issue:
349 1 Umit Uzun
> export EDITOR=gedit
350 1 Umit Uzun
> crontab -e
351 1 Umit Uzun
352 1 Umit Uzun
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):
353 1 Umit Uzun
@reboot cd /opt/redmine/redmine-0.8.6 ; rm -f log/mongrel.pid ; mongrel_rails start -e production -p 3000 -d
354 1 Umit Uzun
355 1 Umit Uzun
*Backup:*
356 1 Umit Uzun
357 1 Umit Uzun
1.Running backups is always a good idea. Redmine backups should include:
358 1 Umit Uzun
data (stored in your redmine database) 
359 1 Umit Uzun
/usr/bin/mysqldump -u -p | gzip > /path/to/redmine/backup/db/redmine_`date +%y_%m_%d`.gz
360 1 Umit Uzun
attachments (stored in the files directory of your Redmine install)
361 1 Umit Uzun
rsync -a /path/to/redmine/files /path/to/redmine/backup/files
362 1 Umit Uzun
363 1 Umit Uzun
2.Or you can use bash shell to automate kind of this operation issue:
364 1 Umit Uzun
> sudo cd /opt/redmine/redmine-0.8.6
365 1 Umit Uzun
> sudo mkdir backup
366 1 Umit Uzun
> sudo mkdir backup/db
367 1 Umit Uzun
> sudo mkdir backup/files
368 1 Umit Uzun
> sudo gedit backup/runRedmineBackup.bash
369 1 Umit Uzun
370 1 Umit Uzun
And after opened gedit with “runRedmineBackup.bash” write all commands below:
371 1 Umit Uzun
372 1 Umit Uzun
#!/bin/bash
373 1 Umit Uzun
data=`date -I`
374 1 Umit Uzun
mysqldump --user=root --password="redmine" --all-databases | gzip > db/backup-$data.sql.gz
375 1 Umit Uzun
cd db
376 1 Umit Uzun
ftp -i -n << EOF
377 1 Umit Uzun
open ftpserver.example.net
378 1 Umit Uzun
user username password
379 1 Umit Uzun
bin
380 1 Umit Uzun
mput backup-$data.sql.gz
381 1 Umit Uzun
bye
382 1 Umit Uzun
EOF
383 1 Umit Uzun
384 1 Umit Uzun
Then save “runRedmineBackup.bash” file and exit to the command prompt. After creation of  runRedmineBackup.bash you can add this bash to run continually between specified periods. Issue:
385 1 Umit Uzun
386 1 Umit Uzun
> export EDITOR=gedit
387 1 Umit Uzun
> crontab -e
388 1 Umit Uzun
Add 0 0 * * 0 cd /opt/redmine/redmine-0.8.6/backup ; sh runRedmineBackup.bash commands to crontab to backup database weekly.
389 1 Umit Uzun
	
390 1 Umit Uzun
To work this bush without any permission problem you have to change all of them modes to maxium permission issue:
391 1 Umit Uzun
392 1 Umit Uzun
> sudo chmod -R 777 backup
393 1 Umit Uzun
> sudo chown -R redmine:redmine backup
394 1 Umit Uzun
395 1 Umit Uzun
That's all. Now we completely installed Redmine our virtual Ubuntu OS and can reach from any machine at our network easily. Congratulations..!
396 1 Umit Uzun
397 2 Sam Wilson
h2. Sources & contributors.
398 2 Sam Wilson
399 2 Sam Wilson
* Ümit Uzun 06/11/2009.
400 2 Sam Wilson
* 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.
401 2 Sam Wilson
* Sam Wilson 2010-05-26, formatting changes.