Project

General

Profile

NetDRMS Installation » History » Version 219

Pablo Alingery, 07/06/2016 16:05

1 50 Herve Ballans
{{toc}}
2 1 Herve Ballans
3 1 Herve Ballans
h1. NetDRMS Installation
4 1 Herve Ballans
5 1 Herve Ballans
h2. Requirements
6 1 Herve Ballans
7 47 Pablo Alingery
h3. Configuring production environment
8 1 Herve Ballans
9 121 Pablo Alingery
Adding user production (en root)
10 47 Pablo Alingery
11 1 Herve Ballans
<pre>
12 1 Herve Ballans
# adduser production
13 1 Herve Ballans
# addgroup ias
14 1 Herve Ballans
# adduser production ias
15 1 Herve Ballans
</pre>
16 1 Herve Ballans
17 49 Herve Ballans
h3. Configure /home/production/.profile
18 1 Herve Ballans
19 49 Herve Ballans
Adding environment variables
20 1 Herve Ballans
21 1 Herve Ballans
<pre>
22 122 Herve Ballans
#Modif Herve.B Pablo.A 12/05/2016
23 122 Herve Ballans
24 1 Herve Ballans
PATH="/usr/local/netdrms_current/bin/linux_x86_64:$PATH"
25 49 Herve Ballans
PATH="/usr/local/netdrms_current/scripts:$PATH"
26 122 Herve Ballans
PATH="/usr/local/jmd/bin:$PATH"
27 122 Herve Ballans
PATH="/usr/local/jmd/scripts:$PATH"
28 141 Pablo Alingery
#The following is not needed as installed with 'apt-get install' 
29 141 Pablo Alingery
#PATH="/usr/local/pgsql/bin:$PATH"
30 122 Herve Ballans
PATH="/usr/local/netdrms-tools/scripts:$PATH"
31 49 Herve Ballans
#2014-12-17 Avec Herve et Pablo on pense que la ligne suivante est intutile as it is f.. install in /usr/local/lib
32 140 Pablo Alingery
PATH="/usr/local/cfitsio:$PATH"
33 1 Herve Ballans
#Done
34 49 Herve Ballans
35 122 Herve Ballans
DERBY_HOME=/usr/local/jmd/databases/derby/derbyBD
36 49 Herve Ballans
export DERBY_HOME
37 49 Herve Ballans
38 49 Herve Ballans
export CVSROOT=:pserver:anonymous@solarch.tuc.noao.edu:2401/vtarc1/vso/cvsroot
39 49 Herve Ballans
</pre>
40 49 Herve Ballans
41 162 Pablo Alingery
h3. Configure /varl/lib/postgres/.profile
42 161 Pablo Alingery
43 163 Pablo Alingery
Add to $PATH so postgres can exeute command like initdb
44 161 Pablo Alingery
45 161 Pablo Alingery
<pre>
46 161 Pablo Alingery
#Modif Herve.B Pablo.A 19/05/2016
47 161 Pablo Alingery
PATH="/usr/lib/postgresql/9.4/bin:$PATH"
48 161 Pablo Alingery
</pre>
49 161 Pablo Alingery
50 125 Pablo Alingery
h3. Setting privileges for SUMS_MANAGER
51 87 Herve Ballans
52 126 Pablo Alingery
Please modify file /etc/sudoers so user 'production' will be able to execute  'sum_chown' that we will locate in the dir : /usr/local/bin . See below
53 125 Pablo Alingery
Add to /etc/sudoers the following line :
54 1 Herve Ballans
	production host=NOPASSWD:/usr/local/bin/sum_chmown
55 1 Herve Ballans
56 127 Pablo Alingery
h3. Set passwords file for db postgres 
57 1 Herve Ballans
58 127 Pablo Alingery
Please create file .pgpass with the following information for user 'production" so he will be able to connect without password as 'production' or 'postgres' to 2 db that we will create later ias_sdo and ias_sdo_sums.
59 1 Herve Ballans
60 1 Herve Ballans
61 1 Herve Ballans
.pgpass content :
62 1 Herve Ballans
<pre>
63 128 Pablo Alingery
	#hostname:5432:ias_sdo:production: 
64 128 Pablo Alingery
	#hostname:5434:ias_sdo_sums:production: 
65 128 Pablo Alingery
	#hostname:5432:ias_sdo:postgres: 
66 128 Pablo Alingery
	#hostname:5434:ias_sdo_sums:postgres
67 1 Herve Ballans
</pre>
68 128 Pablo Alingery
69 129 Pablo Alingery
where #hostname is the name of your server
70 129 Pablo Alingery
71 129 Pablo Alingery
72 131 Pablo Alingery
%{color:red}WARNING : change hostname when migrate sdo-new to sdo%
73 1 Herve Ballans
74 143 Pablo Alingery
75 132 Pablo Alingery
76 133 Pablo Alingery
h3. Install missing libraries 
77 1 Herve Ballans
78 133 Pablo Alingery
• libreadline-dev (but already installed with postgresql)
79 133 Pablo Alingery
• libssl-dev 
80 133 Pablo Alingery
• libpam0g-dev 
81 133 Pablo Alingery
• libperl-dev 
82 1 Herve Ballans
83 133 Pablo Alingery
NB : Already done in Debian 8.4 Jessy
84 1 Herve Ballans
<pre>
85 1 Herve Ballans
# apt-get install $library_name
86 1 Herve Ballans
</pre> 
87 1 Herve Ballans
where
88 1 Herve Ballans
	_$library_name_ is the name of library
89 19 Pablo Alingery
90 1 Herve Ballans
Then to update path on libraries, please type :
91 1 Herve Ballans
<pre>
92 19 Pablo Alingery
# ldconfig
93 1 Herve Ballans
</pre>
94 1 Herve Ballans
95 1 Herve Ballans
h3. Reconfigure locale
96 1 Herve Ballans
97 1 Herve Ballans
<pre>
98 1 Herve Ballans
# dpkg-reconfigure locales
99 1 Herve Ballans
</pre>
100 1 Herve Ballans
101 1 Herve Ballans
select fr_FR.UTF8 UTF8 and unselect en_US.UTF-8
102 1 Herve Ballans
103 1 Herve Ballans
localedef -i en_US -f UTF-8 en_US.UTF-8
104 1 Herve Ballans
105 1 Herve Ballans
(see here : [[http://www.thomas-krenn.com/en/wiki/Perl_warning_Setting_locale_failed_in_Debian]])
106 1 Herve Ballans
107 134 Pablo Alingery
h3. Install gfortran packages
108 1 Herve Ballans
109 1 Herve Ballans
<pre>
110 1 Herve Ballans
# apt-get install gfortran swig
111 1 Herve Ballans
</pre>
112 1 Herve Ballans
113 1 Herve Ballans
h3. Installation of cfitsio library
114 1 Herve Ballans
115 135 Pablo Alingery
In /usr/local dir
116 135 Pablo Alingery
117 135 Pablo Alingery
Version 3.39 (currently on sdo : 3.24)
118 1 Herve Ballans
<pre>
119 135 Pablo Alingery
# wget ftp://heasarc.gsfc.nasa.gov/software/fitsio/c/cfitsio3390.tar.gz
120 1 Herve Ballans
</pre>
121 137 Pablo Alingery
Untar and  decompression
122 1 Herve Ballans
<pre>
123 136 Pablo Alingery
# tar -xzvf cfitsio3390.tar.gz
124 1 Herve Ballans
</pre> 
125 1 Herve Ballans
126 139 Pablo Alingery
Go into /usr/local and type
127 1 Herve Ballans
128 1 Herve Ballans
su - root and :
129 1 Herve Ballans
<pre>
130 1 Herve Ballans
# ./configure --prefix=/usr/local
131 1 Herve Ballans
# make 
132 1 Herve Ballans
# make install
133 135 Pablo Alingery
</pre>
134 118 Pablo Alingery
135 144 Pablo Alingery
h3. Installation of apache2 and lib perl
136 118 Pablo Alingery
137 118 Pablo Alingery
<pre>
138 118 Pablo Alingery
# apt-get install apache2
139 118 Pablo Alingery
140 118 Pablo Alingery
# apt-get install libjson-perl
141 118 Pablo Alingery
142 118 Pablo Alingery
# apt-get install libapache2-mod-perl2
143 118 Pablo Alingery
</pre>
144 1 Herve Ballans
145 183 Herve Ballans
h3. Installation of postgresql
146 1 Herve Ballans
147 145 Pablo Alingery
Into 'root'
148 145 Pablo Alingery
 
149 145 Pablo Alingery
<pre>
150 147 Pablo Alingery
apt-get install postgresql-9.4 postgresql-client-9.4 
151 145 Pablo Alingery
</pre>
152 145 Pablo Alingery
153 213 Herve Ballans
h3. Installation of python3
154 209 Pablo Alingery
155 209 Pablo Alingery
Into 'root'
156 209 Pablo Alingery
 
157 209 Pablo Alingery
<pre>
158 209 Pablo Alingery
apt-get install python3 
159 1 Herve Ballans
</pre>
160 210 Pablo Alingery
161 211 Pablo Alingery
Add some modules psycopg2 (postgres connector) and pySmartDL (Download manager) 
162 210 Pablo Alingery
163 210 Pablo Alingery
<pre>
164 210 Pablo Alingery
apt-get install python3-psycopg2
165 210 Pablo Alingery
</pre>
166 210 Pablo Alingery
167 210 Pablo Alingery
<pre>
168 210 Pablo Alingery
apt-get install python3-psycopg2
169 210 Pablo Alingery
</pre>
170 210 Pablo Alingery
171 210 Pablo Alingery
Add python3-pip for modules within python3
172 210 Pablo Alingery
173 210 Pablo Alingery
<pre>
174 210 Pablo Alingery
apt-get install python3-pip
175 1 Herve Ballans
</pre>
176 212 Pablo Alingery
177 212 Pablo Alingery
<pre>
178 212 Pablo Alingery
pip3 install pySmartDL
179 212 Pablo Alingery
</pre>
180 1 Herve Ballans
181 213 Herve Ballans
Both python2.7 and 3.4 versions are installed on the system.
182 213 Herve Ballans
By default, the python2.7 is used.
183 213 Herve Ballans
In order to change in 3.4 by default, type :
184 213 Herve Ballans
<pre>
185 213 Herve Ballans
update-alternatives --config python
186 213 Herve Ballans
</pre>
187 209 Pablo Alingery
188 1 Herve Ballans
h3. Installation of sdo_scripts
189 218 Pablo Alingery
190 219 Pablo Alingery
Install monitoring scripts for sdo
191 218 Pablo Alingery
192 218 Pablo Alingery
<pre>
193 218 Pablo Alingery
194 218 Pablo Alingery
</pre>
195 218 Pablo Alingery
196 1 Herve Ballans
h2. NetDRMS databases
197 1 Herve Ballans
198 156 Pablo Alingery
into /var/lib/postgresql  (hard mount point separated,  7 disks 15000 tr/min in raid5 in order to distribute read and write) 
199 1 Herve Ballans
200 1 Herve Ballans
<pre>
201 158 Pablo Alingery
# cd /var/lib/postgresql
202 157 Pablo Alingery
# mkdir data  data_sums data_monitor
203 157 Pablo Alingery
# chown -R postgres:postgres * 
204 1 Herve Ballans
</pre>
205 1 Herve Ballans
206 160 Pablo Alingery
h3. Initialize 3 servers data,  data_sums, data_monitor
207 1 Herve Ballans
208 159 Pablo Alingery
Into postgres
209 1 Herve Ballans
<pre>
210 1 Herve Ballans
# su - postgres
211 1 Herve Ballans
212 1 Herve Ballans
$ initdb --locale=C -D data -A md5 -W
213 1 Herve Ballans
(no password)
214 2 Herve Ballans
215 2 Herve Ballans
Success. You can now start the database server using:
216 2 Herve Ballans
217 2 Herve Ballans
    postgres -D data
218 2 Herve Ballans
or
219 2 Herve Ballans
    pg_ctl -D data -l logfile start
220 2 Herve Ballans
221 1 Herve Ballans
222 1 Herve Ballans
$ initdb --locale=C -D data_sums -A md5 -W
223 2 Herve Ballans
(no password)
224 2 Herve Ballans
225 2 Herve Ballans
Success. You can now start the database server using:
226 2 Herve Ballans
227 2 Herve Ballans
    postgres -D data_sums
228 2 Herve Ballans
or
229 2 Herve Ballans
    pg_ctl -D data_sums -l logfile start
230 8 Pablo Alingery
231 8 Pablo Alingery
$ initdb --locale=C -D data_monitor -A md5 -W
232 8 Pablo Alingery
(no password)
233 8 Pablo Alingery
234 8 Pablo Alingery
Success. You can now start the database server using:
235 8 Pablo Alingery
236 8 Pablo Alingery
    postgres -D data_monitor
237 8 Pablo Alingery
or
238 8 Pablo Alingery
    pg_ctl -D data_monitor -l logfile start
239 2 Herve Ballans
</pre>
240 2 Herve Ballans
241 1 Herve Ballans
242 1 Herve Ballans
243 1 Herve Ballans
Edition des fichiers postgresql.conf pour configurer les bons ports d'écoute :
244 1 Herve Ballans
listen_addresses = '*'
245 1 Herve Ballans
data -> port 5432
246 10 Pablo Alingery
data_sums -> port 5434
247 1 Herve Ballans
data_monitor -> port 5436
248 10 Pablo Alingery
249 165 Pablo Alingery
Edit files data*/pg_hba.conf : replace 'md5' by 'trust'
250 1 Herve Ballans
<pre>
251 1 Herve Ballans
#"local"
252 1 Herve Ballans
local   all             all                                     trust
253 1 Herve Ballans
#"IPv4"
254 1 Herve Ballans
host   all             all                                     trust
255 1 Herve Ballans
</pre>
256 166 Pablo Alingery
257 166 Pablo Alingery
h3. Tunning postgres 
258 166 Pablo Alingery
259 166 Pablo Alingery
In file postgres.conf ( according to https://www.qwant.com/?q=Tunning+postgres+server+9.4+&client=firefox  )
260 166 Pablo Alingery
261 168 Pablo Alingery
shared_buffer=4096MB %{color:red}So 1/12 of the total RAM memory available%
262 1 Herve Ballans
263 169 Pablo Alingery
work_mem = 24MB
264 168 Pablo Alingery
265 168 Pablo Alingery
maintenance_work_mem = 4096MB
266 1 Herve Ballans
267 169 Pablo Alingery
wal_buffers = 16MB
268 169 Pablo Alingery
269 169 Pablo Alingery
checkpoint_segments = 32
270 169 Pablo Alingery
271 169 Pablo Alingery
checkpoint_completion_target = 0.9
272 169 Pablo Alingery
273 169 Pablo Alingery
random_page_cost = 1.0
274 169 Pablo Alingery
275 169 Pablo Alingery
effective_cache_size = 16384MB so 1/4 of the max memory 
276 169 Pablo Alingery
277 170 Pablo Alingery
278 170 Pablo Alingery
279 170 Pablo Alingery
#log
280 169 Pablo Alingery
logging_collector = on 
281 169 Pablo Alingery
log_directory = 'pg_log' 
282 169 Pablo Alingery
log_filename = 'postgresql-%Y-%m-%d_%H%M%S.log' # log file name pattern,
283 169 Pablo Alingery
log_truncate_on_rotation = on           # If on, an existing log file with the
284 169 Pablo Alingery
log_rotation_age = 1d                   # Automatic rotation of logfiles will
285 170 Pablo Alingery
client_min_messages = error
286 170 Pablo Alingery
log_min_messages = error 
287 170 Pablo Alingery
log_min_duration_statement = 0
288 170 Pablo Alingery
289 170 Pablo Alingery
log_connections = on
290 170 Pablo Alingery
log_disconnections = on
291 170 Pablo Alingery
log_duration = off
292 170 Pablo Alingery
log_hostname = on
293 170 Pablo Alingery
log_line_prefix = '%t [%p]: %u@%h - %d :'  
294 170 Pablo Alingery
295 170 Pablo Alingery
track_counts = on
296 170 Pablo Alingery
autovacuum = on 
297 170 Pablo Alingery
298 170 Pablo Alingery
extra_float_digits = 3
299 170 Pablo Alingery
300 177 Pablo Alingery
h3. Start the 3 databases :
301 1 Herve Ballans
302 1 Herve Ballans
<pre>
303 1 Herve Ballans
# su - postgres
304 196 Herve Ballans
$ cd /var/lib/postgresql
305 172 Pablo Alingery
$ pg_ctl -D data  start
306 172 Pablo Alingery
$ pg_ctl -D data_sums start
307 172 Pablo Alingery
$ pg_ctl -D data_monitor start
308 1 Herve Ballans
</pre>
309 174 Pablo Alingery
310 1 Herve Ballans
h3. Create the 3 databases :
311 181 Pablo Alingery
312 178 Pablo Alingery
Into user 'postgres'
313 1 Herve Ballans
314 179 Pablo Alingery
* createdb --locale C -E LATIN1 -T template0 ias_sdo
315 179 Pablo Alingery
* createdb --locale C -E LATIN1 -T template0 -p 5434 ias_sdo_sums
316 179 Pablo Alingery
* createdb --locale C -E LATIN1 -T template0 -p 5436 ias_sdo_monitor
317 54 Herve Ballans
318 182 Herve Ballans
h3. Automatic startup
319 182 Herve Ballans
320 182 Herve Ballans
Add following lines in the /etc/rc.local file :
321 182 Herve Ballans
322 182 Herve Ballans
<pre>
323 197 Herve Ballans
su -l -c "/usr/lib/postgresql/9.4/bin/pg_ctl -D /var/lib/postgresql/data start" postgres
324 197 Herve Ballans
su -l -c "/usr/lib/postgresql/9.4/bin/pg_ctl -D /var/lib/postgresql/data_sums start" postgres
325 197 Herve Ballans
su -l -c "/usr/lib/postgresql/9.4/bin/pg_ctl -D /var/lib/postgresql/data_monitor start" postgres
326 182 Herve Ballans
</pre>
327 182 Herve Ballans
328 184 Herve Ballans
h2. System tuning
329 1 Herve Ballans
330 187 Herve Ballans
Current configuration :
331 185 Herve Ballans
<pre>
332 185 Herve Ballans
# sysctl -a
333 185 Herve Ballans
</pre>
334 1 Herve Ballans
335 187 Herve Ballans
In the following file :
336 185 Herve Ballans
<pre>
337 185 Herve Ballans
# vi /etc/sysctl.conf
338 185 Herve Ballans
</pre>
339 1 Herve Ballans
340 188 Herve Ballans
we change some values (default values are commented with '#')
341 194 Herve Ballans
342 195 Herve Ballans
(resources links [[Links|here]])
343 194 Herve Ballans
344 185 Herve Ballans
<pre>
345 191 Herve Ballans
# Semaphore is a object that is used to control utilization of a particular process.
346 191 Herve Ballans
# kernel.sem = SEMMSL SEMMNS SEMOPM SEMMNI
347 191 Herve Ballans
# SEMMSL        maximum number of semaphores per array  (min 128)
348 191 Herve Ballans
# SEMMNS        maximum semaphores system-wide  
349 191 Herve Ballans
# SEMOPM        maximum operations per semop call       
350 191 Herve Ballans
# SEMMNI        maximum arrays 
351 191 Herve Ballans
#semop incresed from 32 (default value)operation to 100 (3rd value )
352 191 Herve Ballans
# kernel.sem = 250      32000   32      128
353 191 Herve Ballans
kernel.sem = 250 32000 100 128
354 191 Herve Ballans
355 191 Herve Ballans
In order to  apply changes :#This sets the  OS receive buffer size for all types of connections (default value 212992)
356 191 Herve Ballans
#net.core.rmem_default = 212992
357 191 Herve Ballans
#net.core.rmem_max = 212992
358 191 Herve Ballans
net.core.rmem_default = 33554432
359 191 Herve Ballans
net.core.rmem_max = 33554432
360 191 Herve Ballans
361 191 Herve Ballans
#This is the OS send buffer size for all types of connections (212992 default value) 
362 191 Herve Ballans
#net.core.wmem_default = 212992
363 191 Herve Ballans
#net.core.wmem_max = 212992
364 191 Herve Ballans
net.core.wmem_default = 33554432
365 191 Herve Ballans
net.core.wmem_max = 33554432
366 191 Herve Ballans
367 193 Pablo Alingery
#TCP Autotuning setting. "The first value tells the kernel the minimum receive buffer for each TCP connection, and this buffer is always
368 193 Pablo Alingery
# allocated to a TCP socket, even under high pressure on the system. ... The second value specified tells the kernel the default receive
369 193 Pablo Alingery
# buffer allocated for each TCP socket. This value overrides the /proc/sys/net/core/rmem_default value used by other protocols. ...
370 192 Pablo Alingery
# The third and last value specified in this variable specifies the maximum receive buffer that can be allocated for a TCP socket."
371 1 Herve Ballans
#net.ipv4.tcp_rmem = 4096       87380   6291456
372 1 Herve Ballans
net.ipv4.tcp_rmem = 10240 87380 33554432
373 1 Herve Ballans
374 193 Pablo Alingery
#TCP Autotuning setting. "This variable takes 3 different values which holds information on how much TCP sendbuffer memory space
375 193 Pablo Alingery
# each TCP socket has to use. Every TCP socket has this much buffer space to use before the buffer is filled up. Each of the three 
376 193 Pablo Alingery
#values are used under different conditions. ... The first value in this variable tells the minimum TCP send buffer space available
377 193 Pablo Alingery
# for a single TCP socket. ... The second value in the variable tells us the default buffer space allowed for a single TCP socket to use. ... 
378 193 Pablo Alingery
#The third value tells the kernel the maximum TCP send buffer space." 
379 191 Herve Ballans
#net.ipv4.tcp_wmem = 4096       16384   4194304
380 191 Herve Ballans
net.ipv4.tcp_wmem = 10240 87380 33554432
381 191 Herve Ballans
382 191 Herve Ballans
#Disable cache metrics so the initial conditions of the closed connections will not be saved to be used in near future connections
383 191 Herve Ballans
#net.ipv4.tcp_no_metrics_save = 0
384 191 Herve Ballans
net.ipv4.tcp_no_metrics_save = 1
385 191 Herve Ballans
386 1 Herve Ballans
# Increase number of incoming connections backlog
387 1 Herve Ballans
# net.core.netdev_max_backlog = 1000
388 1 Herve Ballans
net.core.netdev_max_backlog = 5000
389 1 Herve Ballans
390 1 Herve Ballans
# The tcp_mem variable defines how the TCP stack should behave when it comes to memory usage. ... 
391 192 Pablo Alingery
#The first value specified in the tcp_mem variable tells the kernel the low threshold. 
392 192 Pablo Alingery
#Below this point, the TCP stack do not bother at all about putting any pressure on the memory usage by different TCP sockets. ... 
393 193 Pablo Alingery
#The second value tells the kernel at which point to start pressuring memory usage down. ... The final value tells the kernel how many
394 193 Pablo Alingery
# memory pages it may use maximally
395 1 Herve Ballans
# net.ipv4.tcp_mem = 1543347    2057796 3086694
396 191 Herve Ballans
net.ipv4.tcp_mem = 786432 1048576 26777216
397 191 Herve Ballans
398 192 Pablo Alingery
# local port range that is used by TCP and UDP traffic to choose the local port. You will see in the parameters of this file two numbers:
399 192 Pablo Alingery
# The first number is the first local port allowed for TCP and UDP traffic on the server, the second is the last local port number.
400 191 Herve Ballans
# net.ipv4.ip_local_port_range = 32768  61000
401 191 Herve Ballans
net.ipv4.ip_local_port_range = 1024 65535
402 191 Herve Ballans
403 191 Herve Ballans
# maximum number of sockets in TIME-WAIT to be held simultaneously.
404 191 Herve Ballans
# net.ipv4.tcp_max_tw_buckets = 262144
405 191 Herve Ballans
net.ipv4.tcp_max_tw_buckets = 360000
406 1 Herve Ballans
</pre>
407 185 Herve Ballans
408 191 Herve Ballans
Then we run the following command to make our change take effect:
409 191 Herve Ballans
410 185 Herve Ballans
<pre>
411 185 Herve Ballans
# sysctl -p
412 185 Herve Ballans
</pre>
413 176 Pablo Alingery
414 216 Pablo Alingery
h2. JMD Installation 
415 215 Herve Ballans
416 217 Pablo Alingery
Download new JMD package build by Niles Oien 2016-04-07 following thoses actions :
417 215 Herve Ballans
418 215 Herve Ballans
<pre>
419 215 Herve Ballans
cd /urs/local
420 215 Herve Ballans
421 215 Herve Ballans
[oien@spsc-nso19-12 ~]$ ftp gong2.nso.edu
422 215 Herve Ballans
Name (gong2.nso.edu:oien): anonymous
423 215 Herve Ballans
Password: <---------------- use your email as the password
424 215 Herve Ballans
ftp> cd outgoing/oien
425 215 Herve Ballans
ftp> get pablo_jmd.tar.gz
426 215 Herve Ballans
ftp> quit
427 215 Herve Ballans
</pre>
428 215 Herve Ballans
429 215 Herve Ballans
Install new JMD package following thoses actions 
430 215 Herve Ballans
431 215 Herve Ballans
<pre>
432 215 Herve Ballans
[oien@spsc-nso19-12 ~]$ gunzip -vf pablo_jmd.tar.gz
433 215 Herve Ballans
pablo_jmd.tar.gz:      8.3% -- replaced with pablo_jmd.tar
434 215 Herve Ballans
[oien@spsc-nso19-12 ~]$ tar xf pablo_jmd.tar
435 215 Herve Ballans
[oien@spsc-nso19-12 ~]$ cd pablo_jmd
436 215 Herve Ballans
[oien@spsc-nso19-12 pablo_jmd]$ less PABLO_README.txt
437 215 Herve Ballans
cd ..
438 215 Herve Ballans
mv jmd jmd_old
439 215 Herve Ballans
mv pablo_jmd jmd 
440 215 Herve Ballans
</pre>
441 215 Herve Ballans
442 215 Herve Ballans
h2. JMD Configuration
443 215 Herve Ballans
444 215 Herve Ballans
Configure webserver  to request jsoc_fetch
445 215 Herve Ballans
(following the mail from nilesoien@gmail.com)
446 215 Herve Ballans
447 215 Herve Ballans
config d 'apache2 fichier sdo3.ias.u-psud.fr 
448 215 Herve Ballans
<pre>
449 215 Herve Ballans
450 215 Herve Ballans
<VirtualHost *:80>
451 215 Herve Ballans
        ServerName sdo3.ias.u-psud.fr
452 215 Herve Ballans
        ServerAdmin pablo.alingery@ias.u-psud.fr
453 215 Herve Ballans
        #ErrorLog /var/log/apache2/error.log
454 215 Herve Ballans
        DocumentRoot /var/www
455 215 Herve Ballans
456 215 Herve Ballans
        # Possible values include: debug, info, notice, warn, error, crit,
457 215 Herve Ballans
        # alert, emerg.
458 215 Herve Ballans
        LogLevel debug
459 215 Herve Ballans
460 215 Herve Ballans
        #CustomLog /var/log/apache2/VSO/access.log combined
461 215 Herve Ballans
462 215 Herve Ballans
        Alias /VSO/DRMS/cgi-bin/ "/home/production/netdrms-tools/scripts/cgi-bin/"
463 215 Herve Ballans
464 215 Herve Ballans
        <Location /VSO/DRMS/cgi-bin>
465 215 Herve Ballans
                SetHandler perl-script
466 215 Herve Ballans
                PerlResponseHandler ModPerl::Registry
467 215 Herve Ballans
                PerlOptions +ParseHeaders
468 215 Herve Ballans
                Options +ExecCGI
469 215 Herve Ballans
                Order allow,deny
470 215 Herve Ballans
                Allow from all
471 215 Herve Ballans
        </Location>
472 215 Herve Ballans
</VirtualHost>
473 215 Herve Ballans
474 215 Herve Ballans
</pre>
475 215 Herve Ballans
476 215 Herve Ballans
477 215 Herve Ballans
Execution test cgi with URL :
478 215 Herve Ballans
http://sdo3.ias.u-psud.fr/ VSO/DRMS/cgi-bin/vso_jsoc_fetch.cgi
479 215 Herve Ballans
480 215 Herve Ballans
expected result  :
481 215 Herve Ballans
<pre>
482 215 Herve Ballans
{
483 215 Herve Ballans
   "wait" : 0,
484 215 Herve Ballans
   "requestid" : "",
485 215 Herve Ballans
   "data" : {},
486 215 Herve Ballans
   "method" : "url_quick",
487 215 Herve Ballans
   "size" : 0,
488 215 Herve Ballans
   "errormsg" : "Empty query",
489 215 Herve Ballans
   "protocol" : "as-is",
490 215 Herve Ballans
   "status" : 1,
491 215 Herve Ballans
   "space_ratio" : 0.1,
492 215 Herve Ballans
   "load_ratio" : 0.066875,
493 215 Herve Ballans
   "dir" : "",
494 215 Herve Ballans
   "count" : 0
495 215 Herve Ballans
}
496 215 Herve Ballans
</pre>
497 215 Herve Ballans
498 215 Herve Ballans
499 1 Herve Ballans
h2. NetDRMS tool Install
500 23 Pablo Alingery
501 199 Pablo Alingery
The following installed is based on : [[http://inf-redmine.ias.u-psud.fr/redmine/attachments/download/114/Netdrms_First_Install.odt]]
502 1 Herve Ballans
503 207 Pablo Alingery
The sources are in : http://jsoc.stanford.edu/netdrms/dist/ 
504 207 Pablo Alingery
Locally on sdo-new in  : /home/production/sources
505 1 Herve Ballans
506 199 Pablo Alingery
Symbolic link created 'netdrms_current' that corresponds to the last release
507 1 Herve Ballans
ln -s netdrms_8.10/ netdrms_current 
508 1 Herve Ballans
509 199 Pablo Alingery
Edit file config.local
510 27 Pablo Alingery
<pre>
511 27 Pablo Alingery
cp config.local.template config.local
512 1 Herve Ballans
</pre>
513 29 Pablo Alingery
514 203 Pablo Alingery
%{color:red}Warning WEB_DBUSER      apache  We think that it should value www maybe , to be checked testing the cgi%
515 208 Pablo Alingery
%{color:red}So check the cgi to figure out which user is used to connect to bd%
516 32 Herve Ballans
517 199 Pablo Alingery
Create 2 followings dirs : 
518 1 Herve Ballans
<pre>
519 32 Herve Ballans
mkdir /usr/local/netdrms_8.10/logs/SUM
520 28 Pablo Alingery
mkdir /usr/local/netdrms_8.10/logs/slony
521 27 Pablo Alingery
</pre>
522 1 Herve Ballans
523 205 Pablo Alingery
%{color:red}Warning config.local from line 150 =>222 Remote config to provide data, series to externals%
524 205 Pablo Alingery
%{color:red}To be checked for PLATO%
525 1 Herve Ballans
526 1 Herve Ballans
Création d'un alias netdrms dans /root/.bashrc
527 27 Pablo Alingery
<pre>
528 1 Herve Ballans
alias netdrms='cd /usr/local/netdrms_current'
529 1 Herve Ballans
</pre>
530 31 Pablo Alingery
531 214 Pablo Alingery
532 206 Pablo Alingery
%{color:red}------------------------------------------------------------------------------------------------------------------%
533 206 Pablo Alingery
534 1 Herve Ballans
h3. Modification du fichier /usr/local/netdrms_current/configure (Not Applied in NetDrms_8.10)
535 1 Herve Ballans
536 1 Herve Ballans
<pre>
537 1 Herve Ballans
# The system configuration for configure script
538 1 Herve Ballans
set PERLBIN = "/usr/bin/perl"
539 1 Herve Ballans
set PYBIN = "/usr/bin/python"
540 200 Pablo Alingery
</pre>
541 200 Pablo Alingery
542 34 Herve Ballans
543 34 Herve Ballans
h3. Compilation problem due to uncorrect variable types
544 35 Herve Ballans
545 34 Herve Ballans
Art (art.amezcua@stanford.edu) purpose us a workaround and send us 2 files with correct declaration :
546 42 Herve Ballans
547 42 Herve Ballans
SUMLIB_RmDo.pgc (diff with original file : [[diff_SUMLIB_RmDo.pgc]])
548 34 Herve Ballans
SUMLIB_RmDoX.pgc (diff with original file : [[diff_SUMLIB_RmDoX.pgc]])
549 109 Pablo Alingery
550 109 Pablo Alingery
Dans le répertoire base/sums/libs/pg renommer les anciens en *.orig et placer les nouveau fichiers SUMLIB_RmDo.pgc et SUMLIB_RmDoX.pgc
551 36 Herve Ballans
552 36 Herve Ballans
<pre>
553 36 Herve Ballans
# wget http://jsoc.stanford.edu/~arta/SUMLIB_RmDo.pgc
554 38 Herve Ballans
# wget http://jsoc.stanford.edu/~arta/SUMLIB_RmDoX.pgc
555 34 Herve Ballans
</pre>
556 1 Herve Ballans
557 1 Herve Ballans
h3. Modification du fichier /usr/local/netdrms_current/build/jsoc_machine.csh
558 1 Herve Ballans
559 1 Herve Ballans
ligne 28 :
560 1 Herve Ballans
561 1 Herve Ballans
<pre>
562 1 Herve Ballans
  case "x86_64":
563 1 Herve Ballans
      echo linux_x86_64
564 1 Herve Ballans
      breaksw
565 109 Pablo Alingery
</pre>
566 109 Pablo Alingery
567 109 Pablo Alingery
Overwriting the existing files in the right place (base/sums/libs/pg) & modif in jsoc_machine.csh 
568 109 Pablo Alingery
=> the command 'make' works well.
569 109 Pablo Alingery
570 109 Pablo Alingery
But there is still problem with 'make sums'
571 109 Pablo Alingery
572 109 Pablo Alingery
h3. Workaround to solve make sums problem
573 109 Pablo Alingery
574 109 Pablo Alingery
Modify [[sum_rpc.h]] in order to match the type of some variables
575 109 Pablo Alingery
576 1 Herve Ballans
577 43 Pablo Alingery
578 1 Herve Ballans
h3. Copier /usr/local/netdrms_2.4_release/base/drms/apps/serverdefs.h dans /usr/local/netdrms_current/base/drms/apps (not applied in NetDrms_8.10)
579 44 Pablo Alingery
580 1 Herve Ballans
h3. Modification du fichier /usr/local/netdrms_current/configure (not applied in NetDrms_8.10)
581 1 Herve Ballans
582 1 Herve Ballans
au lieu de $? en csh on va mettre plutot $status
583 1 Herve Ballans
584 61 Herve Ballans
ligne 110 :
585 61 Herve Ballans
586 61 Herve Ballans
<pre>
587 61 Herve Ballans
  if ($status==0) 
588 61 Herve Ballans
</pre>
589 117 Pablo Alingery
590 112 Herve Ballans
et ligne 123 :
591 115 Pablo Alingery
592 115 Pablo Alingery
<pre>
593 115 Pablo Alingery
  if ($status==0) 
594 116 Pablo Alingery
</pre>
595 116 Pablo Alingery
596 115 Pablo Alingery
Lancement :
597 115 Pablo Alingery
<pre>
598 115 Pablo Alingery
./configure
599 115 Pablo Alingery
</pre>
600 115 Pablo Alingery
601 115 Pablo Alingery
h3. Installation des libraries libtar-dev, libcurl3-dev et libecpg-dev
602 115 Pablo Alingery
603 115 Pablo Alingery
<pre>
604 115 Pablo Alingery
apt-get install libtar libtar-dev
605 115 Pablo Alingery
</pre>
606 115 Pablo Alingery
607 115 Pablo Alingery
<pre>
608 1 Herve Ballans
apt-get install libcurl3-dev
609 1 Herve Ballans
</pre>
610 116 Pablo Alingery
611 116 Pablo Alingery
<pre>
612 116 Pablo Alingery
apt-get install libecpg-dev
613 115 Pablo Alingery
</pre>
614 116 Pablo Alingery
615 115 Pablo Alingery
h3. #H4ck 2 Malade #PabloR0cks# (Not Applied in NetDrm_8.10)
616 112 Herve Ballans
617 119 Pablo Alingery
Modification du fichier /usr/include/stdint.h
618 112 Herve Ballans
619 112 Herve Ballans
ligne 55 : long int remplacé par long long int
620 112 Herve Ballans
621 112 Herve Ballans
<pre>
622 113 Pablo Alingery
#if __WORDSIZE == 64
623 113 Pablo Alingery
typedef unsigned long int       uint64_t; --> ici long long int
624 113 Pablo Alingery
#else
625 113 Pablo Alingery
__extension__
626 113 Pablo Alingery
typedef unsigned long long int  uint64_t;
627 113 Pablo Alingery
#endif
628 113 Pablo Alingery
</pre>
629 113 Pablo Alingery
630 113 Pablo Alingery
"Allo Linus ?!?.."
631 113 Pablo Alingery
632 113 Pablo Alingery
h3. Compilation
633 113 Pablo Alingery
634 113 Pablo Alingery
<pre>
635 113 Pablo Alingery
# make
636 113 Pablo Alingery
# make sums
637 113 Pablo Alingery
# make jsoc_fetch
638 113 Pablo Alingery
</pre>
639 113 Pablo Alingery
640 113 Pablo Alingery
NB : lib64 does not exist on debian 8. so ln -s /usr/lib lib64
641 113 Pablo Alingery
642 113 Pablo Alingery
h2. make sums KO  (Not applied in NetDrms_8.10)
643 113 Pablo Alingery
644 113 Pablo Alingery
Solution found : Take old lib libcrypto instead libssl
645 113 Pablo Alingery
646 113 Pablo Alingery
dans le fichier base/sums/apps/Rules.mk ligne 51 
647 112 Herve Ballans
replace -lssl by -lcrypto LD flag
648 112 Herve Ballans
649 112 Herve Ballans
h2. NetDRMS replication
650 112 Herve Ballans
651 1 Herve Ballans
<pre>
652 120 Pablo Alingery
# cd base/drms/replication/etc
653 1 Herve Ballans
# scp production@sdo:/usr/local/netdrms/install-config-files/ias.subscribe_list.cfg  .
654 112 Herve Ballans
# scp production@sdo:/usr/local/netdrms/install-config-files/ias.repclient.cfg  .
655 120 Pablo Alingery
WRONG !!!!!
656 112 Herve Ballans
To be done cp repclient.template.cfg into ias.subscribe_list.cfg because new field in config file can't appear 
657 112 Herve Ballans
Correct that step in NetDrms doc 
658 112 Herve Ballans
The existing ias.repclient.cfg can be used tough to fill params 
659 112 Herve Ballans
660 112 Herve Ballans
661 112 Herve Ballans
</pre>
662 112 Herve Ballans
663 112 Herve Ballans
664 112 Herve Ballans
Create tmp dir in netdrms working directory (/usr/local/netdrms_current)
665 112 Herve Ballans
<pre>
666 112 Herve Ballans
# mkdir tmp
667 112 Herve Ballans
</pre>
668 112 Herve Ballans
669 112 Herve Ballans
Prevent from deleting files
670 112 Herve Ballans
<pre>
671 112 Herve Ballans
cd logs/SUM ; scp production@sdo:/usr/local/netdrms/install-config-files/sum_rm.cfg .
672 91 Herve Ballans
</pre>
673 91 Herve Ballans
674 91 Herve Ballans
h2. NetDRMS Start script
675 91 Herve Ballans
676 91 Herve Ballans
<pre>
677 91 Herve Ballans
sum_start.NetDRMS
678 91 Herve Ballans
</pre>
679 91 Herve Ballans
680 91 Herve Ballans
h2. Database repair (from Art)
681 91 Herve Ballans
682 91 Herve Ballans
On ias_sdo
683 91 Herve Ballans
684 91 Herve Ballans
<pre>
685 91 Herve Ballans
delete from admin.ns where name = 'lm_jps';
686 91 Herve Ballans
delete from admin.ns where name = 'aia_test';
687 91 Herve Ballans
</pre>
688 93 Pablo Alingery
689 93 Pablo Alingery
h2. Private key Public key generation 
690 93 Pablo Alingery
691 93 Pablo Alingery
<pre>
692 93 Pablo Alingery
ssh-keygen -t rsa
693 93 Pablo Alingery
</pre>
694 103 Herve Ballans
695 103 Herve Ballans
Not necessary cause we recover the ssh keys of the current server.
696 103 Herve Ballans
697 103 Herve Ballans
However, we have to retrieve the private key of production account on sdo3
698 103 Herve Ballans
699 103 Herve Ballans
From sdo :
700 103 Herve Ballans
<pre>
701 103 Herve Ballans
rsync -av id_rsa production@sdo3:/home/production/.ssh/
702 103 Herve Ballans
</pre>
703 94 Herve Ballans
704 94 Herve Ballans
h2. Node definition
705 94 Herve Ballans
706 94 Herve Ballans
file : /usr/local/netdrms_current/base/drms/replication/etc/ias.repclient.cfg
707 94 Herve Ballans
708 94 Herve Ballans
<pre>
709 1 Herve Ballans
node=IAStest
710 96 Herve Ballans
</pre>
711 96 Herve Ballans
712 96 Herve Ballans
h2. show_series and delete_series binaries
713 96 Herve Ballans
714 97 Pablo Alingery
Remark : these 2 sources are not compiled during installation
715 96 Herve Ballans
Issue : in netdrms_current 8.10 , do :
716 96 Herve Ballans
$ make delete_series
717 94 Herve Ballans
$ make show_series
718 98 Pablo Alingery
719 1 Herve Ballans
h2. SSH-HPN install 
720 98 Pablo Alingery
721 1 Herve Ballans
Intallation de openssh 6.3p1 car le dernier patch hpn dispo est 6.3hpn13.V6 
722 99 Herve Ballans
723 99 Herve Ballans
web site for open ssh : http://ftp2.fr.openbsd.org/pub/OpenBSD/OpenSSH/portable/openssh-6.3p1.tar.gz
724 1 Herve Ballans
patch hpn : http://www.psc.edu/index.php/hpn-ssh-patches/hpn-14-kitchen-sink-patches/viewdownload/24-hpn-14-kitchen-sink-patches/102-openssh-6-3p1-hpnssh14v2-kitchen-sink-patch
725 99 Herve Ballans
726 99 Herve Ballans
<pre>
727 99 Herve Ballans
# tar -xzvf openssh-6.3p1.tar.gz
728 99 Herve Ballans
# gunzip openssh-6.3p1-hpnssh14v2.diff.gz
729 99 Herve Ballans
# cd openssh-6.3p1
730 99 Herve Ballans
# zcat ../openssh-6.3p1-hpnssh14v2.diff.gz | patch -p1
731 99 Herve Ballans
# ./configure --prefix=/usr/local/hpn-ssh --with-pam --with-md5-passwords --without-zlib-version-check --with-tcp-wrappers
732 99 Herve Ballans
# make
733 99 Herve Ballans
# make install
734 1 Herve Ballans
</pre>
735 99 Herve Ballans
736 99 Herve Ballans
Depuis sdo :
737 99 Herve Ballans
<pre>
738 99 Herve Ballans
# cd /usr/local/hpn-ssh/etc/
739 99 Herve Ballans
# rsync -av *key* netadm@sdo3:/home/netadm/
740 99 Herve Ballans
</pre>
741 99 Herve Ballans
742 99 Herve Ballans
Sur sdo3 :
743 1 Herve Ballans
<pre>
744 100 Herve Ballans
rsync -av /home/netadm/*key* /usr/local/hpn-ssh/etc/
745 100 Herve Ballans
</pre>
746 100 Herve Ballans
747 100 Herve Ballans
We have to configure the port number to 55000
748 100 Herve Ballans
<pre>
749 100 Herve Ballans
# vi ssh_config
750 100 Herve Ballans
</pre>
751 101 Herve Ballans
752 100 Herve Ballans
and add :
753 100 Herve Ballans
<pre>
754 100 Herve Ballans
#Port 22
755 100 Herve Ballans
Port 55000
756 1 Herve Ballans
</pre>
757 101 Herve Ballans
758 100 Herve Ballans
We configure also the server hpn (even we don't use it yet)
759 100 Herve Ballans
<pre>
760 100 Herve Ballans
# vi sshd_config
761 100 Herve Ballans
</pre>
762 100 Herve Ballans
763 100 Herve Ballans
and add :
764 100 Herve Ballans
<pre>
765 100 Herve Ballans
#Port 22
766 100 Herve Ballans
Port 55000
767 100 Herve Ballans
768 100 Herve Ballans
#PidFile /var/run/sshd.pid
769 100 Herve Ballans
PidFile /var/run/sshd.55000.pid
770 100 Herve Ballans
771 100 Herve Ballans
# allow the use of the none cipher
772 100 Herve Ballans
#NoneEnabled no
773 99 Herve Ballans
NoneEnabled yes
774 98 Pablo Alingery
</pre>
775 106 Pablo Alingery
776 105 Pablo Alingery
h2. Correction
777 105 Pablo Alingery
778 105 Pablo Alingery
h3. Modification du fichier ias.repclient.cfg
779 105 Pablo Alingery
780 105 Pablo Alingery
Copier le template existant repclient.template.cfg dans le répertoire [netdrms_current]/base/drms/replication/etc
781 105 Pablo Alingery
 
782 105 Pablo Alingery
<pre>
783 105 Pablo Alingery
production@sdo3:/usr/local/netdrms_current/base/drms/replication/etc$ cp repclient.template.cfg ias.repclient.cfg
784 105 Pablo Alingery
</pre>
785 1 Herve Ballans
786 106 Pablo Alingery
Nouveau / netdrms2.4 
787 105 Pablo Alingery
<pre>
788 105 Pablo Alingery
# Apps
789 106 Pablo Alingery
kRSPerl=<path to Perl binary to use when Perl scripts are executed>
790 105 Pablo Alingery
</pre>
791 107 Pablo Alingery
792 107 Pablo Alingery
h2. Subscription test 
793 107 Pablo Alingery
794 107 Pablo Alingery
h3. Librairies manquantes
795 107 Pablo Alingery
796 107 Pablo Alingery
Errors 
797 107 Pablo Alingery
<pre>
798 107 Pablo Alingery
Failure to apply SQL file 'IAStest.subscribe_series.sql' from server: ABORTING!
799 107 Pablo Alingery
Can't locate DBI.pm 
800 107 Pablo Alingery
.
801 107 Pablo Alingery
.
802 107 Pablo Alingery
.
803 107 Pablo Alingery
Failure to apply SQL file 'IAStest.subscribe_series.sql' from server: ABORTING!
804 107 Pablo Alingery
Can't locate DBD/Pg.pm
805 107 Pablo Alingery
</pre>
806 1 Herve Ballans
807 1 Herve Ballans
<pre>
808 1 Herve Ballans
root@sdo3:/usr/local/netdrms_8.10/base/drms/replication/subscribe_series# apt-get install libdbi-perl 
809 1 Herve Ballans
root@sdo3:/usr/local/netdrms_8.10/base/drms/replication/subscribe_series# apt-get install libdbd-pg-perl
810 1 Herve Ballans
</pre>
811 110 Herve Ballans
812 110 Herve Ballans
h3. Series souscrites
813 110 Herve Ballans
814 110 Herve Ballans
hmi.sharp_720s_nrt
815 110 Herve Ballans
hmi.mharp_720s_nrt
816 110 Herve Ballans
hmi.bharp_720s_nrt
817 110 Herve Ballans
818 110 Herve Ballans
<pre>
819 110 Herve Ballans
production@sdo3:~$ show_info -s hmi.sharp_720s_nrt
820 110 Herve Ballans
First Record: hmi.sharp_720s_nrt[476][2012.09.14_02:12:00_TAI], Recnum = 829707
821 110 Herve Ballans
Last Record:  hmi.sharp_720s_nrt[4943][2016.03.22_18:24:00_TAI], Recnum = 2015202
822 110 Herve Ballans
Last Recnum:  2015202
823 110 Herve Ballans
Has shadow table: no
824 107 Pablo Alingery
</pre>
825 111 Herve Ballans
826 111 Herve Ballans
h3. Lancement de jetty
827 111 Herve Ballans
828 111 Herve Ballans
<pre>
829 111 Herve Ballans
$ jetty.sh start
830 111 Herve Ballans
</pre>
831 111 Herve Ballans
832 111 Herve Ballans
833 111 Herve Ballans
834 108 Pablo Alingery
835 108 Pablo Alingery
h2. Test recuperation de meta data 
836 108 Pablo Alingery
837 108 Pablo Alingery
librairies manquantes 
838 108 Pablo Alingery
apt-get install libnet-ssh-perl
839 108 Pablo Alingery
apt-get install libstring-shellquote-perl
840 108 Pablo Alingery
841 152 Pablo Alingery
h2. TO BE DONE FURTHER
842 108 Pablo Alingery
843 107 Pablo Alingery
844 152 Pablo Alingery
%{color:red} configure sytem nbr de fichier ouvert en meme temps%
845 1 Herve Ballans
846 152 Pablo Alingery
%{color:red} configure sytem taille  buffer%
847 152 Pablo Alingery
848 155 Pablo Alingery
%{color:red} swap désactivé ? discussion Stephane et Gilles%
849 152 Pablo Alingery
850 80 Pablo Alingery
851 1 Herve Ballans
h3. Modification du fichir config.local pour la souscription au jsoc
852 1 Herve Ballans
853 1 Herve Ballans
854 1 Herve Ballans
<pre>
855 1 Herve Ballans
# NetDRMS users can request subdirectories from the Stanford proj directories 
856 1 Herve Ballans
# (e.g., JSOC/proj/util). These users will need to contact Stanford and obtain
857 1 Herve Ballans
# the source subdirectories desired. They will then place these subdirectories
858 1 Herve Ballans
# in the JSOC/proj directory of their NetDRMS release. To properly build 
859 1 Herve Ballans
# targets in these subdirectories, using the JSOC make system, the user needs
860 1 Herve Ballans
# to add entries to this configuration file - one entry for each subdirectory
861 1 Herve Ballans
# that contains source code to be compiled. Each entry is a space-separated pair
862 1 Herve Ballans
# of strings: the string "PROJDIR" followed by a subdirectory (of the proj 
863 1 Herve Ballans
# directory).  For example:
864 1 Herve Ballans
#
865 1 Herve Ballans
# PROJDIR     util/apps
866 1 Herve Ballans
# PROJDIR     util/libs
867 1 Herve Ballans
# 
868 1 Herve Ballans
# NOTE: It is not sufficient to list only a parent directory, like util. Source code
869 18 Herve Ballans
# in child directories will not automatically be compiled.
870 18 Herve Ballans
</pre>
871 18 Herve Ballans
872 18 Herve Ballans
h3. Python library for multi-threaded SUMS
873 1 Herve Ballans
874 1 Herve Ballans
Installation de la librairie python3.4m