1
|
Installation:
|
2
|
Check out svn:
|
3
|
svn co https://code.nceas.ucsb.edu/code/projects/bien/trunk bien
|
4
|
cd bien/
|
5
|
Install: make install
|
6
|
**WARNING**: This will delete the public schema of your VegBIEN DB!
|
7
|
Uninstall: make uninstall
|
8
|
**WARNING**: This will delete your entire VegBIEN DB!
|
9
|
This includes all archived imports and staging tables.
|
10
|
|
11
|
Connecting to vegbiendev:
|
12
|
ssh -t vegbiendev.nceas.ucsb.edu exec sudo -u aaronmk -i
|
13
|
cd /home/bien # should happen automatically at login
|
14
|
|
15
|
Single datasource refresh:
|
16
|
ssh -t vegbiendev.nceas.ucsb.edu exec sudo -u aaronmk -i
|
17
|
# -> Maintenance > to back up the vegbiendev databases
|
18
|
# place updated extract in inputs/ACAD/_src/
|
19
|
# place extracted flat file(s) in the appropriate table subdirs
|
20
|
rm=1 inputs/<datasrc>/run # reload staging tables
|
21
|
make inputs/<datasrc>/reimport_scrub by_col=1 &
|
22
|
# this works whether or not datasource is already imported
|
23
|
tail -150 inputs/<datasrc>/*/logs/public.log.sql # view progress
|
24
|
# -> Full database import > To re-run geoscrubbing
|
25
|
# -> Full database import > To remake analytical DB
|
26
|
# -> Maintenance > to back up the vegbiendev databases
|
27
|
|
28
|
Notes on system stability:
|
29
|
**WARNING**: when shutting down the VM, always first stop Postgres:
|
30
|
sudo service postgresql stop
|
31
|
this prevents the OS from SIGKILLing Postgres, which sometimes causes
|
32
|
database corruption
|
33
|
**WARNING**: system upgrades can break key parts of the full-database
|
34
|
import, causing errors such as disk space overruns. for this reason, it
|
35
|
is recommended to maintain a snapshot copy of the VM as it was at the
|
36
|
last successful import, for fallback use if a system upgrade breaks
|
37
|
anything. system upgrades on the snapshot VM should be disabled
|
38
|
completely, and because this will also disable security fixes, the
|
39
|
snapshot VM should be disconnected from the internet and all networking
|
40
|
interfaces. (this is an unfortunate consequence of modern OSes being
|
41
|
written in non-memory-safe languages such as C and C++.)
|
42
|
|
43
|
Notes on running programs:
|
44
|
**WARNING**: always start with a clean shell, to avoid spurious bugs. the
|
45
|
shell should not have changes to the env vars. (there have been bugs
|
46
|
that went away after closing and reopening the terminal window.) note
|
47
|
that running `exec bash` is not sufficient to *reset* the env vars.
|
48
|
|
49
|
Notes on editing files:
|
50
|
**WARNING**: shell scripts should always be read-only, so that editing them
|
51
|
while an import is in progress will not crash the import (see
|
52
|
http://vegpath.org/links/#**%20modifying%20a%20running%20shell%20script)
|
53
|
|
54
|
Full database import:
|
55
|
**WARNING**: You must perform *every single* step listed below, to avoid
|
56
|
breaking column-based import
|
57
|
**WARNING**: always start with a clean shell, as described above under
|
58
|
"Notes on running programs"
|
59
|
**IMPORTANT**: the beginning of the import should be scheduled at a time
|
60
|
when the DB will not be needed for other uses. this is necessary because
|
61
|
vegbiendev will be slow for the first few hours of the import, due to
|
62
|
the import using all the available cores.
|
63
|
do steps under Maintenance > "to synchronize vegbiendev, jupiter, and
|
64
|
your local machine"
|
65
|
On local machine:
|
66
|
make inputs/upload
|
67
|
make inputs/upload live=1
|
68
|
make test by_col=1 # runtime: 1 h ("53m7.383s") @starscream
|
69
|
if you encounter errors, they are most likely related to the
|
70
|
PostgreSQL error parsing in /lib/sql.py parse_exception()
|
71
|
See note under Testing below
|
72
|
ssh -t vegbiendev.nceas.ucsb.edu exec sudo -u aaronmk -i
|
73
|
Ensure there are no local modifications: svn st
|
74
|
up
|
75
|
make inputs/download
|
76
|
make inputs/download live=1
|
77
|
For each newly-uploaded datasource above: make inputs/<datasrc>/reinstall
|
78
|
Update the auxiliary schemas: make schemas/reinstall
|
79
|
**WARNING**: requires sudo access!
|
80
|
The public schema will be installed separately by the import process
|
81
|
Delete imports before the last so they won't bloat the full DB backup:
|
82
|
make backups/vegbien.<version>.backup/remove
|
83
|
To keep a previous import other than the public schema:
|
84
|
export dump_opts='--exclude-schema=public --exclude-schema=<version>'
|
85
|
# env var will be inherited by `screen` shell
|
86
|
restart Postgres to free up any disk space used by temp tables from the last
|
87
|
import (this is apparently not automatically reclaimed):
|
88
|
make postgres_restart
|
89
|
Make sure there is at least 1 TB of disk space on /: df -h
|
90
|
although the import schema itself is only 315 GB, Postgres uses
|
91
|
significant temporary space at the beginning of the import.
|
92
|
the total disk usage oscillates between 1.2 TB and the entire disk
|
93
|
for the first day (for import started @12:55:09, high-water marks of
|
94
|
1.7 TB @14:00:25, 1.8 TB @15:38:32; then next day w/ 2 datasources
|
95
|
running: entire disk for 4 min @05:35:44, 1.8 TB @11:15:05).
|
96
|
To free up space, remove backups that have been archived on jupiter:
|
97
|
List backups/ to view older backups
|
98
|
Check their MD5 sums using the steps under On jupiter below
|
99
|
Remove these backups
|
100
|
for full import:
|
101
|
screen
|
102
|
Press ENTER
|
103
|
$0 # nested shell to prevent errexit from closing the window
|
104
|
the following must happen within screen to avoid affecting the outer shell:
|
105
|
unset TMOUT # TMOUT causes shell to exit even with background processes
|
106
|
set -o ignoreeof # prevent Ctrl+D from exiting shell to keep attached jobs
|
107
|
on local machine:
|
108
|
unset n # clear any limit set in .profile (unless desired)
|
109
|
unset log # allow logging output to go to log files
|
110
|
unset version # clear any version from last import, etc.
|
111
|
if no commits have been made since the last import (eg. if retrying an
|
112
|
import), set a custom version that differs from the auto-assigned one
|
113
|
(would otherwise cause a collision with the last import):
|
114
|
svn info
|
115
|
extract the svn revision after "Revision:"
|
116
|
export version=r[revision]_2 # +suffix to distinguish from last import
|
117
|
# env var will be inherited by `screen` shell
|
118
|
to import just a subset of the datasources:
|
119
|
declare -ax inputs; inputs=(inputs/{src,...}/) # no () in declare on Mac
|
120
|
# array vars *not* inherited by `screen` shell
|
121
|
export version=custom_import_name
|
122
|
Start column-based import: . bin/import_all
|
123
|
To use row-based import: . bin/import_all by_col=
|
124
|
To stop all running imports: . bin/stop_imports
|
125
|
**WARNING**: Do NOT run import_all in the background, or the jobs it
|
126
|
creates won't be owned by your shell.
|
127
|
Note that import_all will take up to an hour to import the NCBI backbone
|
128
|
and other metadata before returning control to the shell.
|
129
|
To view progress:
|
130
|
tail inputs/{.,}??*/*/logs/$version.log.sql
|
131
|
note: at the beginning of the import, the system may send out CPU load
|
132
|
warning e-mails. these can safely be ignored. (they happen because the
|
133
|
parallel imports use all the available cores.)
|
134
|
for test import, turn off DB backup (also turns off analytical DB creation):
|
135
|
kill % # cancel after_import()
|
136
|
Wait (4 days) for the import to finish
|
137
|
**WARNING**: do *not* run backups/pg_snapshot while the import is running,
|
138
|
due to continuously-changing files
|
139
|
**WARNING**: do *not* run backups/pg_snapshot until the previous import has
|
140
|
been replaced, to avoid running into disk space limits
|
141
|
To recover from a closed terminal window: screen -r
|
142
|
To restart an aborted import for a specific table:
|
143
|
export version=<version>
|
144
|
(set -o errexit; make inputs/<datasrc>/<table>/import_scrub by_col=1 continue=1; make inputs/<datasrc>/publish) &
|
145
|
bin/after_import $! & # $! can also be obtained from `jobs -l`
|
146
|
Get $version: echo $version
|
147
|
Set $version in all vegbiendev terminals: export version=<version>
|
148
|
When there are no more running jobs, exit `screen`: exit # not Ctrl+D
|
149
|
upload logs: make inputs/upload live=1
|
150
|
On local machine: make inputs/download-logs live=1
|
151
|
check for disk space errors:
|
152
|
grep --files-with-matches -F 'No space left on device' inputs/{.,}??*/*/logs/$version.log.sql
|
153
|
if there are any matches:
|
154
|
manually reimport these datasources using the steps under
|
155
|
Single datasource import
|
156
|
bin/after_import &
|
157
|
wait for the import to finish
|
158
|
tail inputs/{.,}??*/*/logs/$version.log.sql
|
159
|
In the output, search for "Command exited with non-zero status"
|
160
|
For inputs that have this, fix the associated bug(s)
|
161
|
If many inputs have errors, discard the current (partial) import:
|
162
|
make schemas/$version/uninstall
|
163
|
Otherwise, continue
|
164
|
In PostgreSQL:
|
165
|
Go to wiki.vegpath.org/VegBIEN_contents
|
166
|
Get the # observations
|
167
|
Get the # datasources
|
168
|
Get the # datasources with observations
|
169
|
in the r# schema:
|
170
|
Check that analytical_stem contains [# observations] rows
|
171
|
Check that source contains [# datasources] rows up through XAL. If this
|
172
|
is not the case, manually check the entries in source against the
|
173
|
datasources list on the wiki page (some datasources may be near the
|
174
|
end depending on import order).
|
175
|
Check that provider_count contains [# datasources with observations]
|
176
|
rows with dataset="(total)" (at the top when the table is unsorted)
|
177
|
Check that TNRS ran successfully:
|
178
|
tail -100 inputs/.TNRS/tnrs/logs/tnrs.make.log.sql
|
179
|
If the log ends in an AssertionError
|
180
|
"assert sql.table_col_names(db, table) == header":
|
181
|
Figure out which TNRS CSV columns have changed
|
182
|
On local machine:
|
183
|
Make the changes in the DB's TNRS and public schemas
|
184
|
rm=1 inputs/.TNRS/schema.sql.run export_
|
185
|
make schemas/remake
|
186
|
inputs/test_taxonomic_names/test_scrub # re-run TNRS
|
187
|
rm=1 inputs/.TNRS/data.sql.run export_
|
188
|
Commit
|
189
|
ssh -t vegbiendev.nceas.ucsb.edu exec sudo -u aaronmk -i
|
190
|
If dropping a column, save the dependent views
|
191
|
Make the same changes in the live TNRS.tnrs table on vegbiendev
|
192
|
If dropping a column, recreate the dependent views
|
193
|
Restart the TNRS client: make scrub by_col=1 &
|
194
|
Publish the new import:
|
195
|
**WARNING**: Before proceeding, be sure you have done *every single*
|
196
|
verification step listed above. Otherwise, a previous valid import
|
197
|
could incorrectly be overwritten with a broken one.
|
198
|
make schemas/$version/publish # runtime: 1 min ("real 1m10.451s")
|
199
|
unset version
|
200
|
make backups/upload live=1
|
201
|
on local machine:
|
202
|
make backups/vegbien.$version.backup/download live=1
|
203
|
# download backup to local machine
|
204
|
ssh aaronmk@jupiter.nceas.ucsb.edu
|
205
|
cd /data/dev/aaronmk/bien/backups
|
206
|
For each newly-archived backup:
|
207
|
make -s <backup>.md5/test
|
208
|
Check that "OK" is printed next to the filename
|
209
|
If desired, record the import times in inputs/import.stats.xls:
|
210
|
On local machine:
|
211
|
Open inputs/import.stats.xls
|
212
|
If the rightmost import is within 5 columns of column IV:
|
213
|
Copy the current tab to <leftmost-date>~<rightmost-date>
|
214
|
Remove the previous imports from the current tab because they are
|
215
|
now in the copied tab instead
|
216
|
Insert a copy of the leftmost "By column" column group before it
|
217
|
export version=<version>
|
218
|
bin/import_date inputs/{.,}??*/*/logs/$version.log.sql
|
219
|
Update the import date in the upper-right corner
|
220
|
bin/import_times inputs/{.,}??*/*/logs/$version.log.sql
|
221
|
Paste the output over the # Rows/Time columns, making sure that the
|
222
|
row counts match up with the previous import's row counts
|
223
|
If the row counts do not match up, insert or reorder rows as needed
|
224
|
until they do. Get the datasource names from the log file footers:
|
225
|
tail inputs/{.,}??*/*/logs/$version.log.sql
|
226
|
Commit: svn ci -m 'inputs/import.stats.xls: updated import times'
|
227
|
Running individual steps separately:
|
228
|
To run TNRS:
|
229
|
To use an import other than public: export version=<version>
|
230
|
to rescrub all names:
|
231
|
make inputs/.TNRS/reinstall
|
232
|
re-create public-schema views that were cascadingly deleted
|
233
|
make scrub &
|
234
|
To view progress:
|
235
|
tail -100 inputs/.TNRS/tnrs/logs/tnrs.make.log.sql
|
236
|
To re-run geoscrubbing:
|
237
|
$ screen
|
238
|
# press Enter
|
239
|
# to use an import other than public: $ export version=<version>
|
240
|
$ bin/psql_verbose_vegbien <<<'SELECT geoscrub_input_view_modify();' &
|
241
|
# runtime: 8 min ("7:40.54") @r14089 @vegbiendev
|
242
|
# wait until done
|
243
|
$ rm=1 exports/geoscrub_input.csv.run
|
244
|
# runtime: 25 s ("0m24.936s") @r14089 @vegbiendev
|
245
|
$ rm=1 inputs/.geoscrub/geoscrub_output/geoscrub.csv.run &
|
246
|
# runtime: 2.5 h
|
247
|
# wait until done
|
248
|
$ rm=1 inputs/.geoscrub/run &
|
249
|
# runtime: 15 min ("16m34.052s") @r14089 @vegbiendev
|
250
|
# wait until done
|
251
|
# re-create public-schema views that were cascadingly deleted
|
252
|
# press Ctrl+D
|
253
|
# remake the analytical DB (below)
|
254
|
To remake analytical DB:
|
255
|
To use an import other than public: export version=<version>
|
256
|
bin/make_analytical_db & # runtime: 13 h ("12:43:57elapsed")
|
257
|
To view progress:
|
258
|
tail -150 inputs/analytical_db/logs/make_analytical_db.log.sql
|
259
|
To back up DB (staging tables and last import):
|
260
|
To use an import *other than public*: export version=<version>
|
261
|
make backups/TNRS.backup-remake &
|
262
|
dump_opts=--exclude-schema=public make backups/vegbien.$version.backup/test &
|
263
|
If after renaming to public, instead set dump_opts='' and replace
|
264
|
$version with the appropriate revision
|
265
|
make backups/upload live=1
|
266
|
|
267
|
Datasource setup:
|
268
|
On local machine:
|
269
|
Example steps for a datasource: wiki.vegpath.org/Import_process_for_Madidi
|
270
|
umask ug=rwx,o= # prevent files from becoming web-accessible
|
271
|
Add a new datasource: make inputs/<datasrc>/add
|
272
|
<datasrc> may not contain spaces, and should be abbreviated.
|
273
|
If the datasource is a herbarium, <datasrc> should be the herbarium code
|
274
|
as defined by the Index Herbariorum <http://sweetgum.nybg.org/ih/>
|
275
|
For a new-style datasource (one containing a ./run runscript):
|
276
|
"cp" -f inputs/.NCBI/{Makefile,run,table.run} inputs/<datasrc>/
|
277
|
For MySQL inputs (exports and live DB connections):
|
278
|
For .sql exports:
|
279
|
Place the original .sql file in _src/ (*not* in _MySQL/)
|
280
|
Follow the steps starting with Install the staging tables below.
|
281
|
This is for an initial sync to get the file onto vegbiendev.
|
282
|
ssh -t vegbiendev.nceas.ucsb.edu exec sudo -u aaronmk -i
|
283
|
Create a database for the MySQL export in phpMyAdmin
|
284
|
Give the bien user all database-specific privileges *except*
|
285
|
UPDATE, DELETE, ALTER, DROP. This prevents bugs in the
|
286
|
import scripts from accidentally deleting data.
|
287
|
bin/mysql_bien database <inputs/<datasrc>/_src/export.sql &
|
288
|
mkdir inputs/<datasrc>/_MySQL/
|
289
|
cp -p lib/MySQL.{data,schema}.sql.make inputs/<datasrc>/_MySQL/
|
290
|
Edit _MySQL/*.make for the DB connection
|
291
|
For a .sql export, use server=vegbiendev and --user=bien
|
292
|
Skip the Add input data for each table section
|
293
|
For MS Access databases:
|
294
|
Place the .mdb or .accdb file in _src/
|
295
|
Download and install Bullzip's MS Access to PostgreSQL from
|
296
|
http://bullzip.com/download.php > Access To PostgreSQL > Download
|
297
|
Use Access To PostgreSQL to export the database:
|
298
|
Export just the tables/indexes to inputs/<datasrc>/<file>.schema.sql
|
299
|
using the settings in the associated .ini file where available
|
300
|
Export just the data to inputs/<datasrc>/<file>.data.sql using the
|
301
|
settings in the associated .ini file where available
|
302
|
In <file>.schema.sql, make the following changes:
|
303
|
Replace text "BOOLEAN" with "/*BOOLEAN*/INTEGER"
|
304
|
Replace text "DOUBLE PRECISION NULL" with "DOUBLE PRECISION"
|
305
|
Skip the Add input data for each table section
|
306
|
Add input data for each table present in the datasource:
|
307
|
For .sql exports, you must use the name of the table in the DB export
|
308
|
For CSV files, you can use any name. It's recommended to use a table
|
309
|
name from <https://projects.nceas.ucsb.edu/nceas/projects/bien/wiki/VegCSV#Suggested-table-names>
|
310
|
Note that if this table will be joined together with another table, its
|
311
|
name must end in ".src"
|
312
|
make inputs/<datasrc>/<table>/add
|
313
|
Important: DO NOT just create an empty directory named <table>!
|
314
|
This command also creates necessary subdirs, such as logs/.
|
315
|
If the table is in a .sql export: make inputs/<datasrc>/<table>/install
|
316
|
Otherwise, place the CSV(s) for the table in
|
317
|
inputs/<datasrc>/<table>/ OR place a query joining other tables
|
318
|
together in inputs/<datasrc>/<table>/create.sql
|
319
|
Important: When exporting relational databases to CSVs, you MUST ensure
|
320
|
that embedded quotes are escaped by doubling them, *not* by
|
321
|
preceding them with a "\" as is the default in phpMyAdmin
|
322
|
If there are multiple part files for a table, and the header is repeated
|
323
|
in each part, make sure each header is EXACTLY the same.
|
324
|
(If the headers are not the same, the CSV concatenation script
|
325
|
assumes the part files don't have individual headers and treats the
|
326
|
subsequent headers as data rows.)
|
327
|
Add <table> to inputs/<datasrc>/import_order.txt before other tables
|
328
|
that depend on it
|
329
|
For a new-style datasource:
|
330
|
"cp" -f inputs/.NCBI/nodes/run inputs/<datasrc>/<table>/
|
331
|
inputs/<datasrc>/<table>/run
|
332
|
Install the staging tables:
|
333
|
make inputs/<datasrc>/reinstall quiet=1 &
|
334
|
For a MySQL .sql export:
|
335
|
At prompt "[you]@vegbiendev's password:", enter your password
|
336
|
At prompt "Enter password:", enter the value in config/bien_password
|
337
|
To view progress: tail -f inputs/<datasrc>/<table>/logs/install.log.sql
|
338
|
View the logs: tail -n +1 inputs/<datasrc>/*/logs/install.log.sql
|
339
|
tail provides a header line with the filename
|
340
|
+1 starts at the first line, to show the whole file
|
341
|
For every file with an error 'column "..." specified more than once':
|
342
|
Add a header override file "+header.<ext>" in <table>/:
|
343
|
Note: The leading "+" should sort it before the flat files.
|
344
|
"_" unfortunately sorts *after* capital letters in ASCII.
|
345
|
Create a text file containing the header line of the flat files
|
346
|
Add an ! at the beginning of the line
|
347
|
This signals cat_csv that this is a header override.
|
348
|
For empty names, use their 0-based column # (by convention)
|
349
|
For duplicate names, add a distinguishing suffix
|
350
|
For long names that collided, rename them to <= 63 chars long
|
351
|
Do NOT make readability changes in this step; that is what the
|
352
|
map spreadsheets (below) are for.
|
353
|
Save
|
354
|
If you made any changes, re-run the install command above
|
355
|
Auto-create the map spreadsheets: make inputs/<datasrc>/
|
356
|
Map each table's columns:
|
357
|
In each <table>/ subdir, for each "via map" map.csv:
|
358
|
Open the map in a spreadsheet editor
|
359
|
Open the "core map" /mappings/Veg+-VegBIEN.csv
|
360
|
In each row of the via map, set the right column to a value from the
|
361
|
left column of the core map
|
362
|
Save
|
363
|
Regenerate the derived maps: make inputs/<datasrc>/
|
364
|
Accept the test cases:
|
365
|
For a new-style datasource:
|
366
|
inputs/<datasrc>/run
|
367
|
svn di inputs/<datasrc>/*/test.xml.ref
|
368
|
If you get errors, follow the steps for old-style datasources below
|
369
|
For an old-style datasource:
|
370
|
make inputs/<datasrc>/test
|
371
|
When prompted to "Accept new test output", enter y and press ENTER
|
372
|
If you instead get errors, do one of the following for each one:
|
373
|
- If the error was due to a bug, fix it
|
374
|
- Add a SQL function that filters or transforms the invalid data
|
375
|
- Make an empty mapping for the columns that produced the error.
|
376
|
Put something in the Comments column of the map spreadsheet to
|
377
|
prevent the automatic mapper from auto-removing the mapping.
|
378
|
When accepting tests, it's helpful to use WinMerge
|
379
|
(see WinMerge setup below for configuration)
|
380
|
make inputs/<datasrc>/test by_col=1
|
381
|
If you get errors this time, this always indicates a bug, usually in
|
382
|
the VegBIEN unique constraints or column-based import itself
|
383
|
Add newly-created files: make inputs/<datasrc>/add
|
384
|
Commit: svn ci -m "Added inputs/<datasrc>/" inputs/<datasrc>/
|
385
|
Update vegbiendev:
|
386
|
ssh aaronmk@jupiter.nceas.ucsb.edu
|
387
|
up
|
388
|
On local machine:
|
389
|
./fix_perms
|
390
|
make inputs/upload
|
391
|
make inputs/upload live=1
|
392
|
ssh -t vegbiendev.nceas.ucsb.edu exec sudo -u aaronmk -i
|
393
|
up
|
394
|
make inputs/download
|
395
|
make inputs/download live=1
|
396
|
Follow the steps under Install the staging tables above
|
397
|
|
398
|
Maintenance:
|
399
|
on a live machine, you should put the following in your .profile:
|
400
|
--
|
401
|
# make svn files web-accessible. this does not affect unversioned files, because
|
402
|
# these get the right permissions on the local machine instead.
|
403
|
umask ug=rwx,o=rx
|
404
|
|
405
|
unset TMOUT # TMOUT causes screen to exit even with background processes
|
406
|
--
|
407
|
if http://vegbiendev.nceas.ucsb.edu/phppgadmin/ goes down:
|
408
|
ssh -t vegbiendev.nceas.ucsb.edu exec sudo -u aaronmk -i
|
409
|
make phppgadmin-Linux
|
410
|
regularly, re-run full-database import so that bugs in it don't pile up.
|
411
|
it needs to be kept in working order so that it works when it's needed.
|
412
|
to back up the vegbiendev databases:
|
413
|
ssh -t vegbiendev.nceas.ucsb.edu exec sudo -u aaronmk -i
|
414
|
back up MySQL: # usually few changes, so do this first
|
415
|
backups/mysql_snapshot
|
416
|
l=1 overwrite=1 inplace=1 local_dir=/ remote_url="$USER@jupiter:/data/dev/aaronmk/Documents/BIEN/" subpath=/var/lib/mysql.bak/ sudo -E env PATH="$PATH" bin/sync_upload
|
417
|
on local machine:
|
418
|
l=1 swap=1 overwrite=1 inplace=1 local_dir=~ sync_remote_subdir= subpath=~/Documents/BIEN/var/lib/mysql.bak/ bin/sync_upload
|
419
|
back up Postgres:
|
420
|
backups/pg_snapshot
|
421
|
to synchronize vegbiendev, jupiter, and your local machine:
|
422
|
**WARNING**: pay careful attention to all files that will be deleted or
|
423
|
overwritten!
|
424
|
install put if needed:
|
425
|
download https://uutils.googlecode.com/svn/trunk/bin/put to ~/bin/ and `chmod +x` it
|
426
|
when changes are made on vegbiendev:
|
427
|
avoid extraneous diffs when rsyncing:
|
428
|
on all machines:
|
429
|
up
|
430
|
./fix_perms
|
431
|
ssh -t vegbiendev.nceas.ucsb.edu exec sudo -u aaronmk -i
|
432
|
upload:
|
433
|
overwrite=1 bin/sync_upload --size-only
|
434
|
then review diff, and rerun with `l=1` prepended
|
435
|
on your machine:
|
436
|
download:
|
437
|
overwrite=1 swap=1 src=. dest='aaronmk@jupiter.nceas.ucsb.edu:~/bien' put --exclude=.svn web/BIEN3/TWiki
|
438
|
then review diff, and rerun with `l=1` prepended
|
439
|
swap=1 bin/sync_upload backups/TNRS.backup
|
440
|
then review diff, and rerun with `l=1` prepended
|
441
|
overwrite=1 swap=1 bin/sync_upload --size-only
|
442
|
then review diff, and rerun with `l=1` prepended
|
443
|
overwrite=1 sync_remote_url=~/Dropbox/svn/ bin/sync_upload --existing --size-only # just update mtimes/perms
|
444
|
then review diff, and rerun with `l=1` prepended
|
445
|
to back up e-mails:
|
446
|
on local machine:
|
447
|
/Applications/gmvault-v1.8.1-beta/bin/gmvault sync --multiple-db-owner --type quick aaronmk.nceas@gmail.com
|
448
|
/Applications/gmvault-v1.8.1-beta/bin/gmvault sync --multiple-db-owner --type quick aaronmk@nceas.ucsb.edu
|
449
|
open Thunderbird
|
450
|
click the All Mail folder for each account and wait for it to download the e-mails in it
|
451
|
to back up the version history:
|
452
|
# back up first on the local machine, because often only the svnsync
|
453
|
command gets run, and that way it will get backed up immediately to
|
454
|
Dropbox (and hourly to Time Machine), while vegbiendev only gets
|
455
|
backed up daily to tape
|
456
|
on local machine:
|
457
|
svnsync sync file://"$HOME"/Dropbox/docs/BIEN/svn_repo/ # initial runtime: 1.5 h ("08:21:38" - "06:45:26") @vegbiendev
|
458
|
(cd ~/Dropbox/docs/BIEN/git/; git svn fetch)
|
459
|
# use absolute path for vegbiendev commands because the Ubuntu 14.04
|
460
|
version of rsync doesn't expand ~ properly
|
461
|
overwrite=1 src=~ dest='aaronmk@jupiter.nceas.ucsb.edu:/data/dev/aaronmk/' put Dropbox/docs/BIEN/svn_repo/ # runtime: 1 min ("1:05.08")
|
462
|
then review diff, and rerun with `l=1` prepended
|
463
|
overwrite=1 src=~ dest='aaronmk@jupiter.nceas.ucsb.edu:/data/dev/aaronmk/' put Dropbox/docs/BIEN/git/
|
464
|
then review diff, and rerun with `l=1` prepended
|
465
|
to back up vegbiendev:
|
466
|
do steps under Maintenance > "to synchronize vegbiendev, jupiter, and
|
467
|
your local machine"
|
468
|
on local machine:
|
469
|
l=1 overwrite=1 inplace=1 src=root@vegbiendev.nceas.ucsb.edu:/ dest=~/Documents/BIEN/vegbiendev/ sudo -E put --exclude=/var/lib/mysql.bak --exclude=/var/lib/postgresql.bak --exclude='/var/lib/postgresql/9.3/main/*/' --exclude=/home/aaronmk/bien
|
470
|
# enable --link-dest to work:
|
471
|
chmod -R o+r ~/bien/.svn/; find ~/bien/.svn -type d -exec chmod o+rx {} \; # match perms
|
472
|
l=1 overwrite=1 del= src='aaronmk@vegbiendev.nceas.ucsb.edu:~/bien/' dest=~/bien/ put --existing --size-only .svn/pristine/ # match times and perms
|
473
|
l=1 overwrite=1 inplace=1 src=aaronmk@vegbiendev.nceas.ucsb.edu:/ dest=~/Documents/BIEN/vegbiendev/ sudo -E put --link-dest="$HOME"/Documents/BIEN/svn/ --no-owner --no-group home/aaronmk/bien/
|
474
|
# --no-owner --no-group: needed to allow --link-dest to work
|
475
|
# --link-dest: relative to dest, not currdir, so need abs path
|
476
|
to back up the local machine's settings:
|
477
|
do step when changes are made on vegbiendev > on your machine, download
|
478
|
ssh aaronmk@jupiter.nceas.ucsb.edu
|
479
|
(cd ~/Dropbox/svn/; up)
|
480
|
on your machine:
|
481
|
sudo find / -name .DS_Store -print -delete
|
482
|
rm ~/'Library/Thunderbird/Profiles/9oo8rcyn.default/ImapMail/imap.googlemail.com/[Gmail].sbd/Spam'
|
483
|
# remove the downloaded Spam folder, because spam e-mails often contain viruses that would trigger clamscan
|
484
|
overwrite=1 sync_local_dir=~/Dropbox/svn/ sync_remote_subdir=Dropbox/svn/ bin/sync_upload --size-only # just update mtimes
|
485
|
then review diff, and rerun with `l=1` prepended
|
486
|
overwrite=1 inplace=1 sync_local_dir=~/ sync_remote_subdir= bin/sync_upload ~/"VirtualBox VMs/**" # need inplace=1 because they are very large files
|
487
|
then review diff, and rerun with `l=1` prepended
|
488
|
overwrite=1 sync_local_dir=~/ sync_remote_subdir= bin/sync_upload --exclude="/Library/Saved Application State/" --exclude="/Library/Thunderbird/Profiles/9oo8rcyn.default/global-messages-db.sqlite" --exclude="/.Trash/" --exclude="/bin/" --exclude="/bin/pg_ctl" --exclude="/bin/unzip" --exclude="/Dropbox/home/" --exclude="/.profile" --exclude="/.shrc" --exclude="/.bashrc" --exclude="/software/**/.svn/"
|
489
|
then review diff, and rerun with `l=1` prepended
|
490
|
stop Dropbox: system tray > Dropbox icon > gear icon > Quit Dropbox
|
491
|
this prevents Dropbox from trying to capture filesystem
|
492
|
events while syncing
|
493
|
overwrite=1 sync_local_dir=~/ sync_remote_url=~/Dropbox/home/ bin/sync_upload --exclude="/Library/Saved Application State/" --exclude="/Library/Thunderbird/Profiles/9oo8rcyn.default/global-messages-db.sqlite" --exclude="/.Trash/" --exclude="/.dropbox/" --exclude="/Documents/BIEN/" --exclude="/Dropbox/" --exclude="/software/" --exclude="/VirtualBox VMs/**.sav" --exclude="/VirtualBox VMs/**.vdi" --exclude="/VirtualBox VMs/**.vmdk"
|
494
|
then review diff, and rerun with `l=1` prepended
|
495
|
start Dropbox: /Applications > double-click Dropbox.app
|
496
|
to backup files not in Time Machine:
|
497
|
**IMPORTANT**: need to use 2 TB external hard drive instead of Time
|
498
|
Machine drive because Time Machine drive does not have
|
499
|
~/Documents/BIEN/ in a location where it can be hardlinked against
|
500
|
On local machine:
|
501
|
on first run, create parent dirs:
|
502
|
sudo mkdir -p '/Volumes/BIEN3.**SAVE**/Users/aaronmk/Documents/BIEN/'
|
503
|
sudo mkdir -p '/Volumes/BIEN3.**SAVE**/usr/local/var/postgres/'
|
504
|
l=1 src=/ dest='/Volumes/BIEN3.**SAVE**/' sudo -E put --existing
|
505
|
l=1 overwrite=1 src=/ dest='/Volumes/BIEN3.**SAVE**/' sudo -E put --include='/vegbiendev**' --exclude='**' Users/aaronmk/Documents/BIEN/
|
506
|
# this cannot be backed up by Time Machine because it dereferences hard links:
|
507
|
# `sudo find /Volumes/Time\ Machine\ Backups/Backups.backupdb/ ! -type d -links +1`
|
508
|
# returns no files when there is a single timestamped backup, but
|
509
|
# `sudo find / ! -type d -links +1` does
|
510
|
l=1 overwrite=1 src=/ dest='/Volumes/BIEN3.**SAVE**/' sudo -E put usr/local/var/postgres/
|
511
|
# this cannot be backed up by Time Machine because it prevents the backup process from ending
|
512
|
launchctl unload ~/Library/LaunchAgents/homebrew.mxcl.postgresql.plist # stop the PostgreSQL server
|
513
|
l=1 overwrite=1 src=/ dest='/Volumes/BIEN3.**SAVE**/' sudo -E put usr/local/var/postgres/
|
514
|
launchctl load ~/Library/LaunchAgents/homebrew.mxcl.postgresql.plist # start the PostgreSQL server
|
515
|
to back up the local machine's hard drive:
|
516
|
turn on and connect the 2 TB external hard drive
|
517
|
screen
|
518
|
# --exclude='/\**': exclude *-files indicating the (differing) retention
|
519
|
# statuses of the partitions involved
|
520
|
l=1 overwrite=1 src=/ dest='/Volumes/BIEN3.**SAVE**/' sudo -E put --exclude='/\**' --exclude=/.fseventsd/ --exclude=/private/var/vm/ --exclude=/usr/local/var/postgres/ --exclude=/Users/aaronmk/.dropbox/
|
521
|
# no --extended-attributes: rsync has to visit every file for this
|
522
|
# runtime: 10 min (~600); initial runtime: 4-13 h ("2422.84"+"12379.91" .. "45813.19"+"747.96")
|
523
|
# repeat until only minimal changes
|
524
|
l=1 overwrite=1 src=/ dest='/Volumes/BIEN3.**SAVE**/' sudo -E put --exclude='/\**' --exclude=/.fseventsd/ --exclude=/private/var/vm/
|
525
|
stop Dropbox: system tray > Dropbox icon > gear icon > Quit Dropbox
|
526
|
otherwise, the backup of ~/.dropbox will be corrupted
|
527
|
launchctl unload ~/Library/LaunchAgents/homebrew.mxcl.postgresql.plist # stop the PostgreSQL server
|
528
|
l=1 overwrite=1 src=/ dest='/Volumes/BIEN3.**SAVE**/' sudo -E put --exclude='/\**' --exclude=/.fseventsd/ --exclude=/private/var/vm/
|
529
|
launchctl load ~/Library/LaunchAgents/homebrew.mxcl.postgresql.plist # start the PostgreSQL server
|
530
|
start Dropbox: /Applications > double-click Dropbox.app
|
531
|
to restore from Time Machine:
|
532
|
# restart holding Alt
|
533
|
# select Time Machine Backups
|
534
|
# restore the last Time Machine backup to Macintosh HD
|
535
|
# restart holding Alt
|
536
|
# select Macintosh HD
|
537
|
$ screen
|
538
|
$ l=1 swap=1 src=/ dest=/Volumes/Time\ Machine\ Backups/ sudo -E put usr/local/var/postgres/ # runtime: 1 h ("4020.61")
|
539
|
$ make postgres_restart
|
540
|
VegCore data dictionary:
|
541
|
Regularly, or whenever the VegCore data dictionary page
|
542
|
(https://projects.nceas.ucsb.edu/nceas/projects/bien/wiki/VegCore)
|
543
|
is changed, regenerate mappings/VegCore.csv:
|
544
|
On local machine:
|
545
|
make mappings/VegCore.htm-remake; make mappings/
|
546
|
apply new data dict mappings to datasource mappings/staging tables:
|
547
|
inputs/run postprocess # runtime: see inputs/run
|
548
|
time yes|make inputs/{NVS,SALVIAS,TEAM}/test # old-style import; runtime: 1 min ("0m59.692s") @starscream
|
549
|
svn di mappings/VegCore.tables.redmine
|
550
|
If there are changes, update the data dictionary's Tables section
|
551
|
When moving terms, check that no terms were lost: svn di
|
552
|
svn ci -m 'mappings/VegCore.htm: regenerated from wiki'
|
553
|
ssh -t vegbiendev.nceas.ucsb.edu exec sudo -u aaronmk -i
|
554
|
perform the steps under "apply new data dict mappings to
|
555
|
datasource mappings/staging tables" above
|
556
|
Important: Whenever you install a system update that affects PostgreSQL or
|
557
|
any of its dependencies, such as libc, you should restart the PostgreSQL
|
558
|
server. Otherwise, you may get strange errors like "the database system
|
559
|
is in recovery mode" which go away upon reimport, or you may not be able
|
560
|
to access the database as the postgres superuser. This applies to both
|
561
|
Linux and Mac OS X.
|
562
|
|
563
|
Backups:
|
564
|
Archived imports:
|
565
|
ssh -t vegbiendev.nceas.ucsb.edu exec sudo -u aaronmk -i
|
566
|
Back up: make backups/<version>.backup &
|
567
|
Note: To back up the last import, you must archive it first:
|
568
|
make schemas/rotate
|
569
|
Test: make -s backups/<version>.backup/test &
|
570
|
Restore: make backups/<version>.backup/restore &
|
571
|
Remove: make backups/<version>.backup/remove
|
572
|
Download: make backups/<version>.backup/download
|
573
|
TNRS cache:
|
574
|
ssh -t vegbiendev.nceas.ucsb.edu exec sudo -u aaronmk -i
|
575
|
Back up: make backups/TNRS.backup-remake &
|
576
|
runtime: 3 min ("real 2m48.859s")
|
577
|
Restore:
|
578
|
yes|make inputs/.TNRS/uninstall
|
579
|
make backups/TNRS.backup/restore &
|
580
|
runtime: 5.5 min ("real 5m35.829s")
|
581
|
yes|make schemas/public/reinstall
|
582
|
Must come after TNRS restore to recreate tnrs_input_name view
|
583
|
Full DB:
|
584
|
ssh -t vegbiendev.nceas.ucsb.edu exec sudo -u aaronmk -i
|
585
|
Back up: make backups/vegbien.<version>.backup &
|
586
|
Test: make -s backups/vegbien.<version>.backup/test &
|
587
|
Restore: make backups/vegbien.<version>.backup/restore &
|
588
|
Download: make backups/vegbien.<version>.backup/download
|
589
|
Import logs:
|
590
|
On local machine:
|
591
|
Download: make inputs/download-logs live=1
|
592
|
|
593
|
Datasource refreshing:
|
594
|
VegBank:
|
595
|
ssh -t vegbiendev.nceas.ucsb.edu exec sudo -u aaronmk -i
|
596
|
make inputs/VegBank/vegbank.sql-remake
|
597
|
make inputs/VegBank/reinstall quiet=1 &
|
598
|
|
599
|
Schema changes:
|
600
|
On local machine:
|
601
|
When changing the analytical views, run sync_analytical_..._to_view()
|
602
|
to update the corresponding table
|
603
|
Remember to update the following files with any renamings:
|
604
|
schemas/filter_ERD.csv
|
605
|
mappings/VegCore-VegBIEN.csv
|
606
|
mappings/verify.*.sql
|
607
|
Regenerate schema from installed DB: make schemas/remake
|
608
|
Reinstall DB from schema: make schemas/public/reinstall schemas/reinstall
|
609
|
**WARNING**: This will delete the public schema of your VegBIEN DB!
|
610
|
If needed, reinstall staging tables:
|
611
|
On local machine:
|
612
|
sudo -E -u postgres psql <<<'ALTER DATABASE vegbien RENAME TO vegbien_prev'
|
613
|
make db
|
614
|
. bin/reinstall_all
|
615
|
Fix any bugs and retry until no errors
|
616
|
make schemas/public/install
|
617
|
This must be run *after* the datasources are installed, because
|
618
|
views in public depend on some of the datasources
|
619
|
sudo -E -u postgres psql <<<'DROP DATABASE vegbien_prev'
|
620
|
ssh -t vegbiendev.nceas.ucsb.edu exec sudo -u aaronmk -i
|
621
|
repeat the above steps
|
622
|
**WARNING**: Do not run this until reinstall_all runs successfully
|
623
|
on the local machine, or the live DB may be unrestorable!
|
624
|
update mappings and staging table column names:
|
625
|
on local machine:
|
626
|
inputs/run postprocess # runtime: see inputs/run
|
627
|
time yes|make inputs/{NVS,SALVIAS,TEAM}/test # old-style import; runtime: 1 min ("0m59.692s") @starscream
|
628
|
ssh -t vegbiendev.nceas.ucsb.edu exec sudo -u aaronmk -i
|
629
|
manually apply schema changes to the live public schema
|
630
|
do steps under "on local machine" above
|
631
|
Sync ERD with vegbien.sql schema:
|
632
|
Run make schemas/vegbien.my.sql
|
633
|
Open schemas/vegbien.ERD.mwb in MySQLWorkbench
|
634
|
Go to File > Export > Synchronize With SQL CREATE Script...
|
635
|
For Input File, select schemas/vegbien.my.sql
|
636
|
Click Continue
|
637
|
In the changes list, select each table with an arrow next to it
|
638
|
Click Update Model
|
639
|
Click Continue
|
640
|
Note: The generated SQL script will be empty because we are syncing in
|
641
|
the opposite direction
|
642
|
Click Execute
|
643
|
Reposition any lines that have been reset
|
644
|
Add any new tables by dragging them from the Catalog in the left sidebar
|
645
|
to the diagram
|
646
|
Remove any deleted tables by right-clicking the table's diagram element,
|
647
|
selecting Delete '<table name>', and clicking Delete
|
648
|
Save
|
649
|
If desired, update the graphical ERD exports (see below)
|
650
|
Update graphical ERD exports:
|
651
|
Go to File > Export > Export as PNG...
|
652
|
Select schemas/vegbien.ERD.png and click Save
|
653
|
Go to File > Export > Export as SVG...
|
654
|
Select schemas/vegbien.ERD.svg and click Save
|
655
|
Go to File > Export > Export as Single Page PDF...
|
656
|
Select schemas/vegbien.ERD.1_pg.pdf and click Save
|
657
|
Go to File > Print...
|
658
|
In the lower left corner, click PDF > Save as PDF...
|
659
|
Set the Title and Author to ""
|
660
|
Select schemas/vegbien.ERD.pdf and click Save
|
661
|
Commit: svn ci -m "schemas/vegbien.ERD.mwb: Regenerated exports"
|
662
|
Refactoring tips:
|
663
|
To rename a table:
|
664
|
In vegbien.sql, do the following:
|
665
|
Replace regexp (?<=_|\b)<old>(?=_|\b) with <new>
|
666
|
This is necessary because the table name is *everywhere*
|
667
|
Search for <new>
|
668
|
Manually change back any replacements inside comments
|
669
|
To rename a column:
|
670
|
Rename the column: ALTER TABLE <table> RENAME <old> TO <new>;
|
671
|
Recreate any foreign key for the column, removing CONSTRAINT <name>
|
672
|
This resets the foreign key name using the new column name
|
673
|
Creating a poster of the ERD:
|
674
|
Determine the poster size:
|
675
|
Measure the line height (from the bottom of one line to the bottom
|
676
|
of another): 16.3cm/24 lines = 0.679cm
|
677
|
Measure the height of the ERD: 35.4cm*2 = 70.8cm
|
678
|
Zoom in as far as possible
|
679
|
Measure the height of a capital letter: 3.5mm
|
680
|
Measure the line height: 8.5mm
|
681
|
Calculate the text's fraction of the line height: 3.5mm/8.5mm = 0.41
|
682
|
Calculate the text height: 0.679cm*0.41 = 0.28cm
|
683
|
Calculate the text height's fraction of the ERD height:
|
684
|
0.28cm/70.8cm = 0.0040
|
685
|
Measure the text height on the *VegBank* ERD poster: 5.5mm = 0.55cm
|
686
|
Calculate the VegBIEN poster height to make the text the same size:
|
687
|
0.55cm/0.0040 = 137.5cm H; *1in/2.54cm = 54.1in H
|
688
|
The ERD aspect ratio is 11 in W x (2*8.5in H) = 11x17 portrait
|
689
|
Calculate the VegBIEN poster width: 54.1in H*11W/17H = 35.0in W
|
690
|
The minimum VegBIEN poster size is 35x54in portrait
|
691
|
Determine the cost:
|
692
|
The FedEx Kinkos near NCEAS (1030 State St, Santa Barbara, CA 93101)
|
693
|
charges the following for posters:
|
694
|
base: $7.25/sq ft
|
695
|
lamination: $3/sq ft
|
696
|
mounting on a board: $8/sq ft
|
697
|
|
698
|
Testing:
|
699
|
On a development machine, you should put the following in your .profile:
|
700
|
umask ug=rwx,o= # prevent files from becoming web-accessible
|
701
|
export log= n=2
|
702
|
For development machine specs, see /planning/resources/dev_machine.specs/
|
703
|
On local machine:
|
704
|
Mapping process: make test
|
705
|
Including column-based import: make test by_col=1
|
706
|
If the row-based and column-based imports produce different inserted
|
707
|
row counts, this usually means that a table is underconstrained
|
708
|
(the unique indexes don't cover all possible rows).
|
709
|
This can occur if you didn't use COALESCE(field, null_value) around
|
710
|
a nullable field in a unique index. See sql_gen.null_sentinels for
|
711
|
the appropriate null value to use.
|
712
|
Map spreadsheet generation: make remake
|
713
|
Missing mappings: make missing_mappings
|
714
|
Everything (for most complete coverage): make test-all
|
715
|
|
716
|
Debugging:
|
717
|
"Binary chop" debugging:
|
718
|
(This is primarily useful for regressions that occurred in a previous
|
719
|
revision, which was committed without running all the tests)
|
720
|
up -r <rev>; make inputs/.TNRS/reinstall; make schemas/public/reinstall; make <failed-test>.xml
|
721
|
.htaccess:
|
722
|
mod_rewrite:
|
723
|
**IMPORTANT**: whenever you change the DirectorySlash setting for a
|
724
|
directory, you *must* clear your browser's cache to ensure that
|
725
|
a cached redirect is not used. this is because RewriteRule
|
726
|
redirects are (by default) temporary, but DirectorySlash
|
727
|
redirects are permanent.
|
728
|
for Firefox:
|
729
|
press Cmd+Shift+Delete
|
730
|
check only Cache
|
731
|
press Enter or click Clear Now
|
732
|
|
733
|
WinMerge setup:
|
734
|
In a Windows VM:
|
735
|
Install WinMerge from <http://winmerge.org/>
|
736
|
Open WinMerge
|
737
|
Go to Edit > Options and click Compare in the left sidebar
|
738
|
Enable "Moved block detection", as described at
|
739
|
<http://manual.winmerge.org/Configuration.html#d0e5892>.
|
740
|
Set Whitespace to Ignore change, as described at
|
741
|
<http://manual.winmerge.org/Configuration.html#d0e5758>.
|
742
|
|
743
|
Documentation:
|
744
|
To generate a Redmine-formatted list of steps for column-based import:
|
745
|
On local machine:
|
746
|
make schemas/public/reinstall
|
747
|
make inputs/ACAD/Specimen/logs/steps.by_col.log.sql
|
748
|
To import and scrub just the test taxonomic names:
|
749
|
ssh -t vegbiendev.nceas.ucsb.edu exec sudo -u aaronmk -i
|
750
|
inputs/test_taxonomic_names/test_scrub
|
751
|
|
752
|
General:
|
753
|
To see a program's description, read its top-of-file comment
|
754
|
To see a program's usage, run it without arguments
|
755
|
To remake a directory: make <dir>/remake
|
756
|
To remake a file: make <file>-remake
|