1
0
mirror of https://github.com/alanorth/cgspace-notes.git synced 2025-01-01 01:35:57 +01:00
cgspace-notes/docs/2018-08/index.html

602 lines
28 KiB
HTML
Raw Normal View History

2018-08-01 11:49:05 +02:00
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
<meta property="og:title" content="August, 2018" />
<meta property="og:description" content="2018-08-01
DSpace Test had crashed at some point yesterday morning and I see the following in dmesg:
[Tue Jul 31 00:00:41 2018] Out of memory: Kill process 1394 (java) score 668 or sacrifice child
[Tue Jul 31 00:00:41 2018] Killed process 1394 (java) total-vm:15601860kB, anon-rss:5355528kB, file-rss:0kB, shmem-rss:0kB
[Tue Jul 31 00:00:41 2018] oom_reaper: reaped process 1394 (java), now anon-rss:0kB, file-rss:0kB, shmem-rss:0kB
Judging from the time of the crash it was probably related to the Discovery indexing that starts at midnight
2019-05-05 15:45:12 +02:00
2018-08-01 11:49:05 +02:00
From the DSpace log I see that eventually Solr stopped responding, so I guess the java process that was OOM killed above was Tomcat&rsquo;s
2019-05-05 15:45:12 +02:00
2018-08-01 11:49:05 +02:00
I&rsquo;m not sure why Tomcat didn&rsquo;t crash with an OutOfMemoryError&hellip;
2019-05-05 15:45:12 +02:00
2018-08-01 11:49:05 +02:00
Anyways, perhaps I should increase the JVM heap from 5120m to 6144m like we did a few months ago when we tried to run the whole CGSpace Solr core
2019-05-05 15:45:12 +02:00
2018-08-01 11:49:05 +02:00
The server only has 8GB of RAM so we&rsquo;ll eventually need to upgrade to a larger one because we&rsquo;ll start starving the OS, PostgreSQL, and command line batch processes
2019-05-05 15:45:12 +02:00
2018-08-01 11:49:05 +02:00
I ran all system updates on DSpace Test and rebooted it
" />
<meta property="og:type" content="article" />
2019-02-02 13:12:57 +01:00
<meta property="og:url" content="https://alanorth.github.io/cgspace-notes/2018-08/" />
2019-08-08 17:10:44 +02:00
<meta property="article:published_time" content="2018-08-01T11:52:54+03:00" />
<meta property="article:modified_time" content="2018-09-10T23:35:46+03:00" />
2018-09-30 07:23:48 +02:00
2018-08-01 11:49:05 +02:00
<meta name="twitter:card" content="summary"/>
<meta name="twitter:title" content="August, 2018"/>
<meta name="twitter:description" content="2018-08-01
DSpace Test had crashed at some point yesterday morning and I see the following in dmesg:
[Tue Jul 31 00:00:41 2018] Out of memory: Kill process 1394 (java) score 668 or sacrifice child
[Tue Jul 31 00:00:41 2018] Killed process 1394 (java) total-vm:15601860kB, anon-rss:5355528kB, file-rss:0kB, shmem-rss:0kB
[Tue Jul 31 00:00:41 2018] oom_reaper: reaped process 1394 (java), now anon-rss:0kB, file-rss:0kB, shmem-rss:0kB
Judging from the time of the crash it was probably related to the Discovery indexing that starts at midnight
2019-05-05 15:45:12 +02:00
2018-08-01 11:49:05 +02:00
From the DSpace log I see that eventually Solr stopped responding, so I guess the java process that was OOM killed above was Tomcat&rsquo;s
2019-05-05 15:45:12 +02:00
2018-08-01 11:49:05 +02:00
I&rsquo;m not sure why Tomcat didn&rsquo;t crash with an OutOfMemoryError&hellip;
2019-05-05 15:45:12 +02:00
2018-08-01 11:49:05 +02:00
Anyways, perhaps I should increase the JVM heap from 5120m to 6144m like we did a few months ago when we tried to run the whole CGSpace Solr core
2019-05-05 15:45:12 +02:00
2018-08-01 11:49:05 +02:00
The server only has 8GB of RAM so we&rsquo;ll eventually need to upgrade to a larger one because we&rsquo;ll start starving the OS, PostgreSQL, and command line batch processes
2019-05-05 15:45:12 +02:00
2018-08-01 11:49:05 +02:00
I ran all system updates on DSpace Test and rebooted it
"/>
2019-08-08 17:10:44 +02:00
<meta name="generator" content="Hugo 0.56.3" />
2018-08-01 11:49:05 +02:00
<script type="application/ld+json">
{
"@context": "http://schema.org",
"@type": "BlogPosting",
"headline": "August, 2018",
2019-04-13 11:15:55 +02:00
"url": "https:\/\/alanorth.github.io\/cgspace-notes\/2018-08\/",
2018-09-02 11:03:43 +02:00
"wordCount": "2748",
2019-04-13 11:15:55 +02:00
"datePublished": "2018-08-01T11:52:54\x2b03:00",
"dateModified": "2018-09-10T23:35:46\x2b03:00",
2018-08-01 11:49:05 +02:00
"author": {
"@type": "Person",
"name": "Alan Orth"
},
"keywords": "Notes"
}
</script>
<link rel="canonical" href="https://alanorth.github.io/cgspace-notes/2018-08/">
<title>August, 2018 | CGSpace Notes</title>
<!-- combined, minified CSS -->
2019-02-13 17:47:17 +01:00
<link href="https://alanorth.github.io/cgspace-notes/css/style.css" rel="stylesheet" integrity="sha384-G5B34w7DFTumWTswxYzTX7NWfbvQEg1HbFFEg6ItN03uTAAoS2qkPS/fu3LhuuSA" crossorigin="anonymous">
2018-08-01 11:49:05 +02:00
2019-04-14 15:59:47 +02:00
<!-- RSS 2.0 feed -->
2018-08-01 11:49:05 +02:00
</head>
<body>
<div class="blog-masthead">
<div class="container">
<nav class="nav blog-nav">
<a class="nav-link " href="https://alanorth.github.io/cgspace-notes/">Home</a>
</nav>
</div>
</div>
2018-12-19 12:20:39 +01:00
2018-08-01 11:49:05 +02:00
<header class="blog-header">
<div class="container">
<h1 class="blog-title"><a href="https://alanorth.github.io/cgspace-notes/" rel="home">CGSpace Notes</a></h1>
<p class="lead blog-description">Documenting day-to-day work on the <a href="https://cgspace.cgiar.org">CGSpace</a> repository.</p>
</div>
</header>
2018-12-19 12:20:39 +01:00
2018-08-01 11:49:05 +02:00
<div class="container">
<div class="row">
<div class="col-sm-8 blog-main">
<article class="blog-post">
<header>
<h2 class="blog-post-title"><a href="https://alanorth.github.io/cgspace-notes/2018-08/">August, 2018</a></h2>
<p class="blog-post-meta"><time datetime="2018-08-01T11:52:54&#43;03:00">Wed Aug 01, 2018</time> by Alan Orth in
<i class="fa fa-tag" aria-hidden="true"></i>&nbsp;<a href="/cgspace-notes/tags/notes" rel="tag">Notes</a>
</p>
</header>
<h2 id="2018-08-01">2018-08-01</h2>
<ul>
2019-05-05 15:45:12 +02:00
<li><p>DSpace Test had crashed at some point yesterday morning and I see the following in <code>dmesg</code>:</p>
2018-08-01 11:49:05 +02:00
<pre><code>[Tue Jul 31 00:00:41 2018] Out of memory: Kill process 1394 (java) score 668 or sacrifice child
[Tue Jul 31 00:00:41 2018] Killed process 1394 (java) total-vm:15601860kB, anon-rss:5355528kB, file-rss:0kB, shmem-rss:0kB
[Tue Jul 31 00:00:41 2018] oom_reaper: reaped process 1394 (java), now anon-rss:0kB, file-rss:0kB, shmem-rss:0kB
2019-05-05 15:45:12 +02:00
</code></pre></li>
2018-08-01 11:49:05 +02:00
2019-05-05 15:45:12 +02:00
<li><p>Judging from the time of the crash it was probably related to the Discovery indexing that starts at midnight</p></li>
<li><p>From the DSpace log I see that eventually Solr stopped responding, so I guess the <code>java</code> process that was OOM killed above was Tomcat&rsquo;s</p></li>
<li><p>I&rsquo;m not sure why Tomcat didn&rsquo;t crash with an OutOfMemoryError&hellip;</p></li>
<li><p>Anyways, perhaps I should increase the JVM heap from 5120m to 6144m like we did a few months ago when we tried to run the whole CGSpace Solr core</p></li>
<li><p>The server only has 8GB of RAM so we&rsquo;ll eventually need to upgrade to a larger one because we&rsquo;ll start starving the OS, PostgreSQL, and command line batch processes</p></li>
<li><p>I ran all system updates on DSpace Test and rebooted it</p></li>
2018-08-01 11:49:05 +02:00
</ul>
2018-08-01 16:24:49 +02:00
<ul>
<li>I started looking over the latest round of IITA batch records from Sisay on DSpace Test: <a href="https://dspacetest.cgiar.org/handle/10568/103250">IITA July_30</a>
<ul>
<li>incorrect authorship types</li>
<li>dozens of inconsistencies, spelling mistakes, and white space in author affiliations</li>
<li>minor issues in countries (California is not a country)</li>
<li>minor issues in IITA subjects, ISBNs, languages, and AGROVOC subjects</li>
</ul></li>
</ul>
2018-08-02 13:29:59 +02:00
<h2 id="2018-08-02">2018-08-02</h2>
<ul>
2019-05-05 15:45:12 +02:00
<li><p>DSpace Test crashed again and I don&rsquo;t see the only error I see is this in <code>dmesg</code>:</p>
2018-08-02 13:29:59 +02:00
<pre><code>[Thu Aug 2 00:00:12 2018] Out of memory: Kill process 1407 (java) score 787 or sacrifice child
[Thu Aug 2 00:00:12 2018] Killed process 1407 (java) total-vm:18876328kB, anon-rss:6323836kB, file-rss:0kB, shmem-rss:0kB
2019-05-05 15:45:12 +02:00
</code></pre></li>
2018-08-02 13:29:59 +02:00
2019-05-05 15:45:12 +02:00
<li><p>I am still assuming that this is the Tomcat process that is dying, so maybe actually we need to reduce its memory instead of increasing it?</p></li>
<li><p>The risk we run there is that we&rsquo;ll start getting OutOfMemory errors from Tomcat</p></li>
<li><p>So basically we need a new test server with more RAM very soon&hellip;</p></li>
<li><p>Abenet asked about the workflow statistics in the Atmire CUA module again</p></li>
<li><p>Last year Atmire told me that it&rsquo;s disabled by default but you can enable it with <code>workflow.stats.enabled = true</code> in the CUA configuration file</p></li>
<li><p>There was a bug with adding users so they sent a patch, but I didn&rsquo;t merge it because it was <a href="https://github.com/ilri/DSpace/pull/319">very dirty</a> and I wasn&rsquo;t sure it actually fixed the problem</p></li>
<li><p>I just tried to enable the stats again on DSpace Test now that we&rsquo;re on DSpace 5.8 with updated Atmire modules, but every user I search for shows &ldquo;No data available&rdquo;</p></li>
<li><p>As a test I submitted a new item and I was able to see it in the workflow statistics &ldquo;data&rdquo; tab, but not in the graph</p></li>
2018-08-02 13:29:59 +02:00
</ul>
2018-08-15 11:56:38 +02:00
<h2 id="2018-08-15">2018-08-15</h2>
<ul>
<li>Run through Peter&rsquo;s list of author affiliations from earlier this month</li>
<li>I did some quick sanity checks and small cleanups in Open Refine, checking for spaces, weird accents, and encoding errors</li>
2019-05-05 15:45:12 +02:00
<li><p>Finally I did a test run with the <a href="https://gist.github.com/alanorth/df92cbfb54d762ba21b28f7cd83b6897"><code>fix-metadata-value.py</code></a> script:</p>
2018-08-15 11:56:38 +02:00
<pre><code>$ ./fix-metadata-values.py -i 2018-08-15-Correct-1083-Affiliations.csv -db dspace -u dspace -p 'fuuu' -f cg.contributor.affiliation -t correct -m 211
$ ./delete-metadata-values.py -i 2018-08-15-Remove-11-Affiliations.csv -db dspace -u dspace -p 'fuuu' -f cg.contributor.affiliation -m 211
2019-05-05 15:45:12 +02:00
</code></pre></li>
</ul>
2018-08-15 11:56:38 +02:00
2018-08-16 14:40:38 +02:00
<h2 id="2018-08-16">2018-08-16</h2>
<ul>
2019-05-05 15:45:12 +02:00
<li><p>Generate a list of the top 1,500 authors on CGSpace for Sisay so he can create the controlled vocabulary:</p>
2018-08-16 14:40:38 +02:00
<pre><code>dspace=# \copy (select distinct text_value, count(*) from metadatavalue where metadata_field_id = (select metadata_field_id from metadatafieldregistry where element = 'contributor' and qualifier = 'author') AND resource_type_id = 2 group by text_value order by count desc limit 1500) to /tmp/2018-08-16-top-1500-authors.csv with csv;
2019-05-05 15:45:12 +02:00
</code></pre></li>
2018-08-16 14:40:38 +02:00
2019-05-05 15:45:12 +02:00
<li><p>Start working on adding the ORCID metadata to a handful of CIAT authors as requested by Elizabeth earlier this month</p></li>
<li><p>I might need to overhaul the <a href="https://gist.github.com/alanorth/a49d85cd9c5dea89cddbe809813a7050">add-orcid-identifiers-csv.py</a> script to be a little more robust about author order and ORCID metadata that might have been altered manually by editors after submission, as this script was written without that consideration</p></li>
<li><p>After checking a few examples I see that checking only the <code>text_value</code> and <code>place</code> when adding ORCID fields is not enough anymore</p></li>
<li><p>It was a sane assumption when I was initially migrating ORCID records from Solr to regular metadata, but now it seems that some authors might have been added or changed after item submission</p></li>
<li><p>Now it is better to check if there is <em>any</em> existing ORCID identifier for a given author for the item&hellip;</p></li>
<li><p>I will have to update my script to extract the ORCID identifier and search for that</p></li>
<li><p>Re-create my local DSpace database using the latest PostgreSQL 9.6 Docker image and re-import the latest CGSpace dump:</p>
2018-08-16 14:40:38 +02:00
2018-08-16 17:59:45 +02:00
<pre><code>$ sudo docker run --name dspacedb -e POSTGRES_PASSWORD=postgres -p 5432:5432 -d postgres:9.6-alpine
$ createuser -h localhost -U postgres --pwprompt dspacetest
$ createdb -h localhost -U postgres -O dspacetest --encoding=UNICODE dspacetest
$ psql -h localhost -U postgres dspacetest -c 'alter user dspacetest superuser;'
2018-09-02 11:03:43 +02:00
$ pg_restore -h localhost -U postgres -d dspacetest -O --role=dspacetest ~/Downloads/cgspace_2018-08-16.backup
2018-08-16 17:59:45 +02:00
$ psql -h localhost -U postgres dspacetest -c 'alter user dspacetest nosuperuser;'
$ psql -h localhost -U postgres -f ~/src/git/DSpace/dspace/etc/postgres/update-sequences.sql dspacetest
2019-05-05 15:45:12 +02:00
</code></pre></li>
</ul>
2018-08-16 17:59:45 +02:00
2018-08-19 17:42:55 +02:00
<h2 id="2018-08-19">2018-08-19</h2>
<ul>
<li>Keep working on the CIAT ORCID identifiers from Elizabeth</li>
<li>In the spreadsheet she sent me there are some names with other versions in the database, so when it is obviously the same one (ie &ldquo;Schultze-Kraft, Rainer&rdquo; and &ldquo;Schultze-Kraft, R.&rdquo;) I will just tag them with ORCID identifiers too</li>
<li>This is less obvious and more error prone with names like &ldquo;Peters&rdquo; where there are many more authors</li>
2019-05-05 15:45:12 +02:00
<li><p>I see some errors in the variations of names as well, for example:</p>
2018-08-19 17:42:55 +02:00
<pre><code>Verchot, Louis
Verchot, L
Verchot, L. V.
Verchot, L.V
Verchot, L.V.
Verchot, LV
Verchot, Louis V.
2019-05-05 15:45:12 +02:00
</code></pre></li>
2018-08-19 17:42:55 +02:00
2019-05-05 15:45:12 +02:00
<li><p>I&rsquo;ll just tag them all with Louis Verchot&rsquo;s ORCID identifier&hellip;</p></li>
<li><p>In the end, I&rsquo;ll run the following CSV with my <a href="https://gist.github.com/alanorth/a49d85cd9c5dea89cddbe809813a7050">add-orcid-identifiers-csv.py</a> script:</p>
2018-08-19 17:42:55 +02:00
<pre><code>dc.contributor.author,cg.creator.id
&quot;Campbell, Bruce&quot;,Bruce M Campbell: 0000-0002-0123-4859
&quot;Campbell, Bruce M.&quot;,Bruce M Campbell: 0000-0002-0123-4859
&quot;Campbell, B.M&quot;,Bruce M Campbell: 0000-0002-0123-4859
&quot;Peters, Michael&quot;,Michael Peters: 0000-0003-4237-3916
&quot;Peters, M.&quot;,Michael Peters: 0000-0003-4237-3916
&quot;Peters, M.K.&quot;,Michael Peters: 0000-0003-4237-3916
&quot;Tamene, Lulseged&quot;,Lulseged Tamene: 0000-0002-3806-8890
&quot;Desta, Lulseged Tamene&quot;,Lulseged Tamene: 0000-0002-3806-8890
&quot;Läderach, Peter&quot;,Peter Läderach: 0000-0001-8708-6318
&quot;Lundy, Mark&quot;,Mark Lundy: 0000-0002-5241-3777
&quot;Schultze-Kraft, Rainer&quot;,Rainer Schultze-Kraft: 0000-0002-4563-0044
&quot;Schultze-Kraft, R.&quot;,Rainer Schultze-Kraft: 0000-0002-4563-0044
&quot;Verchot, Louis&quot;,Louis Verchot: 0000-0001-8309-6754
&quot;Verchot, L&quot;,Louis Verchot: 0000-0001-8309-6754
&quot;Verchot, L. V.&quot;,Louis Verchot: 0000-0001-8309-6754
&quot;Verchot, L.V&quot;,Louis Verchot: 0000-0001-8309-6754
&quot;Verchot, L.V.&quot;,Louis Verchot: 0000-0001-8309-6754
&quot;Verchot, LV&quot;,Louis Verchot: 0000-0001-8309-6754
&quot;Verchot, Louis V.&quot;,Louis Verchot: 0000-0001-8309-6754
&quot;Mukankusi, Clare&quot;,Clare Mukankusi: 0000-0001-7837-4545
&quot;Mukankusi, Clare M.&quot;,Clare Mukankusi: 0000-0001-7837-4545
&quot;Wyckhuys, Kris&quot;,Kris Wyckhuys: 0000-0003-0922-488X
&quot;Wyckhuys, Kris A. G.&quot;,Kris Wyckhuys: 0000-0003-0922-488X
&quot;Wyckhuys, Kris A.G.&quot;,Kris Wyckhuys: 0000-0003-0922-488X
&quot;Chirinda, Ngonidzashe&quot;,Ngonidzashe Chirinda: 0000-0002-4213-6294
&quot;Chirinda, Ngoni&quot;,Ngonidzashe Chirinda: 0000-0002-4213-6294
&quot;Ngonidzashe, Chirinda&quot;,Ngonidzashe Chirinda: 0000-0002-4213-6294
2019-05-05 15:45:12 +02:00
</code></pre></li>
2018-08-19 17:42:55 +02:00
2019-05-05 15:45:12 +02:00
<li><p>The invocation would be:</p>
2018-08-19 17:42:55 +02:00
<pre><code>$ ./add-orcid-identifiers-csv.py -i 2018-08-16-ciat-orcid.csv -db dspace -u dspace -p 'fuuu'
2019-05-05 15:45:12 +02:00
</code></pre></li>
2018-08-19 17:42:55 +02:00
2019-05-05 15:45:12 +02:00
<li><p>I ran the script on DSpace Test and CGSpace and tagged a total of 986 ORCID identifiers</p></li>
<li><p>Looking at the list of author affialitions from Peter one last time</p></li>
<li><p>I notice that I should add the Unicode character 0x00b4 (`) to my list of invalid characters to look for in Open Refine, making the latest version of the GREL expression being:</p>
2018-08-19 17:42:55 +02:00
<pre><code>or(
2019-05-05 15:45:12 +02:00
isNotNull(value.match(/.*\uFFFD.*/)),
isNotNull(value.match(/.*\u00A0.*/)),
isNotNull(value.match(/.*\u200A.*/)),
isNotNull(value.match(/.*\u2019.*/)),
isNotNull(value.match(/.*\u00b4.*/))
2018-08-19 17:42:55 +02:00
)
2019-05-05 15:45:12 +02:00
</code></pre></li>
2018-08-19 17:42:55 +02:00
2019-05-05 15:45:12 +02:00
<li><p>This character all by itself is indicative of encoding issues in French, Italian, and Spanish names, for example: De´veloppement and Investigacio´n</p></li>
<li><p>I will run the following on DSpace Test and CGSpace:</p>
2018-08-19 17:42:55 +02:00
<pre><code>$ ./fix-metadata-values.py -i /tmp/2018-08-15-Correct-1083-Affiliations.csv -db dspace -u dspace -p 'fuuu' -f cg.contributor.affiliation -t correct -m 211
$ ./delete-metadata-values.py -i /tmp/2018-08-15-Remove-11-Affiliations.csv -db dspace -u dspace -p 'fuuu' -f cg.contributor.affiliation -m 211
2019-05-05 15:45:12 +02:00
</code></pre></li>
2018-08-19 17:42:55 +02:00
2019-05-05 15:45:12 +02:00
<li><p>Then force an update of the Discovery index on DSpace Test:</p>
2018-08-19 17:42:55 +02:00
<pre><code>$ export JAVA_OPTS=&quot;-Dfile.encoding=UTF-8 -Xmx512m&quot;
$ time schedtool -D -e ionice -c2 -n7 nice -n19 dspace index-discovery -b
real 72m12.570s
user 6m45.305s
sys 2m2.461s
2019-05-05 15:45:12 +02:00
</code></pre></li>
2018-08-19 17:42:55 +02:00
2019-05-05 15:45:12 +02:00
<li><p>And then on CGSpace:</p>
2018-08-19 17:42:55 +02:00
<pre><code>$ export JAVA_OPTS=&quot;-Dfile.encoding=UTF-8 -Xmx1024m&quot;
$ time schedtool -D -e ionice -c2 -n7 nice -n19 dspace index-discovery -b
real 79m44.392s
user 8m50.730s
sys 2m20.248s
2019-05-05 15:45:12 +02:00
</code></pre></li>
2018-08-19 17:42:55 +02:00
2019-05-05 15:45:12 +02:00
<li><p>Run system updates on DSpace Test and reboot the server</p></li>
<li><p>In unrelated news, I see some newish Russian bot making a few thousand requests per day and not re-using its XMLUI session:</p>
2018-08-19 17:42:55 +02:00
<pre><code># cat /var/log/nginx/access.log /var/log/nginx/access.log.1 | grep '19/Aug/2018' | grep -c 5.9.6.51
1553
2018-09-10 23:37:38 +02:00
# grep -c -E 'session_id=[A-Z0-9]{32}:ip_addr=5.9.6.51' dspace.log.2018-08-19
2018-08-19 17:42:55 +02:00
1724
2019-05-05 15:45:12 +02:00
</code></pre></li>
2018-08-19 17:42:55 +02:00
2019-05-05 15:45:12 +02:00
<li><p>I don&rsquo;t even know how its possible for the bot to use MORE sessions than total requests&hellip;</p></li>
<li><p>The user agent is:</p>
2018-08-19 17:42:55 +02:00
<pre><code>Mozilla/5.0 (compatible; MegaIndex.ru/2.0; +http://megaindex.com/crawler)
2019-05-05 15:45:12 +02:00
</code></pre></li>
2018-08-19 17:42:55 +02:00
2019-05-05 15:45:12 +02:00
<li><p>So I&rsquo;m thinking we should add &ldquo;crawl&rdquo; to the Tomcat Crawler Session Manager valve, as we already have &ldquo;bot&rdquo; that catches Googlebot, Bingbot, etc.</p></li>
2018-08-19 17:42:55 +02:00
</ul>
2018-08-20 12:49:43 +02:00
<h2 id="2018-08-20">2018-08-20</h2>
<ul>
<li>Help Sisay with some UTF-8 encoding issues in a file Peter sent him</li>
<li>Finish up reconciling Atmire&rsquo;s pull request for DSpace 5.8 changes with the latest status of our <code>5_x-prod</code> branch</li>
<li>I had to do some <code>git rev-list --reverse --no-merges oldestcommit..newestcommit</code> and <code>git cherry-pick -S</code> hackery to get everything all in order</li>
<li>After building I ran the Atmire schema migrations and forced old migrations, then did the <code>ant update</code></li>
2018-08-20 16:52:38 +02:00
<li>I tried to build it on DSpace Test, but it seems to still need more RAM to complete (like I experienced last month), so I stopped Tomcat and set <code>JAVA_OPTS</code> to 1024m and tried the <code>mvn package</code> again</li>
<li>Still the <code>mvn package</code> takes forever and essentially hangs on processing the xmlui-mirage2 overlay (though after building all the themes)</li>
<li>I will try to reduce Tomcat memory from 4608m to 4096m and then retry the <code>mvn package</code> with 1024m of <code>JAVA_OPTS</code> again</li>
<li>After running the <code>mvn package</code> for the third time and waiting an hour, I attached <code>strace</code> to the Java process and saw that it was indeed reading XMLUI theme data&hellip; so I guess I just need to wait more</li>
<li>After waiting two hours the maven process completed and installation was successful</li>
<li>I restarted Tomcat and it seems everything is working well, so I&rsquo;ll merge the pull request and try to schedule the CGSpace upgrade for this coming Sunday, August 26th</li>
<li>I merged <a href="https://github.com/ilri/DSpace/pull/378">Atmire&rsquo;s pull request</a> into our <code>5_x-dspace-5.8</code> temporary brach and then cherry-picked all the changes from <code>5_x-prod</code> since April, 2018 when that temporary branch was created</li>
<li>As the branch histories are very different I cannot merge the new 5.8 branch into the current <code>5_x-prod</code> branch</li>
<li>Instead, I will archive the current <code>5_x-prod</code> DSpace 5.5 branch as <code>5_x-prod-dspace-5.5</code> and then hard reset <code>5_x-prod</code> based on <code>5_x-dspace-5.8</code></li>
<li>Unfortunately this will mess up the references in pull requests and issues on GitHub</li>
2018-08-20 12:49:43 +02:00
</ul>
2018-08-21 13:41:34 +02:00
<h2 id="2018-08-21">2018-08-21</h2>
<ul>
2019-05-05 15:45:12 +02:00
<li><p>Something must have happened, as the <code>mvn package</code> <em>always</em> takes about two hours now, stopping for a very long time near the end at this step:</p>
2018-08-21 13:41:34 +02:00
<pre><code>[INFO] Processing overlay [ id org.dspace.modules:xmlui-mirage2]
2019-05-05 15:45:12 +02:00
</code></pre></li>
2018-08-21 13:41:34 +02:00
2019-05-05 15:45:12 +02:00
<li><p>It&rsquo;s the same on DSpace Test, my local laptop, and CGSpace&hellip;</p></li>
<li><p>It wasn&rsquo;t this way before when I was constantly building the previous 5.8 branch with Atmire patches&hellip;</p></li>
<li><p>I will restore the previous <code>5_x-dspace-5.8</code> and <code>atmire-module-upgrades-5.8</code> branches to see if the build time is different there</p></li>
<li><p>&hellip; it seems that the <code>atmire-module-upgrades-5.8</code> branch still takes 1 hour and 23 minutes on my local machine&hellip;</p></li>
<li><p>Let me try to build the old <code>5_x-prod-dspace-5.5</code> branch on my local machine and see how long it takes</p></li>
<li><p>That one only took 13 minutes! So there is definitely something wrong with our 5.8 branch, now I should try vanilla DSpace 5.8</p></li>
<li><p>I notice that the step this pauses at is:</p>
2018-08-22 00:42:03 +02:00
<pre><code>[INFO] --- maven-war-plugin:2.4:war (default-war) @ xmlui ---
2019-05-05 15:45:12 +02:00
</code></pre></li>
2018-08-22 00:42:03 +02:00
2019-05-05 15:45:12 +02:00
<li><p>And I notice that Atmire changed something in the XMLUI module&rsquo;s <code>pom.xml</code> as part of the DSpace 5.8 changes, specifically to remove the exclude for <code>node_modules</code> in the <code>maven-war-plugin</code> step</p></li>
<li><p>This exclude is <em>present</em> in vanilla DSpace, and if I add it back the build time goes from 1 hour 23 minutes to 12 minutes!</p></li>
<li><p>It makes sense that it would take longer to complete this step because the <code>node_modules</code> folder has tens of thousands of files, and we have 27 themes!</p></li>
<li><p>I need to test to see if this has any side effects when deployed&hellip;</p></li>
<li><p>In other news, I see there was a pull request in DSpace 5.9 that fixes the issue with not being able to have blank lines in CSVs when importing via command line or webui (<a href="https://jira.duraspace.org/browse/DS-3245">DS-3245</a>)</p></li>
2018-08-21 13:41:34 +02:00
</ul>
2018-08-23 09:49:23 +02:00
<h2 id="2018-08-23">2018-08-23</h2>
<ul>
<li>Skype meeting with CKM people to meet new web dev guy Tariku</li>
<li>They say they want to start working on the ContentDM harvester middleware again</li>
<li>I sent a list of the top 1500 author affiliations on CGSpace to CodeObia so we can compare ours with the ones on MELSpace</li>
2018-08-23 15:34:16 +02:00
<li>Discuss CTA items with Sisay, he was trying to figure out how to do the collection mapping in combination with SAFBuilder</li>
<li>It appears that the web UI&rsquo;s upload interface <em>requires</em> you to specify the collection, whereas the CLI interface allows you to omit the collection command line flag and defer to the <code>collections</code> file inside each item in the bundle</li>
2019-05-05 15:45:12 +02:00
<li><p>I imported the CTA items on CGSpace for Sisay:</p>
2018-08-23 09:49:23 +02:00
2018-08-23 15:34:16 +02:00
<pre><code>$ dspace import -a -e s.webshet@cgiar.org -s /home/swebshet/ictupdates_uploads_August_21 -m /tmp/2018-08-23-cta-ictupdates.map
2019-05-05 15:45:12 +02:00
</code></pre></li>
</ul>
2018-08-23 15:34:16 +02:00
2018-08-26 08:38:15 +02:00
<h2 id="2018-08-26">2018-08-26</h2>
<ul>
<li>Doing the DSpace 5.8 upgrade on CGSpace (linode18)</li>
2019-05-05 15:45:12 +02:00
<li><p>I already finished the Maven build, now I&rsquo;ll take a backup of the PostgreSQL database and do a database cleanup just in case:</p>
2018-08-26 08:38:15 +02:00
<pre><code>$ pg_dump -b -v -o --format=custom -U dspace -f dspace-2018-08-26-before-dspace-58.backup dspace
$ dspace cleanup -v
2019-05-05 15:45:12 +02:00
</code></pre></li>
2018-08-26 08:38:15 +02:00
2019-05-05 15:45:12 +02:00
<li><p>Now I can stop Tomcat and do the install:</p>
2018-08-26 08:38:15 +02:00
<pre><code>$ cd dspace/target/dspace-installer
$ ant update clean_backups update_geolite
2019-05-05 15:45:12 +02:00
</code></pre></li>
2018-08-26 08:38:15 +02:00
2019-05-05 15:45:12 +02:00
<li><p>After the successful Ant update I can run the database migrations:</p>
2018-08-26 08:38:15 +02:00
<pre><code>$ psql dspace dspace
dspace=&gt; \i /tmp/Atmire-DSpace-5.8-Schema-Migration.sql
DELETE 0
UPDATE 1
DELETE 1
dspace=&gt; \q
$ dspace database migrate ignored
2019-05-05 15:45:12 +02:00
</code></pre></li>
2018-08-26 08:38:15 +02:00
2019-05-05 15:45:12 +02:00
<li><p>Then I&rsquo;ll run all system updates and reboot the server:</p>
2018-08-26 08:38:15 +02:00
<pre><code>$ sudo su -
# apt update &amp;&amp; apt full-upgrade
# apt clean &amp;&amp; apt autoclean &amp;&amp; apt autoremove
# reboot
2019-05-05 15:45:12 +02:00
</code></pre></li>
2018-08-26 08:38:15 +02:00
2019-05-05 15:45:12 +02:00
<li><p>After reboot I logged in and cleared all the XMLUI caches and everything looked to be working fine</p></li>
<li><p>Adam from WLE had asked a few weeks ago about getting the metadata for a bunch of items related to gender from 2013 until now</p></li>
<li><p>They want a CSV with <em>all</em> metadata, which the Atmire Listings and Reports module can&rsquo;t do</p></li>
<li><p>I exported a list of items from Listings and Reports with the following criteria: from year 2013 until now, have WLE subject <code>GENDER</code> or <code>GENDER POVERTY AND INSTITUTIONS</code>, and CRP <code>Water, Land and Ecosystems</code></p></li>
<li><p>Then I extracted the Handle links from the report so I could export each item&rsquo;s metadata as CSV</p>
2018-08-27 09:27:13 +02:00
<pre><code>$ grep -o -E &quot;[0-9]{5}/[0-9]{0,5}&quot; listings-export.txt &gt; /tmp/iwmi-gender-items.txt
2019-05-05 15:45:12 +02:00
</code></pre></li>
2018-08-27 09:27:13 +02:00
2019-05-05 15:45:12 +02:00
<li><p>Then on the DSpace server I exported the metadata for each item one by one:</p>
2018-08-27 09:27:13 +02:00
<pre><code>$ while read -r line; do dspace metadata-export -f &quot;/tmp/${line/\//-}.csv&quot; -i $line; sleep 2; done &lt; /tmp/iwmi-gender-items.txt
2019-05-05 15:45:12 +02:00
</code></pre></li>
2018-08-27 09:27:13 +02:00
2019-05-05 15:45:12 +02:00
<li><p>But from here I realized that each of the fifty-nine items will have different columns in their CSVs, making it difficult to combine them</p></li>
<li><p>I&rsquo;m not sure how to proceed without writing some script to parse and join the CSVs, and I don&rsquo;t think it&rsquo;s worth my time</p></li>
<li><p>I tested DSpace 5.8 in Tomcat 8.5.32 and it seems to work now, so I&rsquo;m not sure why I got those errors last time I tried</p></li>
<li><p>It could have been a configuration issue, though, as I also reconciled the <code>server.xml</code> with the one in <a href="https://github.com/ilri/rmg-ansible-public">our Ansible infrastructure scripts</a></p></li>
<li><p>But now I can start testing and preparing to move DSpace Test to Ubuntu 18.04 + Tomcat 8.5 + OpenJDK + PostgreSQL 9.6&hellip;</p></li>
<li><p>Actually, upon closer inspection, it seems that when you try to go to Listings and Reports under Tomcat 8.5.33 you are taken to the JSPUI login page despite having already logged in in XMLUI</p></li>
<li><p>If I type my username and password again it <em>does</em> take me to Listings and Reports, though&hellip;</p></li>
<li><p>I don&rsquo;t see anything interesting in the Catalina or DSpace logs, so I might have to file a bug with Atmire</p></li>
<li><p>For what it&rsquo;s worth, the Content and Usage (CUA) module does load, though I can&rsquo;t seem to get any results in the graph</p></li>
<li><p>I just checked to see if the Listings and Reports issue with using the CGSpace citation field was fixed as planned alongside the DSpace 5.8 upgrades (<a href="https://tracker.atmire.com/tickets-cgiar-ilri/view-ticket?id=589">#589</a></p></li>
<li><p>I was able to create a new layout containing only the citation field, so I closed the ticket</p></li>
2018-08-26 08:38:15 +02:00
</ul>
2018-08-29 17:00:56 +02:00
<h2 id="2018-08-29">2018-08-29</h2>
<ul>
<li>Discuss <a href="https://copo-project.org/copo/">COPO</a> with Martin Mueller</li>
<li>He and the consortium&rsquo;s idea is to use this for metadata annotation (submission?) to all repositories</li>
<li>It is somehow related to adding events as items in the repository, and then linking related papers, presentations, etc to the event item using <code>dc.relation</code>, etc.</li>
<li>Discuss Linode server charges with Abenet, apparently we want to start charging these to Big Data</li>
</ul>
2018-08-30 15:29:19 +02:00
<h2 id="2018-08-30">2018-08-30</h2>
<ul>
<li>I fixed the graphical glitch in the cookieconsent popup (the dismiss bug is still there) by pinning the last known good version (3.0.6) in <code>bower.json</code> of each XMLUI theme</li>
<li>I guess cookieconsent got updated without me realizing it and the previous expression <code>^3.0.6</code> make bower install version 3.1.0</li>
</ul>
2018-08-01 11:49:05 +02:00
<!-- vim: set sw=2 ts=2: -->
</article>
</div> <!-- /.blog-main -->
<aside class="col-sm-3 ml-auto blog-sidebar">
<section class="sidebar-module">
<h4>Recent Posts</h4>
<ol class="list-unstyled">
2019-08-04 21:49:04 +02:00
<li><a href="/cgspace-notes/2019-08/">August, 2019</a></li>
2019-04-01 08:02:18 +02:00
2019-04-13 11:15:55 +02:00
<li><a href="/cgspace-notes/posts/">Posts</a></li>
2019-08-04 21:49:04 +02:00
<li><a href="/cgspace-notes/2019-07/">July, 2019</a></li>
2019-07-01 11:22:43 +02:00
<li><a href="/cgspace-notes/2019-06/">June, 2019</a></li>
2019-06-02 09:57:51 +02:00
<li><a href="/cgspace-notes/2019-05/">May, 2019</a></li>
2018-08-01 11:49:05 +02:00
</ol>
</section>
<section class="sidebar-module">
<h4>Links</h4>
<ol class="list-unstyled">
<li><a href="https://cgspace.cgiar.org">CGSpace</a></li>
<li><a href="https://dspacetest.cgiar.org">DSpace Test</a></li>
<li><a href="https://github.com/ilri/DSpace">CGSpace @ GitHub</a></li>
</ol>
</section>
</aside>
</div> <!-- /.row -->
</div> <!-- /.container -->
<footer class="blog-footer">
<p>
Blog template created by <a href="https://twitter.com/mdo">@mdo</a>, ported to Hugo by <a href='https://twitter.com/mralanorth'>@mralanorth</a>.
</p>
<p>
<a href="#">Back to top</a>
</p>
</footer>
</body>
</html>