mirror of
https://github.com/alanorth/cgspace-notes.git
synced 2024-12-23 05:32:20 +01:00
587 lines
35 KiB
HTML
587 lines
35 KiB
HTML
<!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="January, 2024" />
|
|
<meta property="og:description" content="2024-01-02
|
|
|
|
Work on preparation of new server for DSpace 7 migration
|
|
|
|
I’m not quite sure what we need to do for the Handle server
|
|
For now I just ran the dspace make-handle-config script and diffed it with the one from DSpace 6
|
|
I sent the bundle to the Handle admins to make sure it’s OK before we do the migration
|
|
|
|
|
|
Continue testing and debugging the cgspace-java-helpers on DSpace 7
|
|
Work on IFPRI ISNAR archive cleanup
|
|
" />
|
|
<meta property="og:type" content="article" />
|
|
<meta property="og:url" content="https://alanorth.github.io/cgspace-notes/2024-01/" />
|
|
<meta property="article:published_time" content="2024-01-02T10:08:00+03:00" />
|
|
<meta property="article:modified_time" content="2024-01-10T17:21:12+03:00" />
|
|
|
|
|
|
|
|
<meta name="twitter:card" content="summary"/>
|
|
<meta name="twitter:title" content="January, 2024"/>
|
|
<meta name="twitter:description" content="2024-01-02
|
|
|
|
Work on preparation of new server for DSpace 7 migration
|
|
|
|
I’m not quite sure what we need to do for the Handle server
|
|
For now I just ran the dspace make-handle-config script and diffed it with the one from DSpace 6
|
|
I sent the bundle to the Handle admins to make sure it’s OK before we do the migration
|
|
|
|
|
|
Continue testing and debugging the cgspace-java-helpers on DSpace 7
|
|
Work on IFPRI ISNAR archive cleanup
|
|
"/>
|
|
<meta name="generator" content="Hugo 0.121.2">
|
|
|
|
|
|
|
|
<script type="application/ld+json">
|
|
{
|
|
"@context": "http://schema.org",
|
|
"@type": "BlogPosting",
|
|
"headline": "January, 2024",
|
|
"url": "https://alanorth.github.io/cgspace-notes/2024-01/",
|
|
"wordCount": "1847",
|
|
"datePublished": "2024-01-02T10:08:00+03:00",
|
|
"dateModified": "2024-01-10T17:21:12+03:00",
|
|
"author": {
|
|
"@type": "Person",
|
|
"name": "Alan Orth"
|
|
},
|
|
"keywords": "Notes"
|
|
}
|
|
</script>
|
|
|
|
|
|
|
|
<link rel="canonical" href="https://alanorth.github.io/cgspace-notes/2024-01/">
|
|
|
|
<title>January, 2024 | CGSpace Notes</title>
|
|
|
|
|
|
<!-- combined, minified CSS -->
|
|
|
|
<link href="https://alanorth.github.io/cgspace-notes/css/style.c6ba80bc50669557645abe05f86b73cc5af84408ed20f1551a267bc19ece8228.css" rel="stylesheet" integrity="sha256-xrqAvFBmlVdkWr4F+GtzzFr4RAjtIPFVGiZ7wZ7Ogig=" crossorigin="anonymous">
|
|
|
|
|
|
<!-- minified Font Awesome for SVG icons -->
|
|
|
|
<script defer src="https://alanorth.github.io/cgspace-notes/js/fontawesome.min.f5072c55a0721857184db93a50561d7dc13975b4de2e19db7f81eb5f3fa57270.js" integrity="sha256-9QcsVaByGFcYTbk6UFYdfcE5dbTeLhnbf4HrXz+lcnA=" crossorigin="anonymous"></script>
|
|
|
|
<!-- RSS 2.0 feed -->
|
|
|
|
|
|
|
|
|
|
</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>
|
|
|
|
|
|
|
|
|
|
<header class="blog-header">
|
|
<div class="container">
|
|
<h1 class="blog-title" dir="auto"><a href="https://alanorth.github.io/cgspace-notes/" rel="home">CGSpace Notes</a></h1>
|
|
<p class="lead blog-description" dir="auto">Documenting day-to-day work on the <a href="https://cgspace.cgiar.org">CGSpace</a> repository.</p>
|
|
</div>
|
|
</header>
|
|
|
|
|
|
|
|
|
|
<div class="container">
|
|
<div class="row">
|
|
<div class="col-sm-8 blog-main">
|
|
|
|
|
|
|
|
|
|
<article class="blog-post">
|
|
<header>
|
|
<h2 class="blog-post-title" dir="auto"><a href="https://alanorth.github.io/cgspace-notes/2024-01/">January, 2024</a></h2>
|
|
<p class="blog-post-meta">
|
|
<time datetime="2024-01-02T10:08:00+03:00">Tue Jan 02, 2024</time>
|
|
in
|
|
<span class="fas fa-folder" aria-hidden="true"></span> <a href="/categories/notes/" rel="category tag">Notes</a>
|
|
|
|
|
|
</p>
|
|
</header>
|
|
<h2 id="2024-01-02">2024-01-02</h2>
|
|
<ul>
|
|
<li>Work on preparation of new server for DSpace 7 migration
|
|
<ul>
|
|
<li>I’m not quite sure what we need to do for the Handle server</li>
|
|
<li>For now I just ran the <code>dspace make-handle-config</code> script and diffed it with the one from DSpace 6</li>
|
|
<li>I sent the bundle to the Handle admins to make sure it’s OK before we do the migration</li>
|
|
</ul>
|
|
</li>
|
|
<li>Continue testing and debugging the cgspace-java-helpers on DSpace 7</li>
|
|
<li>Work on IFPRI ISNAR archive cleanup</li>
|
|
</ul>
|
|
<h2 id="2024-01-03">2024-01-03</h2>
|
|
<ul>
|
|
<li>I haven’t heard from the Handle admins so I’m preparing a backup solution using nginx streams</li>
|
|
<li>This seems to work in my simple tests (this must be outside the <code>http {}</code> block):</li>
|
|
</ul>
|
|
<pre tabindex="0"><code>stream {
|
|
upstream handle_tcp_9000 {
|
|
server 188.34.177.10:9000;
|
|
}
|
|
|
|
server {
|
|
listen 9000;
|
|
proxy_connect_timeout 1s;
|
|
proxy_timeout 3s;
|
|
proxy_pass handle_tcp_9000;
|
|
}
|
|
}
|
|
</code></pre><ul>
|
|
<li>Here I forwarded a test TCP port 9000 from one server to another and was able to retrieve a test HTML that was running on the target
|
|
<ul>
|
|
<li>I will have to do TCP and UDP on port 2641, and TCP/HTTP on port 8000.</li>
|
|
</ul>
|
|
</li>
|
|
<li>I did some more minor work on the IFPRI ISNAR archive
|
|
<ul>
|
|
<li>I got some PDFs from the UMN AgEcon search and fixed some metadata</li>
|
|
<li>Then I did some duplicate checking and found five items already on CGSpace</li>
|
|
</ul>
|
|
</li>
|
|
</ul>
|
|
<h2 id="2024-01-04">2024-01-04</h2>
|
|
<ul>
|
|
<li>Upload 692 items for the ISNAR archive to CGSpace: <a href="https://cgspace.cgiar.org/handle/10568/136192">https://cgspace.cgiar.org/handle/10568/136192</a></li>
|
|
<li>Help Peter proof and upload 252 items from the 2023 Gender conference to CGSpace</li>
|
|
<li>Meeting with IFPRI to discuss their migration to CGSpace
|
|
<ul>
|
|
<li>We agreed to add two new fields, one for IFPRI project and one for IFPRI publication ranking</li>
|
|
<li>Most likely we will use <code>cg.identifier.project</code> as a general field and consolidate other project fields there</li>
|
|
<li>Not sure which field to use for the publication rank…</li>
|
|
</ul>
|
|
</li>
|
|
</ul>
|
|
<h2 id="2024-01-05">2024-01-05</h2>
|
|
<ul>
|
|
<li>Proof and upload 51 items in bulk for IFPRI</li>
|
|
<li>I did a big cleanup of user groups in anticipation of complaints about slow workflow tasks etc in DSpace 7
|
|
<ul>
|
|
<li>I removed ILRI editors from all the dozens of CCAFS community and collection groups, and I should do the same for other CRPs since they are closed for two years now</li>
|
|
</ul>
|
|
</li>
|
|
</ul>
|
|
<h2 id="2024-01-06">2024-01-06</h2>
|
|
<ul>
|
|
<li>Migrate CGSpace to DSpace 7</li>
|
|
</ul>
|
|
<h2 id="2024-01-07">2024-01-07</h2>
|
|
<ul>
|
|
<li>High load on the server and UptimeRobot saying the frontend is flapping
|
|
<ul>
|
|
<li>I noticed tons of logs from pm2 in the systemd journal, so I disabled those in the systemd unit because they are available from pm2’s log directory anyway</li>
|
|
<li>I also noticed the same for Solr, so I disabled stdout for that systemd unit as well</li>
|
|
</ul>
|
|
</li>
|
|
<li>I spent a lot of time bringing back the nginx rate limits we used in DSpace 6 and it seems to have helped</li>
|
|
<li>I see some client doing weird HEAD requests to search pages:</li>
|
|
</ul>
|
|
<pre tabindex="0"><code>47.76.35.19 - - [07/Jan/2024:00:00:02 +0100] "HEAD /search/?f.accessRights=Open+Access%2Cequals&f.actionArea=Resilient+Agrifood+Systems%2Cequals&f.author=Burkart%2C+Stefan%2Cequals&f.country=Kenya%2Cequals&f.impactArea=Climate+adaptation+and+mitigation%2Cequals&f.itemtype=Brief%2Cequals&f.publisher=CGIAR+System+Organization%2Cequals&f.region=Asia%2Cequals&f.sdg=SDG+12+-+Responsible+consumption+and+production%2Cequals&f.sponsorship=CGIAR+Trust+Fund%2Cequals&f.subject=environmental+factors%2Cequals&spc.page=1 HTTP/1.1" 499 0 "-" "Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/74.0.2504.63 Safari/537.36"
|
|
</code></pre><ul>
|
|
<li>I will add their network blocks (AS45102) and regenerate my list of bot networks:</li>
|
|
</ul>
|
|
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>$ wget https://asn.ipinfo.app/api/text/list/AS16276 <span style="color:#ae81ff">\
|
|
</span></span></span><span style="display:flex;"><span><span style="color:#ae81ff"></span> https://asn.ipinfo.app/api/text/list/AS23576 \
|
|
</span></span><span style="display:flex;"><span> https://asn.ipinfo.app/api/text/list/AS24940 \
|
|
</span></span><span style="display:flex;"><span> https://asn.ipinfo.app/api/text/list/AS13238 \
|
|
</span></span><span style="display:flex;"><span> https://asn.ipinfo.app/api/text/list/AS14061 \
|
|
</span></span><span style="display:flex;"><span> https://asn.ipinfo.app/api/text/list/AS12876 \
|
|
</span></span><span style="display:flex;"><span> https://asn.ipinfo.app/api/text/list/AS55286 \
|
|
</span></span><span style="display:flex;"><span> https://asn.ipinfo.app/api/text/list/AS203020 \
|
|
</span></span><span style="display:flex;"><span> https://asn.ipinfo.app/api/text/list/AS204287 \
|
|
</span></span><span style="display:flex;"><span> https://asn.ipinfo.app/api/text/list/AS50245 \
|
|
</span></span><span style="display:flex;"><span> https://asn.ipinfo.app/api/text/list/AS6939 \
|
|
</span></span><span style="display:flex;"><span> https://asn.ipinfo.app/api/text/list/AS45102 \
|
|
</span></span><span style="display:flex;"><span> https://asn.ipinfo.app/api/text/list/AS21859
|
|
</span></span><span style="display:flex;"><span>$ cat AS* | sort | uniq | wc -l
|
|
</span></span><span style="display:flex;"><span>4897
|
|
</span></span><span style="display:flex;"><span>$ cat AS* | ~/go/bin/mapcidr -a > /tmp/networks.txt
|
|
</span></span><span style="display:flex;"><span>$ wc -l /tmp/networks.txt
|
|
</span></span><span style="display:flex;"><span>2017 /tmp/networks.txt
|
|
</span></span></code></pre></div><ul>
|
|
<li>I’m surprised to see the number of networks reduced from my current ones… hmmm.</li>
|
|
<li>I will also update my list of Bing networks:</li>
|
|
</ul>
|
|
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>$ ./ilri/bing-networks-to-ips.sh
|
|
</span></span><span style="display:flex;"><span>$ ~/go/bin/mapcidr -a < /tmp/bing-ips.txt > /tmp/bing-networks.txt
|
|
</span></span><span style="display:flex;"><span>$ wc -l /tmp/bing-networks.txt
|
|
</span></span><span style="display:flex;"><span>250 /tmp/bing-networks.txt
|
|
</span></span></code></pre></div><h2 id="2024-01-08">2024-01-08</h2>
|
|
<ul>
|
|
<li>Export list of publishers for Peter to select some amount to use as a controlled vocabulary:</li>
|
|
</ul>
|
|
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>localhost/dspace7= ☘ \COPY (SELECT DISTINCT text_value AS "dcterms.publisher", count(*) FROM metadatavalue WHERE dspace_object_id in (SELECT dspace_object_id FROM item) AND metadata_field_id = 178 GROUP BY "dcterms.publisher" ORDER BY count DESC) to /tmp/2024-01-publishers.csv WITH CSV HEADER;
|
|
</span></span><span style="display:flex;"><span>COPY 4332
|
|
</span></span></code></pre></div><ul>
|
|
<li>Address some feedback on DSpace 7 from users, including fileing some issues on GitHub
|
|
<ul>
|
|
<li><a href="https://github.com/DSpace/dspace-angular/issues/2730">https://github.com/DSpace/dspace-angular/issues/2730</a>: List of available metadata fields is truncated when adding new metadata in “Edit Item”</li>
|
|
</ul>
|
|
</li>
|
|
<li>The Alliance TIP team was having issues posting to one collection via the legacy DSpace 6 REST API
|
|
<ul>
|
|
<li>In the DSpace logs I see the same issue that they had last month:</li>
|
|
</ul>
|
|
</li>
|
|
</ul>
|
|
<pre tabindex="0"><code>ERROR unknown unknown org.dspace.rest.Resource @ Something get wrong. Aborting context in finally statement.
|
|
</code></pre><h2 id="2024-01-09">2024-01-09</h2>
|
|
<ul>
|
|
<li>I restarted Tomcat to see if it helps the REST issue</li>
|
|
<li>After talking with Peter about publishers we decided to get a clean list of the top ~100 publishers and then make sure all CGIAR centers, Initiatives, and Impact Platforms are there as well
|
|
<ul>
|
|
<li>I exported a list from PostgreSQL and then filtered by count > 40 in OpenRefine and then extracted the metadata values:</li>
|
|
</ul>
|
|
</li>
|
|
</ul>
|
|
<pre tabindex="0"><code>$ csvcut -c dcterms.publisher ~/Downloads/2024-01-09-publishers4.csv | sed -e 1d -e 's/"//g' > /tmp/top-publishers.txt
|
|
</code></pre><ul>
|
|
<li>Export a list of ORCID identifiers from PostgreSQL to look them up on ORCID and update our controlled vocabulary:</li>
|
|
</ul>
|
|
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>localhost/dspace7= ☘ \COPY (SELECT DISTINCT(text_value) FROM metadatavalue WHERE dspace_object_id IN (SELECT uuid FROM item) AND metadata_field_id=247) to /tmp/2024-01-09-orcid-identifiers.txt;
|
|
</span></span><span style="display:flex;"><span>localhost/dspace7= ☘ \q
|
|
</span></span><span style="display:flex;"><span>$ cat ~/src/git/DSpace/dspace/config/controlled-vocabularies/cg-creator-identifier.xml /tmp/2024-01-09-orcid-identifiers.txt | grep -oE <span style="color:#e6db74">'[A-Z0-9]{4}-[A-Z0-9]{4}-[A-Z0-9]{4}-[A-Z0-9]{4}'</span> | sort -u > /tmp/2024-01-09-orcids.txt
|
|
</span></span><span style="display:flex;"><span>$ ./ilri/resolve_orcids.py -i /tmp/2024-01-09-orcids.txt -o /tmp/2024-01-09-orcids-names.txt -d
|
|
</span></span></code></pre></div><ul>
|
|
<li>Then I updated existing ORCID identifiers in CGSpace:</li>
|
|
</ul>
|
|
<pre tabindex="0"><code>$ ./ilri/update_orcids.py -i /tmp/2024-01-09-orcids-names.txt -db dspace -u dspace -p bahhhh
|
|
</code></pre><ul>
|
|
<li>Bizu seems to be having issues due to belonging to too many groups
|
|
<ul>
|
|
<li>I see some messages from Solr in the DSpace log:</li>
|
|
</ul>
|
|
</li>
|
|
</ul>
|
|
<pre tabindex="0"><code>2024-01-09 06:23:35,893 ERROR unknown unknown org.dspace.authorize.AuthorizeServiceImpl @ Failed getting getting community/collection admin status for bahhhhh@cgiar.org The search error is: Error from server at http://localhost:8983/solr/search: org.apache.solr.search.SyntaxError: Cannot parse 'search.resourcetype:Community AND (admin:eef481147-daf3-4fd2-bb8d-e18af8131d8c OR admin:g80199ef9-bcd6-4961-9512-501dea076607 OR admin:g4ac29263-cf0c-48d0-8be7-7f09317d50ec OR admin:g0e594148-a0f6-4f00-970d-6b7812f89540 OR admin:g0265b87a-2183-4357-a971-7a5b0c7add3a OR admin:g371ae807-f014-4305-b4ec-f2a8f6f0dcfa OR admin:gdc5cb27c-4a5a-45c2-b656-a399fded70de OR admin:ge36d0ece-7a52-4925-afeb-6641d6a348cc OR admin:g15dc1173-7ddf-43cf-a89a-77a7f81c4cfc OR admin:gc3a599d3-c758-46cd-9855-c98f6ab58ae4 OR admin:g3d648c3e-58c3-4342-b500-07cba10ba52d OR admin:g82bf5168-65c1-4627-8eb4-724fa0ea51a7 OR admin:ge751e973-697d-419c-b59b-5a5644702874 OR admin:g44dd0a80-c1e6-4274-9be4-9f342d74928c OR admin:g4842f9c2-73ed-476a-a81a-7167d8aa7946 OR admin:g5f279b3f-c2ce-4c75-b151-1de52c1a540e OR admin:ga6df8adc-2e1d-40f2-8f1e-f77796d0eecd OR admin:gfdfc1621-382e-437a-8674-c9007627565c OR admin:g15cd114a-0b89-442b-a1b4-1febb6959571 OR admin:g12aede99-d018-4c00-b4d4-a732541d0017 OR admin:gc59529d7-002a-4216-b2e1-d909afd2d4a9 OR admin:gd0806714-bc13-460d-bedd-121bdd5436a4 OR admin:gce70739a-8820-4d56-b19c-f191855479e4 OR admin:g7d3409eb-81e3-4156-afb1-7f02de22065f OR admin:g54bc009e-2954-4dad-8c30-be6a09dc5093 OR admin:gc5e1d6b7-4603-40d7-852f-6654c159dec9 OR admin:g0046214d-c85b-4f12-a5e6-2f57a2c3abb0 OR admin:g4c7b4fd0-938f-40e9-ab3e-447c317296c1 OR admin:gcfae9b69-d8dd-4cf3-9a4e-d6e31ff68731 OR ... admin:g20f366c0-96c0-4416-ad0b-46884010925f)': too many boolean clauses The search resourceType filter was: search.resourcetype:Community
|
|
</code></pre><ul>
|
|
<li>There are 1,805 OR clauses in the full log!
|
|
<ul>
|
|
<li>We previous had this issue in 2020-01 and 2020-02 with DSpace 5 and DSpace 6</li>
|
|
<li>At the time the solution was to increase the <code>maxBooleanClauses</code> in Solr and to disable access rights awareness, but I don’t think we want to do the second one now</li>
|
|
<li>I saw many users of Solr in other applications increasing this to obscenely high numbers, so I think we should be OK to increase it from 1024 to 2048</li>
|
|
</ul>
|
|
</li>
|
|
<li>Re-visiting the DSpace user groomer to delete inactive users
|
|
<ul>
|
|
<li>In 2023-08 I noticed that this was now <a href="https://github.com/DSpace/DSpace/pull/2928">possible in DSpace 7</a></li>
|
|
<li>As a test I tried to delete all users who have been inactive since six years ago (Janury 9, 2018):</li>
|
|
</ul>
|
|
</li>
|
|
</ul>
|
|
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>$ dspace dsrun org.dspace.eperson.Groomer -a -b 01/09/2018 -d
|
|
</span></span></code></pre></div><ul>
|
|
<li>I tested it on DSpace 7 Test and it worked… I am debating running it on CGSpace…
|
|
<ul>
|
|
<li>I see we have almost 9,000 users:</li>
|
|
</ul>
|
|
</li>
|
|
</ul>
|
|
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>$ dspace user -L > /tmp/users-before.txt
|
|
</span></span><span style="display:flex;"><span>$ wc -l /tmp/users-before.txt
|
|
</span></span><span style="display:flex;"><span>8943 /tmp/users-before.txt
|
|
</span></span></code></pre></div><ul>
|
|
<li>I decided to do the same on CGSpace and it worked without errors</li>
|
|
<li>I finished working on the controlled vocabulary for publishers</li>
|
|
</ul>
|
|
<h2 id="2024-01-10">2024-01-10</h2>
|
|
<ul>
|
|
<li>I spent some time deleting old groups on CGSpace</li>
|
|
<li>I looked into the use of the <code>cg.identifier.ciatproject</code> field and found there are only a handful of uses, with some even seeming to be a mistake:</li>
|
|
</ul>
|
|
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>localhost/dspace7= ☘ SELECT DISTINCT text_value AS "cg.identifier.ciatproject", count(*) FROM metadatavalue WHERE dspace_object_id in (SELECT dspace_object_id FROM item) AND metadata
|
|
</span></span><span style="display:flex;"><span>_field_id = 232 GROUP BY "cg.identifier.ciatproject" ORDER BY count DESC;
|
|
</span></span><span style="display:flex;"><span> cg.identifier.ciatproject │ count
|
|
</span></span><span style="display:flex;"><span>───────────────────────────┼───────
|
|
</span></span><span style="display:flex;"><span> D145 │ 4
|
|
</span></span><span style="display:flex;"><span> LAM_LivestockPlus │ 2
|
|
</span></span><span style="display:flex;"><span> A215 │ 1
|
|
</span></span><span style="display:flex;"><span> A217 │ 1
|
|
</span></span><span style="display:flex;"><span> A220 │ 1
|
|
</span></span><span style="display:flex;"><span> A223 │ 1
|
|
</span></span><span style="display:flex;"><span> A224 │ 1
|
|
</span></span><span style="display:flex;"><span> A227 │ 1
|
|
</span></span><span style="display:flex;"><span> A229 │ 1
|
|
</span></span><span style="display:flex;"><span> A230 │ 1
|
|
</span></span><span style="display:flex;"><span> CLIMATE CHANGE MITIGATION │ 1
|
|
</span></span><span style="display:flex;"><span> LIVESTOCK │ 1
|
|
</span></span><span style="display:flex;"><span>(12 rows)
|
|
</span></span><span style="display:flex;"><span><span style="color:#960050;background-color:#1e0010">
|
|
</span></span></span><span style="display:flex;"><span><span style="color:#960050;background-color:#1e0010"></span>Time: 240.041 ms
|
|
</span></span></code></pre></div><ul>
|
|
<li>I think we can move those to a new <code>cg.identifier.project</code> if we create one</li>
|
|
<li>The <code>cg.identifier.cpwfproject</code> field is similarly sparse, but the CCAFS ones are widely used</li>
|
|
</ul>
|
|
<h2 id="2024-01-12">2024-01-12</h2>
|
|
<ul>
|
|
<li>Export a list of affiliations to do some cleanup:</li>
|
|
</ul>
|
|
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>localhost/dspace7= ☘ \COPY (SELECT DISTINCT text_value AS "cg.contributor.affiliation", count(*) FROM metadatavalue WHERE dspace_object_id in (SELECT dspace_object_id FROM item) AND metadata_field_id = 211 GROUP BY "cg.contributor.affiliation" ORDER BY count DESC) to /tmp/2024-01-affiliations.csv WITH CSV HEADER;
|
|
</span></span><span style="display:flex;"><span>COPY 11719
|
|
</span></span></code></pre></div><ul>
|
|
<li>I first did some clustering and editing in OpenRefine, then I’ll import those back into CGSpace and then do another export</li>
|
|
<li>Troubleshooting the statistics pages that aren’t working on DSpace 7
|
|
<ul>
|
|
<li>On a hunch, I queried for for Solr statistics documents that <strong>did not have an <code>id</code> matching the 36-character UUID pattern</strong>:</li>
|
|
</ul>
|
|
</li>
|
|
</ul>
|
|
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>$ curl <span style="color:#e6db74">'http://localhost:8983/solr/statistics/select?q=-id%3A%2F.\{36\}%2F&rows=0'</span>
|
|
</span></span><span style="display:flex;"><span>{
|
|
</span></span><span style="display:flex;"><span> "responseHeader":{
|
|
</span></span><span style="display:flex;"><span> "status":0,
|
|
</span></span><span style="display:flex;"><span> "QTime":0,
|
|
</span></span><span style="display:flex;"><span> "params":{
|
|
</span></span><span style="display:flex;"><span> "q":"-id:/.{36}/",
|
|
</span></span><span style="display:flex;"><span> "rows":"0"}},
|
|
</span></span><span style="display:flex;"><span> "response":{"numFound":800167,"start":0,"numFoundExact":true,"docs":[]
|
|
</span></span><span style="display:flex;"><span> }}
|
|
</span></span></code></pre></div><ul>
|
|
<li>They seem to come mostly from 2020, 2023, and 2024:</li>
|
|
</ul>
|
|
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>$ curl <span style="color:#e6db74">'http://localhost:8983/solr/statistics/select?q=-id%3A%2F.\{36\}%2F&facet.range=time&facet=true&facet.range.start=2010-01-01T00:00:00Z&facet.range.end=NOW&facet.range.gap=%2B1YEAR&rows=0'</span>
|
|
</span></span><span style="display:flex;"><span>{
|
|
</span></span><span style="display:flex;"><span> "responseHeader":{
|
|
</span></span><span style="display:flex;"><span> "status":0,
|
|
</span></span><span style="display:flex;"><span> "QTime":13,
|
|
</span></span><span style="display:flex;"><span> "params":{
|
|
</span></span><span style="display:flex;"><span> "facet.range":"time",
|
|
</span></span><span style="display:flex;"><span> "q":"-id:/.{36}/",
|
|
</span></span><span style="display:flex;"><span> "facet.range.gap":"+1YEAR",
|
|
</span></span><span style="display:flex;"><span> "rows":"0",
|
|
</span></span><span style="display:flex;"><span> "facet":"true",
|
|
</span></span><span style="display:flex;"><span> "facet.range.start":"2010-01-01T00:00:00Z",
|
|
</span></span><span style="display:flex;"><span> "facet.range.end":"NOW"}},
|
|
</span></span><span style="display:flex;"><span> "response":{"numFound":800168,"start":0,"numFoundExact":true,"docs":[]
|
|
</span></span><span style="display:flex;"><span> },
|
|
</span></span><span style="display:flex;"><span> "facet_counts":{
|
|
</span></span><span style="display:flex;"><span> "facet_queries":{},
|
|
</span></span><span style="display:flex;"><span> "facet_fields":{},
|
|
</span></span><span style="display:flex;"><span> "facet_ranges":{
|
|
</span></span><span style="display:flex;"><span> "time":{
|
|
</span></span><span style="display:flex;"><span> "counts":[
|
|
</span></span><span style="display:flex;"><span> "2010-01-01T00:00:00Z",0,
|
|
</span></span><span style="display:flex;"><span> "2011-01-01T00:00:00Z",0,
|
|
</span></span><span style="display:flex;"><span> "2012-01-01T00:00:00Z",0,
|
|
</span></span><span style="display:flex;"><span> "2013-01-01T00:00:00Z",0,
|
|
</span></span><span style="display:flex;"><span> "2014-01-01T00:00:00Z",0,
|
|
</span></span><span style="display:flex;"><span> "2015-01-01T00:00:00Z",89,
|
|
</span></span><span style="display:flex;"><span> "2016-01-01T00:00:00Z",11,
|
|
</span></span><span style="display:flex;"><span> "2017-01-01T00:00:00Z",0,
|
|
</span></span><span style="display:flex;"><span> "2018-01-01T00:00:00Z",0,
|
|
</span></span><span style="display:flex;"><span> "2019-01-01T00:00:00Z",0,
|
|
</span></span><span style="display:flex;"><span> "2020-01-01T00:00:00Z",1339,
|
|
</span></span><span style="display:flex;"><span> "2021-01-01T00:00:00Z",0,
|
|
</span></span><span style="display:flex;"><span> "2022-01-01T00:00:00Z",0,
|
|
</span></span><span style="display:flex;"><span> "2023-01-01T00:00:00Z",653736,
|
|
</span></span><span style="display:flex;"><span> "2024-01-01T00:00:00Z",144993],
|
|
</span></span><span style="display:flex;"><span> "gap":"+1YEAR",
|
|
</span></span><span style="display:flex;"><span> "start":"2010-01-01T00:00:00Z",
|
|
</span></span><span style="display:flex;"><span> "end":"2025-01-01T00:00:00Z"}},
|
|
</span></span><span style="display:flex;"><span> "facet_intervals":{},
|
|
</span></span><span style="display:flex;"><span> "facet_heatmaps":{}}}
|
|
</span></span></code></pre></div><ul>
|
|
<li>They seem to come from 2023-08 until now (so way before we migrated to DSpace 7):</li>
|
|
</ul>
|
|
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>$ curl <span style="color:#e6db74">'http://localhost:8983/solr/statistics/select?q=-id%3A%2F.\{36\}%2F&facet.range=time&facet=true&facet.range.start=2023-01-01T00:00:00Z&facet.range.end=NOW&facet.range.gap=%2B1MONTH&rows=0'</span>
|
|
</span></span><span style="display:flex;"><span>{
|
|
</span></span><span style="display:flex;"><span> "responseHeader":{
|
|
</span></span><span style="display:flex;"><span> "status":0,
|
|
</span></span><span style="display:flex;"><span> "QTime":196,
|
|
</span></span><span style="display:flex;"><span> "params":{
|
|
</span></span><span style="display:flex;"><span> "facet.range":"time",
|
|
</span></span><span style="display:flex;"><span> "q":"-id:/.{36}/",
|
|
</span></span><span style="display:flex;"><span> "facet.range.gap":"+1MONTH",
|
|
</span></span><span style="display:flex;"><span> "rows":"0",
|
|
</span></span><span style="display:flex;"><span> "facet":"true",
|
|
</span></span><span style="display:flex;"><span> "facet.range.start":"2023-01-01T00:00:00Z",
|
|
</span></span><span style="display:flex;"><span> "facet.range.end":"NOW"}},
|
|
</span></span><span style="display:flex;"><span> "response":{"numFound":800168,"start":0,"numFoundExact":true,"docs":[]
|
|
</span></span><span style="display:flex;"><span> },
|
|
</span></span><span style="display:flex;"><span> "facet_counts":{
|
|
</span></span><span style="display:flex;"><span> "facet_queries":{},
|
|
</span></span><span style="display:flex;"><span> "facet_fields":{},
|
|
</span></span><span style="display:flex;"><span> "facet_ranges":{
|
|
</span></span><span style="display:flex;"><span> "time":{
|
|
</span></span><span style="display:flex;"><span> "counts":[
|
|
</span></span><span style="display:flex;"><span> "2023-01-01T00:00:00Z",1,
|
|
</span></span><span style="display:flex;"><span> "2023-02-01T00:00:00Z",0,
|
|
</span></span><span style="display:flex;"><span> "2023-03-01T00:00:00Z",0,
|
|
</span></span><span style="display:flex;"><span> "2023-04-01T00:00:00Z",0,
|
|
</span></span><span style="display:flex;"><span> "2023-05-01T00:00:00Z",0,
|
|
</span></span><span style="display:flex;"><span> "2023-06-01T00:00:00Z",0,
|
|
</span></span><span style="display:flex;"><span> "2023-07-01T00:00:00Z",0,
|
|
</span></span><span style="display:flex;"><span> "2023-08-01T00:00:00Z",27621,
|
|
</span></span><span style="display:flex;"><span> "2023-09-01T00:00:00Z",59165,
|
|
</span></span><span style="display:flex;"><span> "2023-10-01T00:00:00Z",115338,
|
|
</span></span><span style="display:flex;"><span> "2023-11-01T00:00:00Z",96147,
|
|
</span></span><span style="display:flex;"><span> "2023-12-01T00:00:00Z",355464,
|
|
</span></span><span style="display:flex;"><span> "2024-01-01T00:00:00Z",125429],
|
|
</span></span><span style="display:flex;"><span> "gap":"+1MONTH",
|
|
</span></span><span style="display:flex;"><span> "start":"2023-01-01T00:00:00Z",
|
|
</span></span><span style="display:flex;"><span> "end":"2024-02-01T00:00:00Z"}},
|
|
</span></span><span style="display:flex;"><span> "facet_intervals":{},
|
|
</span></span><span style="display:flex;"><span> "facet_heatmaps":{}}}
|
|
</span></span></code></pre></div><ul>
|
|
<li>I see that we had 31,744 statistic events yesterday, and 799 have no <code>id</code>!</li>
|
|
<li>I asked about this on Slack and will file an issue on GitHub if someone else also finds such records
|
|
<ul>
|
|
<li>Several people said they have them, so it’s a bug of some sort in DSpace, not our configuration</li>
|
|
</ul>
|
|
</li>
|
|
</ul>
|
|
<h2 id="2024-01-13">2024-01-13</h2>
|
|
<ul>
|
|
<li>Yesterday alone we had 37,000 unique IPs making requests to nginx
|
|
<ul>
|
|
<li>I looked up the ASNs and found 6,000 IPs from this network in Amazon Singapore: 47.128.0.0/14</li>
|
|
</ul>
|
|
</li>
|
|
</ul>
|
|
<h2 id="2024-01-15">2024-01-15</h2>
|
|
<ul>
|
|
<li>Investigating the CSS selector warning that I’ve seen in PM2 logs:</li>
|
|
</ul>
|
|
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span>0|dspace-ui | 1 rules skipped due to selector errors:
|
|
</span></span><span style="display:flex;"><span>0|dspace-ui | .custom-file-input:lang(en)~.custom-file-label -> unmatched pseudo-class :lang
|
|
</span></span></code></pre></div><ul>
|
|
<li>It seems to be a bug in Angular, as this selector comes from Bootstrap 4.6.x and is not invalid
|
|
<ul>
|
|
<li>But that led me to a more interesting issue with <code>inlineCritical</code> optimization for styles in Angular SSR that might be responsible for causing high load in the frontend</li>
|
|
<li>See: <a href="https://github.com/angular/angular/issues/42098">https://github.com/angular/angular/issues/42098</a></li>
|
|
<li>See: <a href="https://github.com/angular/universal/issues/2106">https://github.com/angular/universal/issues/2106</a></li>
|
|
<li>See: <a href="https://github.com/GoogleChromeLabs/critters/issues/78">https://github.com/GoogleChromeLabs/critters/issues/78</a></li>
|
|
</ul>
|
|
</li>
|
|
<li>Since the production site was flapping a lot I decided to try disabling inlineCriticalCss</li>
|
|
<li>There have been on and off load issues with the Angular frontend today
|
|
<ul>
|
|
<li>I think I will just block all data center network blocks for now</li>
|
|
<li>In the last week I see almost 200,000 unique IPs:</li>
|
|
</ul>
|
|
</li>
|
|
</ul>
|
|
<div class="highlight"><pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"><code class="language-console" data-lang="console"><span style="display:flex;"><span># zcat -f /var/log/nginx/*access.log /var/log/nginx/*access.log.1 /var/log/nginx/*access.log.2.gz /var/log/nginx/*access.log.3.gz /var/log/nginx/*access.log.4.gz /var/log/nginx/*access.log.5.gz /var/log/nginx/*access.log.6.gz | awk <span style="color:#e6db74">'{print $1}'</span> | sort -u |
|
|
</span></span><span style="display:flex;"><span>tee /tmp/ips.txt | wc -l
|
|
</span></span><span style="display:flex;"><span>196493
|
|
</span></span></code></pre></div><ul>
|
|
<li>Looking these IPs up I see there are 18,000 coming from Comcast, 10,000 from AT&T, 4110 from Charter, 3500 from Cox and dozens of other residential IPs
|
|
<ul>
|
|
<li>I highly doubt these are home users browsing CGSpace… seems super fishy</li>
|
|
<li>Also, over 1,000 IPs from SpaceX Starlink in the last week. RIGHT</li>
|
|
<li>I will temporarily add a few new datacenter ISP network blocks to our rate limit:
|
|
<ul>
|
|
<li>16509 Amazon-02</li>
|
|
<li>701 UUNET</li>
|
|
<li>8075 Microsoft</li>
|
|
<li>15169 Google</li>
|
|
<li>14618 Amazon-AES</li>
|
|
<li>396982 Google Cloud</li>
|
|
</ul>
|
|
</li>
|
|
<li>The load on the server <em>immediately</em> dropped</li>
|
|
</ul>
|
|
</li>
|
|
</ul>
|
|
<!-- raw HTML omitted -->
|
|
|
|
|
|
|
|
|
|
|
|
</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">
|
|
|
|
|
|
<li><a href="/cgspace-notes/2024-01/">January, 2024</a></li>
|
|
|
|
<li><a href="/cgspace-notes/2023-12/">December, 2023</a></li>
|
|
|
|
<li><a href="/cgspace-notes/2023-11/">November, 2023</a></li>
|
|
|
|
<li><a href="/cgspace-notes/2023-10/">October, 2023</a></li>
|
|
|
|
<li><a href="/cgspace-notes/2023-09/">September, 2023</a></li>
|
|
|
|
</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 dir="auto">
|
|
|
|
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>
|