##// END OF EJS Templates
merge with beta
marcink -
r2361:948c16bb merge codereview
parent child Browse files
Show More
@@ -0,0 +1,244
1 .. _installation_win:
2
3
4 Step by step Installation for Windows
5 =====================================
6
7
8 RhodeCode step-by-step install Guide for Windows
9
10 Target OS: Windows XP SP3 English (Clean installation)
11 + All Windows Updates until 24-may-2012
12
13 Step1 - Install Visual Studio 2008 Express
14 ------------------------------------------
15
16
17 Optional: You can also install MingW, but VS2008 installation is easier
18
19 Download "Visual C++ 2008 Express Edition with SP1" from:
20 http://www.microsoft.com/visualstudio/en-us/products/2008-editions/express
21 (if not found or relocated, google for "visual studio 2008 express" for
22 updated link)
23
24 You can also download full ISO file for offline installation, just
25 choose "All - Offline Install ISO image file" in the previous page and
26 choose "Visual C++ 2008 Express" when installing.
27
28
29 .. note::
30
31 Silverlight Runtime and SQL Server 2008 Express Edition are not
32 required, you can uncheck them
33
34
35 Step2 - Install Python
36 ----------------------
37
38 Install Python 2.x.y (x >= 5) x86 version (32bit). DO NOT USE A 3.x version.
39 Download Python 2.x.y from:
40 http://www.python.org/download/
41
42 Choose "Windows Installer" (32bit version) not "Windows X86-64
43 Installer". While writing this guide, the latest version was v2.7.3.
44 Remember the specific major and minor version installed, because it will
45 be needed in the next step. In this case, it is "2.7".
46
47
48 Step3 - Install Win32py extensions
49 ----------------------------------
50
51 Download pywin32 from:
52 http://sourceforge.net/projects/pywin32/files/
53
54 - Click on "pywin32" folder
55 - Click on the first folder (in this case, Build 217, maybe newer when you try)
56 - Choose the file ending with ".win32-py2.x.exe" -> x being the minor
57 version of Python you installed (in this case, 7)
58 When writing this guide, the file was:
59 http://sourceforge.net/projects/pywin32/files/pywin32/Build%20217/pywin32-217.win32-py2.7.exe/download
60
61
62 Step4 - Python BIN
63 ------------------
64
65 Add Python BIN folder to the path
66
67 You have to add the Python folder to the path, you can do it manually
68 (editing "PATH" environment variable) or using Windows Support Tools
69 that came preinstalled in Vista/7 and can be installed in Windows XP.
70
71 - Using support tools on WINDOWS XP:
72 If you use Windows XP you can install them using Windows XP CD and
73 navigating to \SUPPORT\TOOLS. There, execute Setup.EXE (not MSI).
74 Afterwards, open a CMD and type::
75
76 SETX PATH "%PATH%;[your-python-path]" -M
77
78 Close CMD (the path variable will be updated then)
79
80 - Using support tools on WINDOWS Vista/7:
81
82 Open a CMD and type::
83
84 SETX PATH "%PATH%;[your-python-path]" /M
85
86 Please substitute [your-python-path] with your Python installation path.
87 Typically: C:\\Python27
88
89
90 Step5 - RhodeCode folder structure
91 ----------------------------------
92
93 Create a RhodeCode folder structure
94
95 This is only a example to install RhodeCode, you can of course change
96 it. However, this guide will follow the proposed structure, so please
97 later adapt the paths if you change them. My recommendation is to use
98 folders with NO SPACES. But you can try if you are brave...
99
100 Create the following folder structure::
101
102 C:\RhodeCode
103 C:\RhodeCode\Bin
104 C:\RhodeCode\Env
105 C:\RhodeCode\Repos
106
107
108 Step6 - Install virtualenv
109 ---------------------------
110
111 Install Virtual Env for Python
112
113 Navigate to: http://www.virtualenv.org/en/latest/index.html#installation
114 Right click on "virtualenv.py" file and choose "Save link as...".
115 Download to C:\\RhodeCode (or whatever you want)
116 (the file is located at
117 https://raw.github.com/pypa/virtualenv/master/virtualenv.py)
118
119 Create a virtual Python environment in C:\\RhodeCode\\Env (or similar). To
120 do so, open a CMD (Python Path should be included in Step3), navigate
121 where you downloaded "virtualenv.py", and write::
122
123 python virtualenv.py C:\RhodeCode\Env
124
125 (--no-site-packages is now the default behaviour of virtualenv, no need
126 to include it)
127
128
129 Step7 - Install RhodeCode
130 -------------------------
131
132 Finally, install RhodeCode
133
134 Close previously opened command prompt/s, and open a Visual Studio 2008
135 Command Prompt (**IMPORTANT!!**). To do so, go to Start Menu, and then open
136 "Microsoft Visual C++ 2008 Express Edition" -> "Visual Studio Tools" ->
137 "Visual Studio 2008 Command Prompt"
138
139 In that CMD (loaded with VS2008 PATHs) type::
140
141 cd C:\RhodeCode\Env\Scripts (or similar)
142 activate
143
144 The prompt will change into "(Env) C:\\RhodeCode\\Env\\Scripts" or similar
145 (depending of your folder structure). Then type::
146
147 pip install rhodecode
148
149 (long step, please wait until fully complete)
150
151 Some warnings will appear, don't worry as they are normal.
152
153
154 Step8 - Configuring RhodeCode
155 -----------------------------
156
157
158 steps taken from http://packages.python.org/RhodeCode/setup.html
159
160 You have to use the same Visual Studio 2008 command prompt as Step7, so
161 if you closed it reopen it following the same commands (including the
162 "activate" one). When ready, just type::
163
164 cd C:\RhodeCode\Bin
165 paster make-config RhodeCode production.ini
166
167 Then, you must edit production.ini to fit your needs (ip address, ip
168 port, mail settings, database, whatever). I recommend using NotePad++
169 (free) or similar text editor, as it handles well the EndOfLine
170 character differences between Unix and Windows
171 (http://notepad-plus-plus.org/)
172
173 For the sake of simplicity lets run it with the default settings. After
174 your edits (if any), in the previous Command Prompt, type::
175
176 paster setup-rhodecode production.ini
177
178 (this time a NEW database will be installed, you must follow a different
179 step to later UPGRADE to a newer RhodeCode version)
180
181 The script will ask you for confirmation about creating a NEW database,
182 answer yes (y)
183 The script will ask you for repository path, answer C:\\RhodeCode\\Repos
184 (or similar)
185 The script will ask you for admin username and password, answer "admin"
186 + "123456" (or whatever you want)
187 The script will ask you for admin mail, answer "admin@xxxx.com" (or
188 whatever you want)
189
190 If you make some mistake and the script does not end, don't worry, start
191 it again.
192
193
194 Step9 - Running RhodeCode
195 -------------------------
196
197
198 In the previous command prompt, being in the C:\\RhodeCode\\Bin folder,
199 just type::
200
201 paster serve production.ini
202
203 Open yout web server, and go to http://127.0.0.1:5000
204
205 It works!! :-)
206
207 Remark:
208 If it does not work first time, just Ctrl-C the CMD process and start it
209 again. Don't forget the "http://" in Internet Explorer
210
211
212
213 What this Guide does not cover:
214
215 - Installing Celery
216 - Running RhodeCode as Windows Service. You can investigate here:
217
218 - http://pypi.python.org/pypi/wsgisvc
219 - http://ryrobes.com/python/running-python-scripts-as-a-windows-service/
220 - http://wiki.pylonshq.com/display/pylonscookbook/How+to+run+Pylons+as+a+Windows+service
221
222 - Using Apache. You can investigate here:
223
224 - https://groups.google.com/group/rhodecode/msg/c433074e813ffdc4
225
226
227 Upgrading
228 =========
229
230 Stop running RhodeCode
231 Open a CommandPrompt like in Step7 (VS2008 path + activate) and type::
232
233 easy_install -U rhodecode
234 cd \RhodeCode\Bin
235
236 { backup your production.ini file now} ::
237
238 paster make-config RhodeCode production.ini
239
240 (check changes and update your production.ini accordingly) ::
241
242 paster upgrade-db production.ini (update database)
243
244 Full steps in http://packages.python.org/RhodeCode/upgrade.html No newline at end of file
@@ -29,9 +29,14 http://pypi.python.org/pypi/RhodeCode, d
29
29
30 python setup.py install
30 python setup.py install
31
31
32 Step by step installation example for Windows
33 ---------------------------------------------
32
34
33 Step by step installation example
35 :ref:`installation_win`
34 ---------------------------------
36
37
38 Step by step installation example for Linux
39 -------------------------------------------
35
40
36
41
37 For installing RhodeCode i highly recommend using separate virtualenv_. This
42 For installing RhodeCode i highly recommend using separate virtualenv_. This
@@ -34,6 +34,11 entering this "root" path ``setup-rhodec
34 and password for the initial admin account which ``setup-rhodecode`` sets
34 and password for the initial admin account which ``setup-rhodecode`` sets
35 up for you.
35 up for you.
36
36
37 setup process can be fully automated, example for lazy::
38
39 paster setup-rhodecode production.ini --user=marcink --password=secret --email=marcin@rhodecode.org --repos=/home/marcink/my_repos
40
41
37 - The ``setup-rhodecode`` command will create all of the needed tables and an
42 - The ``setup-rhodecode`` command will create all of the needed tables and an
38 admin account. When choosing a root path you can either use a new empty
43 admin account. When choosing a root path you can either use a new empty
39 location, or a location which already contains existing repositories. If you
44 location, or a location which already contains existing repositories. If you
@@ -286,7 +286,6 class DiffProcessor(object):
286 tag,
286 tag,
287 l['line'][last:]
287 l['line'][last:]
288 )
288 )
289
290 do(line)
289 do(line)
291 do(next_)
290 do(next_)
292
291
@@ -298,9 +297,6 class DiffProcessor(object):
298 files = []
297 files = []
299 try:
298 try:
300 line = lineiter.next()
299 line = lineiter.next()
301 # skip first context
302 skipfirst = True
303
304 while 1:
300 while 1:
305 # continue until we found the old file
301 # continue until we found the old file
306 if not line.startswith('--- '):
302 if not line.startswith('--- '):
@@ -322,7 +318,6 class DiffProcessor(object):
322
318
323 line = lineiter.next()
319 line = lineiter.next()
324 while line:
320 while line:
325
326 match = self._chunk_re.match(line)
321 match = self._chunk_re.match(line)
327 if not match:
322 if not match:
328 break
323 break
@@ -334,20 +329,20 class DiffProcessor(object):
334 [int(x or 1) for x in match.groups()[:-1]]
329 [int(x or 1) for x in match.groups()[:-1]]
335 old_line -= 1
330 old_line -= 1
336 new_line -= 1
331 new_line -= 1
337 context = len(match.groups()) == 5
332 gr = match.groups()
333 context = len(gr) == 5
338 old_end += old_line
334 old_end += old_line
339 new_end += new_line
335 new_end += new_line
340
336
341 if context:
337 if context:
342 if not skipfirst:
338 # skip context only if it's first line
339 if int(gr[0]) > 1:
343 lines.append({
340 lines.append({
344 'old_lineno': '...',
341 'old_lineno': '...',
345 'new_lineno': '...',
342 'new_lineno': '...',
346 'action': 'context',
343 'action': 'context',
347 'line': line,
344 'line': line,
348 })
345 })
349 else:
350 skipfirst = False
351
346
352 line = lineiter.next()
347 line = lineiter.next()
353 while old_line < old_end or new_line < new_end:
348 while old_line < old_end or new_line < new_end:
@@ -372,6 +367,15 class DiffProcessor(object):
372 affects_old = affects_new = True
367 affects_old = affects_new = True
373 action = 'unmod'
368 action = 'unmod'
374
369
370 if line.find('No newline at end of file') != -1:
371 lines.append({
372 'old_lineno': '...',
373 'new_lineno': '...',
374 'action': 'context',
375 'line': line
376 })
377
378 else:
375 old_line += affects_old
379 old_line += affects_old
376 new_line += affects_new
380 new_line += affects_new
377 lines.append({
381 lines.append({
@@ -380,6 +384,7 class DiffProcessor(object):
380 'action': action,
384 'action': action,
381 'line': line
385 'line': line
382 })
386 })
387
383 line = lineiter.next()
388 line = lineiter.next()
384 except StopIteration:
389 except StopIteration:
385 pass
390 pass
@@ -393,7 +398,7 class DiffProcessor(object):
393 line = lineiter.next()
398 line = lineiter.next()
394 if line['action'] != 'unmod':
399 if line['action'] != 'unmod':
395 nextline = lineiter.next()
400 nextline = lineiter.next()
396 if nextline['action'] == 'unmod' or \
401 if nextline['action'] in ['unmod', 'context'] or \
397 nextline['action'] == line['action']:
402 nextline['action'] == line['action']:
398 continue
403 continue
399 self.differ(line, nextline)
404 self.differ(line, nextline)
General Comments 0
You need to be logged in to leave comments. Login now