~azzar1/unity/add-show-desktop-key

« back to all changes in this revision

Viewing changes to doc/setup/install_proc.txt

  • Committer: mattgiuca
  • Date: 2008-07-21 02:21:56 UTC
  • Revision ID: svn-v3-trunk0:2b9c9e99-6f39-0410-b283-7f802c844ae2:trunk:915
Moved projectid from all tables using assessedid into the assessed table
itself.
    Rationale: "assessed" now describes the submitter of a project along with
    the project itself (as these two things are always used together).

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
# Installation Procedure for IVLE
2
2
# ===============================
3
3
 
4
 
# Target Machine: Ubuntu (Versions 6.06 and 7.10 - differences between
5
 
# versions noted)
 
4
# Target Platform: Ubuntu 8.04
6
5
#
7
6
# IMPORTANT: This is NOT a shell script. It has interactive sections and
8
7
# things that need to be customized.
11
10
 
12
11
# While other install guides in this package are generic, this one is very
13
12
# specific to our intended configuration. It will be very helpful if trying to
14
 
# set up IVLE on Ubuntu 7.06 or higher; less helpful for other platforms.
 
13
# set up IVLE on Ubuntu 8.04 or higher; less helpful for other platforms.
15
14
# This refers to ivle.conf, also included.
16
15
#
17
16
# Author: Matt Giuca
18
17
# Date: 29/1/2008
19
18
 
20
 
sudo vim /etc/apt/sources.list
21
 
 
22
 
# 7.10 (Gutsy) specific #
23
 
 
24
 
# Gutsy by default had the CD-ROM packages selected, and the Internet packages
25
 
# commented out. (A comment in the apt sources list said it was because it
26
 
# failed to verify - IMPORTANT?? Probably not.)
27
 
# Comment out line 4 (deb cdrom:...)
28
 
 
29
 
# End 7.10 (Gutsy) specific #
30
 
 
31
 
# Uncomment ALL the lines for main, restricted and universe
32
 
# (deb http:...gutsy main restricted, deb-src ... main restricted
33
 
# deb http:...gutsy universe)
34
 
# Universe is important for pysvn (python-svn) later on
35
 
# :wq
36
 
 
37
 
sudo apt-get update
38
 
 
 
19
##########################################################################
39
20
# Apt packages
40
 
sudo apt-get install subversion
41
 
sudo apt-get install gcc libc6 libc6-dev
42
 
# On 6.06 (Dapper):
43
 
sudo apt-get install python2.4-dev
44
 
# On 7.10 (Gutsy):
45
 
sudo apt-get install python2.5-dev
46
 
 
47
 
# Python packages needed by IVLE or student code
48
 
# See trunk/doc/dependencies.txt
49
 
wget 'http://pypi.python.org/packages/source/p/python-cjson/python-cjson-1.0.5.tar.gz'
50
 
 
51
 
tar -zxvf python-cjson-1.0.5.tar.gz
52
 
 
53
 
cd python-cjson-1.0.5
54
 
./setup.py build
55
 
sudo ./setup.py install
56
 
cd ..
57
 
 
58
 
# 6.06 (Dapper) specific
59
 
wget 'http://webpy.org/static/web.py-0.22.tar.gz'
60
 
tar -zxvf web.py-0.22.tar.gz
61
 
cd webpy
62
 
python ./setup.py build
63
 
sudo python ./setup.py install
64
 
cd ..
65
 
 
66
 
sudo apt-get install python-svn python-webpy python2.4-gtk2 python-matplotlib
67
 
# End 6.06 (Dapper) specific
68
 
 
69
 
# 7.10 (Gutsy) specific
70
 
sudo apt-get install python-svn python-webpy python-numpy python-matplotlib
71
 
# Note: I had a lot of trouble with the python-svn package.
72
 
# After playing around a bit it started working.
73
 
# python -c 'import pysvn'
74
 
# to test if it worked.
75
 
# Do Not install python-svn-dbg.
76
 
# End 7.10 (Gutsy) specific
77
 
 
 
21
##########################################################################
 
22
sudo apt-get install subversion build-essential debootstrap             \
 
23
                     apache2 libapache2-mod-python libapache2-svn       \
 
24
                     python2.5-dev python-svn python-webpy python-cjson \
 
25
                     postgresql python-pygresql php5 php5-pgsql         \
 
26
                     python-docutils python-epydoc python-ldap
 
27
 
 
28
##########################################################################
 
29
# Configure postgres
 
30
##########################################################################
 
31
 
 
32
# Set the postgres user's postgres password
 
33
sudo -u postgres psql template1
 
34
# At the prompt type (substituting <***password***> with a real one).
 
35
ALTER USER postgres WITH ENCRYPTED PASSWORD '<***password***>';
 
36
\q
 
37
 
 
38
##########################################################################
 
39
# Installing ivle
 
40
##########################################################################
 
41
#
78
42
# Check out the IVLE trunk
 
43
 
79
44
svn co https://ivle.svn.sourceforge.net/svnroot/ivle/trunk ivle_svn
80
 
# Says the SourceForge certificate authority is not trusted.
81
 
# I chose "Accept (p)ermanently" - Problem??
 
45
cd ivle_svn
82
46
 
83
 
# NOTE: From this point onwards it is 7.10 (Gutsy) specific. This is because I
84
 
# never was able to get IVLE to build with all dependencies on Dapper.
 
47
# Create a postgres database
 
48
# (only need the first line if it was previously created and is now changed)
 
49
sudo -u postgres dropdb ivle
 
50
sudo -u postgres createdb ivle
 
51
sudo -u postgres psql -d ivle < userdb/users.sql
85
52
 
86
53
# Set up IVLE
87
 
cd ivle_svn
88
54
./setup.py listmake
89
55
./setup.py config
90
56
 
91
 
# "Root directory" - type "/"
 
57
# "Root directory" - type "/" or "/ivle" (without the quotes)
92
58
# "UID of web server process" - 1000 at this stage (informatics)
93
59
# Leave others default.
94
60
# Note: This will cause IVLE to get installed to /opt/ivle
95
61
 
96
 
./setup.py build
 
62
sudo ./setup.py build
97
63
sudo ./setup.py install
98
64
 
 
65
# Make the directory containing the svn auth.
 
66
# Make sure it is owned by www-data.
 
67
sudo mkdir /opt/ivle/svn
 
68
sudo chown -R www-data:www-data /opt/ivle/svn
 
69
 
 
70
# Make the "repositories", "sessions" and "logs" directories in the home.
 
71
# Make sure they are owned by www-data.
 
72
cd /home/informatics
 
73
sudo mkdir repositories sessions logs
 
74
sudo chown -R www-data:www-data repositories sessions logs
 
75
 
 
76
cd /home/informatics/ivle_svn
 
77
 
99
78
# Create a user
100
 
sudo ./makeuser.py <username>
101
 
 
102
 
# Set up the Apache HTTP server
103
 
sudo apt-get install apache2 libapache2-mod-python
104
 
 
105
 
# DO: Copy the file "ivle.conf" from this package to
106
 
# /etc/apache2/sites-available.
 
79
sudo ./makeuser.py [OPTIONS] <login> 'Firstname Lastname' <rolenm> -p <password>
 
80
# role = guest/student/tutor/lecturer/admin
 
81
 
 
82
# Configure the Apache HTTP server
 
83
sudo cp doc/setup/ivle-both.conf /etc/apache2/sites-available/ivle
107
84
# MODIFY the first few lines so it is specific to your server.
108
 
 
109
 
# Replace the existing config link with the ivle one
110
 
cd /etc/apache2/sites-enabled/
111
 
sudo ln -fs /etc/apache2/sites-available/ivle.conf 000-default
112
 
 
113
 
# Restart the server
114
 
sudo apache2ctl -k restart
 
85
# * Change ServerAdmin and ServerName (for error reporting).
 
86
# * Inside the first VirtualHost block, there are two ServerNames
 
87
#   (localhost and public.localhost). You must change these to the domains
 
88
#   for regular IVLE and published-browsing IVLE respectively.
 
89
# * Inside the second VirtualHost block, there is one ServerName
 
90
#   (svn.localhost). You must change this to the domain for svn access.
 
91
# * Change all paths beginning with /opt/ivle or /home/informatics to the
 
92
#   locations you have installed things in.
 
93
sudo vim /etc/apache2/sites-available/ivle
 
94
 
 
95
# Replace the default with the IVLE site.
 
96
sudo a2dissite default
 
97
sudo a2ensite ivle
 
98
 
 
99
# Restart Apache.
 
100
sudo /etc/init.d/apache2 restart
 
101
 
 
102
# Make sure the 3 domains given in Apache conf all lookup to your server.
 
103
# (By default these are localhost, public.localhost and svn.localhost).
 
104
# For testing purposes, this can be done by editing /etc/hosts, for example:
 
105
# 127.0.0.1     svn.localhost public.localhost
 
106
sudo vim /etc/hosts
 
107
 
 
108
##########################################################################
 
109
# User management server: usrmgt-server
 
110
##########################################################################
 
111
# To start the user management server:
 
112
cd /opt/ivle/scripts
 
113
sudo ./usrmgt-server <port> <usrmgt-password>
 
114
# usrmgt-password is the password entered in setup.py config (usrmgt_magic)
 
115
# Note that the port number and usrmgt password are recorded in
 
116
# the automatically created init.d script: doc/setup/usrmgt-server.init
 
117
 
 
118
# To run it at boot time:
 
119
sudo cp doc/setup/usrmgt-server.init /etc/init.d/usrmgt-server
 
120
sudo chown root:root /etc/init.d/usrmgt-server
 
121
sudo chmod 700 /etc/init.d/usrmgt-server  # so world can't read database magic
 
122
sudo update-rc.d usrmgt-server defaults 99  # create symlinks in /etc/rc*.d
 
123
 
 
124
##########################################################################
 
125
# Setting up phpBB Forum in IVLE
 
126
##########################################################################
 
127
# This should all be run from the SVN directory
 
128
 
 
129
# Create a postgres database
 
130
# (only need the first line if it was previously created and is now changed)
 
131
sudo -u postgres dropdb ivle_forum
 
132
sudo -u postgres createdb ivle_forum
 
133
sudo -u postgres psql -d ivle_forum < userdb/forum_schema.sql
 
134
sudo -u postgres psql -d ivle_forum < userdb/forum_data.sql
 
135
 
 
136
#Change to the installed IVLE directory
 
137
cd /opt/ivle
 
138
# Fix permissions for install
 
139
cd www/php/phpBB3
 
140
# At very minimum you apache user must be able to write to
 
141
# cache/ files/ store/ images/avatars/upload config.php
 
142
sudo chown -R www-data:www-data .
 
143
 
 
144
##########################################################################
 
145
# Installing Pound reverse proxy (optional)
 
146
##########################################################################
 
147
 
 
148
sudo apt-get install pound
 
149
 
 
150
# edit /etc/default/pound so that the line reading
 
151
#     startup=0
 
152
# instead reads
 
153
#     startup=1
 
154
#
 
155
# copy pound.cfg to /etc/pound/pound.cfg
 
156
# edit IP addresses in pound.cfg