release v1.13: improved use of sudo in docker version, pinned version of openrefine-client, improved README
This commit is contained in:
parent
f6c8ee9d98
commit
b259cf571c
46
README.md
46
README.md
|
@ -19,7 +19,11 @@ If you prefer a containerized approach, see a [variation of this script for Dock
|
||||||
|
|
||||||
### Install
|
### Install
|
||||||
|
|
||||||
Download the script and grant file permissions to execute: `wget https://github.com/felixlohmeier/openrefine-batch/raw/master/openrefine-batch.sh && chmod +x openrefine-batch.sh`
|
Download the script and grant file permissions to execute:
|
||||||
|
```
|
||||||
|
wget https://github.com/felixlohmeier/openrefine-batch/raw/master/openrefine-batch.sh
|
||||||
|
chmod +x openrefine-batch.sh
|
||||||
|
```
|
||||||
|
|
||||||
That's all. The script will automatically download copies of OpenRefine and the python client on first run and will tell you if something (python, java) is missing.
|
That's all. The script will automatically download copies of OpenRefine and the python client on first run and will tell you if something (python, java) is missing.
|
||||||
|
|
||||||
|
@ -288,8 +292,14 @@ A variation of the shell script orchestrates a [docker container for OpenRefine]
|
||||||
|
|
||||||
**Install**
|
**Install**
|
||||||
|
|
||||||
1. Install [Docker](https://docs.docker.com/engine/installation/#on-linux) and **a)** [configure Docker to start on boot](https://docs.docker.com/engine/installation/linux/linux-postinstall/#configure-docker-to-start-on-boot) or **b)** start Docker on demand each time you use the script: `sudo systemctl start docker`
|
1. Install [Docker](https://docs.docker.com/engine/installation/#on-linux)
|
||||||
2. Download the script and grant file permissions to execute: `wget https://github.com/felixlohmeier/openrefine-batch/raw/master/openrefine-batch-docker.sh && chmod +x openrefine-batch-docker.sh`
|
* **a)** [configure Docker to start on boot](https://docs.docker.com/engine/installation/linux/linux-postinstall/#configure-docker-to-start-on-boot)
|
||||||
|
* or **b)** start Docker on demand each time you use the script: `sudo systemctl start docker`
|
||||||
|
2. Download the script and grant file permissions to execute:
|
||||||
|
```
|
||||||
|
wget https://github.com/felixlohmeier/openrefine-batch/raw/master/openrefine-batch-docker.sh
|
||||||
|
chmod +x openrefine-batch-docker.sh
|
||||||
|
```
|
||||||
|
|
||||||
**Usage**
|
**Usage**
|
||||||
|
|
||||||
|
@ -298,10 +308,36 @@ mkdir input
|
||||||
cp INPUTFILES input/
|
cp INPUTFILES input/
|
||||||
mkdir config
|
mkdir config
|
||||||
cp CONFIGFILES config/
|
cp CONFIGFILES config/
|
||||||
sudo ./openrefine-batch-docker.sh -a input/ -b config/ -c OUTPUT/
|
./openrefine-batch-docker.sh -a input/ -b config/ -c OUTPUT/
|
||||||
```
|
```
|
||||||
|
|
||||||
Why `sudo`? Non-root users can only access the Unix socket of the Docker daemon by using `sudo`. If you created a Docker group in [Post-installation steps for Linux](https://docs.docker.com/engine/installation/linux/linux-postinstall/) then you may call the script without `sudo`.
|
The script may ask you for sudo privileges. Why `sudo`? Non-root users can only access the Unix socket of the Docker daemon by using `sudo`. If you created a Docker group in [Post-installation steps for Linux](https://docs.docker.com/engine/installation/linux/linux-postinstall/) then you may call the script without `sudo`.
|
||||||
|
|
||||||
|
**Example**
|
||||||
|
|
||||||
|
[Example Powerhouse Museum](examples/powerhouse-museum)
|
||||||
|
|
||||||
|
download example data
|
||||||
|
|
||||||
|
```
|
||||||
|
wget https://github.com/opencultureconsulting/openrefine-batch/archive/master.zip
|
||||||
|
unzip master.zip openrefine-batch-master/examples/*
|
||||||
|
mv openrefine-batch-master/examples .
|
||||||
|
rm -f master.zip
|
||||||
|
```
|
||||||
|
|
||||||
|
execute openrefine-batch-docker.sh
|
||||||
|
|
||||||
|
```
|
||||||
|
./openrefine-batch-docker.sh \
|
||||||
|
-a examples/powerhouse-museum/input/ \
|
||||||
|
-b examples/powerhouse-museum/config/ \
|
||||||
|
-c examples/powerhouse-museum/output/ \
|
||||||
|
-f tsv \
|
||||||
|
-i processQuotes=false \
|
||||||
|
-i guessCellValueTypes=true \
|
||||||
|
-RX
|
||||||
|
```
|
||||||
|
|
||||||
### Todo
|
### Todo
|
||||||
|
|
||||||
|
|
|
@ -1,23 +1,32 @@
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
# openrefine-batch-docker.sh, Felix Lohmeier, v1.12, 2019-07-29
|
# openrefine-batch-docker.sh, Felix Lohmeier, v1.13, 2019-08-06
|
||||||
# https://github.com/felixlohmeier/openrefine-batch
|
# https://github.com/felixlohmeier/openrefine-batch
|
||||||
|
|
||||||
# check system requirements
|
# check system requirements
|
||||||
DOCKER="$(which docker 2> /dev/null)"
|
DOCKER="$(command -v docker 2> /dev/null)"
|
||||||
if [ -z "$DOCKER" ] ; then
|
if [ -z "$DOCKER" ] ; then
|
||||||
echo 1>&2 "This action requires you to have 'docker' installed and present in your PATH. You can download it for free at http://www.docker.com/"
|
echo 1>&2 "This action requires you to have 'docker' installed and present in your PATH. You can download it for free at http://www.docker.com/"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
DOCKERINFO="$(docker info 2>/dev/null | grep 'Server Version')"
|
DOCKERINFO="$(docker info 2>/dev/null | grep 'Server Version')"
|
||||||
if [ -z "$DOCKERINFO" ] ; then
|
if [ -z "$DOCKERINFO" ]
|
||||||
echo 1>&2 "This action requires you to start the docker daemon. Try 'sudo systemctl start docker' or 'sudo start docker'. If the docker daemon is already running then maybe some security privileges are missing to run docker commands. Try to run the script with 'sudo ./openrefine-batch-docker.sh ...'"
|
then
|
||||||
exit 1
|
echo "command 'docker info' failed, trying again with sudo..."
|
||||||
|
DOCKERINFO="$(sudo docker info 2>/dev/null | grep 'Server Version')"
|
||||||
|
echo "OK"
|
||||||
|
docker=(sudo docker)
|
||||||
|
if [ -z "$DOCKERINFO" ] ; then
|
||||||
|
echo 1>&2 "This action requires you to start the docker daemon. Try 'sudo systemctl start docker' or 'sudo start docker'. If the docker daemon is already running then maybe some security privileges are missing to run docker commands.'"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
docker=(docker)
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# help screen
|
# help screen
|
||||||
function usage () {
|
function usage () {
|
||||||
cat <<EOF
|
cat <<EOF
|
||||||
Usage: sudo ./openrefine-batch-docker.sh [-a INPUTDIR] [-b TRANSFORMDIR] [-c OUTPUTDIR] ...
|
Usage: ./openrefine-batch-docker.sh [-a INPUTDIR] [-b TRANSFORMDIR] [-c OUTPUTDIR] ...
|
||||||
|
|
||||||
== basic arguments ==
|
== basic arguments ==
|
||||||
-a INPUTDIR path to directory with source files (leave empty to transform only ; multiple files may be imported into a single project by providing a zip or tar.gz archive, cf. https://github.com/OpenRefine/OpenRefine/wiki/Importers )
|
-a INPUTDIR path to directory with source files (leave empty to transform only ; multiple files may be imported into a single project by providing a zip or tar.gz archive, cf. https://github.com/OpenRefine/OpenRefine/wiki/Importers )
|
||||||
|
@ -81,7 +90,7 @@ rm -f master.zip
|
||||||
|
|
||||||
example 1 (input, transform, export to tsv)
|
example 1 (input, transform, export to tsv)
|
||||||
|
|
||||||
sudo ./openrefine-batch-docker.sh \
|
./openrefine-batch-docker.sh \
|
||||||
-a examples/powerhouse-museum/input/ \
|
-a examples/powerhouse-museum/input/ \
|
||||||
-b examples/powerhouse-museum/config/ \
|
-b examples/powerhouse-museum/config/ \
|
||||||
-c examples/powerhouse-museum/output/ \
|
-c examples/powerhouse-museum/output/ \
|
||||||
|
@ -92,7 +101,7 @@ sudo ./openrefine-batch-docker.sh \
|
||||||
|
|
||||||
example 2 (input, transform, templating export)
|
example 2 (input, transform, templating export)
|
||||||
|
|
||||||
sudo ./openrefine-batch-docker.sh -a examples/powerhouse-museum/input/ -b examples/powerhouse-museum/config/ -c examples/powerhouse-museum/output/ -f tsv -i processQuotes=false -i guessCellValueTypes=true -RX -t template='{ "Record ID" : {{jsonize(cells["Record ID"].value)}}, "Object Title" : {{jsonize(cells["Object Title"].value)}}, "Registration Number" : {{jsonize(cells["Registration Number"].value)}}, "Description." : {{jsonize(cells["Description."].value)}}, "Marks" : {{jsonize(cells["Marks"].value)}}, "Production Date" : {{jsonize(cells["Production Date"].value)}}, "Provenance (Production)" : {{jsonize(cells["Provenance (Production)"].value)}}, "Provenance (History)" : {{jsonize(cells["Provenance (History)"].value)}}, "Categories" : {{jsonize(cells["Categories"].value)}}, "Persistent Link" : {{jsonize(cells["Persistent Link"].value)}}, "Height" : {{jsonize(cells["Height"].value)}}, "Width" : {{jsonize(cells["Width"].value)}}, "Depth" : {{jsonize(cells["Depth"].value)}}, "Diameter" : {{jsonize(cells["Diameter"].value)}}, "Weight" : {{jsonize(cells["Weight"].value)}}, "License info" : {{jsonize(cells["License info"].value)}} }' -t rowSeparator=',' -t prefix='{ "rows" : [ ' -t suffix='] }' -t splitToFiles=true
|
./openrefine-batch-docker.sh -a examples/powerhouse-museum/input/ -b examples/powerhouse-museum/config/ -c examples/powerhouse-museum/output/ -f tsv -i processQuotes=false -i guessCellValueTypes=true -RX -t template='{ "Record ID" : {{jsonize(cells["Record ID"].value)}}, "Object Title" : {{jsonize(cells["Object Title"].value)}}, "Registration Number" : {{jsonize(cells["Registration Number"].value)}}, "Description." : {{jsonize(cells["Description."].value)}}, "Marks" : {{jsonize(cells["Marks"].value)}}, "Production Date" : {{jsonize(cells["Production Date"].value)}}, "Provenance (Production)" : {{jsonize(cells["Provenance (Production)"].value)}}, "Provenance (History)" : {{jsonize(cells["Provenance (History)"].value)}}, "Categories" : {{jsonize(cells["Categories"].value)}}, "Persistent Link" : {{jsonize(cells["Persistent Link"].value)}}, "Height" : {{jsonize(cells["Height"].value)}}, "Width" : {{jsonize(cells["Width"].value)}}, "Depth" : {{jsonize(cells["Depth"].value)}}, "Diameter" : {{jsonize(cells["Diameter"].value)}}, "Weight" : {{jsonize(cells["Weight"].value)}}, "License info" : {{jsonize(cells["License info"].value)}} }' -t rowSeparator=',' -t prefix='{ "rows" : [ ' -t suffix='] }' -t splitToFiles=true
|
||||||
EOF
|
EOF
|
||||||
exit 1
|
exit 1
|
||||||
}
|
}
|
||||||
|
@ -200,8 +209,8 @@ memoryload=()
|
||||||
cleanup()
|
cleanup()
|
||||||
{
|
{
|
||||||
echo "cleanup..."
|
echo "cleanup..."
|
||||||
docker stop -t=5000 ${uuid}
|
${docker[*]} stop -t=5000 ${uuid}
|
||||||
docker rm ${uuid}
|
${docker[*]} rm ${uuid}
|
||||||
rm -r -f "${outputdir:?}"/workspace*.json
|
rm -r -f "${outputdir:?}"/workspace*.json
|
||||||
# delete duplicates from copied projects
|
# delete duplicates from copied projects
|
||||||
if [ -n "$crossprojects" ]; then
|
if [ -n "$crossprojects" ]; then
|
||||||
|
@ -218,11 +227,11 @@ echo "=== $checkpoints. ${checkpointname[$((checkpoints + 1))]} ==="
|
||||||
echo ""
|
echo ""
|
||||||
echo "starting time: $(date --date=@${checkpointdate[$((checkpoints + 1))]})"
|
echo "starting time: $(date --date=@${checkpointdate[$((checkpoints + 1))]})"
|
||||||
echo ""
|
echo ""
|
||||||
sudo docker run -d --name=${uuid} -v ${outputdir}:/data:z felixlohmeier/openrefine:${version} -i 0.0.0.0 -m ${ram} -d /data
|
${docker[*]} run -d --name=${uuid} -v ${outputdir}:/data:z felixlohmeier/openrefine:${version} -i 0.0.0.0 -m ${ram} -d /data
|
||||||
# wait until server is available
|
# wait until server is available
|
||||||
until sudo docker run --rm --link ${uuid} --entrypoint /usr/bin/curl felixlohmeier/openrefine-client --silent -N http://${uuid}:3333 | cat | grep -q -o "OpenRefine" ; do sleep 1; done
|
until ${docker[*]} run --rm --link ${uuid} --entrypoint /usr/bin/curl felixlohmeier/openrefine-client:v0.3.4 --silent -N http://${uuid}:3333 | cat | grep -q -o "OpenRefine" ; do sleep 1; done
|
||||||
# show server logs
|
# show server logs
|
||||||
docker attach ${uuid} &
|
${docker[*]} attach ${uuid} &
|
||||||
echo ""
|
echo ""
|
||||||
|
|
||||||
# import all files
|
# import all files
|
||||||
|
@ -237,7 +246,7 @@ if [ -n "$inputfiles" ]; then
|
||||||
for inputfile in "${inputfiles[@]}" ; do
|
for inputfile in "${inputfiles[@]}" ; do
|
||||||
echo "import ${inputfile}..."
|
echo "import ${inputfile}..."
|
||||||
# run client with input command
|
# run client with input command
|
||||||
sudo docker run --rm --link ${uuid} -v ${inputdir}:/data:z felixlohmeier/openrefine-client -H ${uuid} -c $inputfile $inputformat ${inputoptions[@]}
|
${docker[*]} run --rm --link ${uuid} -v ${inputdir}:/data:z felixlohmeier/openrefine-client:v0.3.4 -H ${uuid} -c $inputfile $inputformat ${inputoptions[@]}
|
||||||
# show allocated system resources
|
# show allocated system resources
|
||||||
ps -o start,etime,%mem,%cpu,rss -C java --sort=start
|
ps -o start,etime,%mem,%cpu,rss -C java --sort=start
|
||||||
memoryload+=($(ps --no-headers -o rss -C java))
|
memoryload+=($(ps --no-headers -o rss -C java))
|
||||||
|
@ -245,11 +254,11 @@ if [ -n "$inputfiles" ]; then
|
||||||
# restart server to clear memory
|
# restart server to clear memory
|
||||||
if [ "$restartfile" = "true" ]; then
|
if [ "$restartfile" = "true" ]; then
|
||||||
echo "save project and restart OpenRefine server..."
|
echo "save project and restart OpenRefine server..."
|
||||||
docker stop -t=5000 ${uuid}
|
${docker[*]} stop -t=5000 ${uuid}
|
||||||
docker rm ${uuid}
|
${docker[*]} rm ${uuid}
|
||||||
sudo docker run -d --name=${uuid} -v ${outputdir}:/data:z felixlohmeier/openrefine:${version} -i 0.0.0.0 -m ${ram} -d /data
|
${docker[*]} run -d --name=${uuid} -v ${outputdir}:/data:z felixlohmeier/openrefine:${version} -i 0.0.0.0 -m ${ram} -d /data
|
||||||
until sudo docker run --rm --link ${uuid} --entrypoint /usr/bin/curl felixlohmeier/openrefine-client --silent -N http://${uuid}:3333 | cat | grep -q -o "OpenRefine" ; do sleep 1; done
|
until ${docker[*]} run --rm --link ${uuid} --entrypoint /usr/bin/curl felixlohmeier/openrefine-client:v0.3.4 --silent -N http://${uuid}:3333 | cat | grep -q -o "OpenRefine" ; do sleep 1; done
|
||||||
docker attach ${uuid} &
|
${docker[*]} attach ${uuid} &
|
||||||
echo ""
|
echo ""
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
@ -267,7 +276,7 @@ if [ -n "$jsonfiles" ] || [ "$export" = "true" ]; then
|
||||||
|
|
||||||
# get project ids
|
# get project ids
|
||||||
echo "get project ids..."
|
echo "get project ids..."
|
||||||
sudo docker run --rm --link ${uuid} felixlohmeier/openrefine-client -H ${uuid} -l > "${outputdir}/projects.tmp"
|
${docker[*]} run --rm --link ${uuid} felixlohmeier/openrefine-client:v0.3.4 -H ${uuid} -l > "${outputdir}/projects.tmp"
|
||||||
projectids=($(cut -c 2-14 "${outputdir}/projects.tmp"))
|
projectids=($(cut -c 2-14 "${outputdir}/projects.tmp"))
|
||||||
projectnames=($(cut -c 17- "${outputdir}/projects.tmp"))
|
projectnames=($(cut -c 17- "${outputdir}/projects.tmp"))
|
||||||
cat "${outputdir}/projects.tmp" && rm "${outputdir:?}/projects.tmp"
|
cat "${outputdir}/projects.tmp" && rm "${outputdir:?}/projects.tmp"
|
||||||
|
@ -280,11 +289,11 @@ if [ -n "$jsonfiles" ] || [ "$export" = "true" ]; then
|
||||||
rsync -a --exclude='*.project/history' "${crossdir}"/*.project "${outputdir}"
|
rsync -a --exclude='*.project/history' "${crossdir}"/*.project "${outputdir}"
|
||||||
# restart server to advertise copied projects
|
# restart server to advertise copied projects
|
||||||
echo "restart OpenRefine server to advertise copied projects..."
|
echo "restart OpenRefine server to advertise copied projects..."
|
||||||
docker stop -t=5000 ${uuid}
|
${docker[*]} stop -t=5000 ${uuid}
|
||||||
docker rm ${uuid}
|
${docker[*]} rm ${uuid}
|
||||||
sudo docker run -d --name=${uuid} -v ${outputdir}:/data:z felixlohmeier/openrefine:${version} -i 0.0.0.0 -m ${ram} -d /data
|
${docker[*]} run -d --name=${uuid} -v ${outputdir}:/data:z felixlohmeier/openrefine:${version} -i 0.0.0.0 -m ${ram} -d /data
|
||||||
until sudo docker run --rm --link ${uuid} --entrypoint /usr/bin/curl felixlohmeier/openrefine-client --silent -N http://${uuid}:3333 | cat | grep -q -o "OpenRefine" ; do sleep 1; done
|
until ${docker[*]} run --rm --link ${uuid} --entrypoint /usr/bin/curl felixlohmeier/openrefine-client:v0.3.4 --silent -N http://${uuid}:3333 | cat | grep -q -o "OpenRefine" ; do sleep 1; done
|
||||||
docker attach ${uuid} &
|
${docker[*]} attach ${uuid} &
|
||||||
echo ""
|
echo ""
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
@ -303,7 +312,7 @@ if [ -n "$jsonfiles" ] || [ "$export" = "true" ]; then
|
||||||
for jsonfile in "${jsonfiles[@]}" ; do
|
for jsonfile in "${jsonfiles[@]}" ; do
|
||||||
echo "transform ${jsonfile}..."
|
echo "transform ${jsonfile}..."
|
||||||
# run client with apply command
|
# run client with apply command
|
||||||
sudo docker run --rm --link ${uuid} -v ${configdir}:/data:z felixlohmeier/openrefine-client -H ${uuid} -f ${jsonfile} ${projectids[i]}
|
${docker[*]} run --rm --link ${uuid} -v ${configdir}:/data:z felixlohmeier/openrefine-client:v0.3.4 -H ${uuid} -f ${jsonfile} ${projectids[i]}
|
||||||
# allocated system resources
|
# allocated system resources
|
||||||
ps -o start,etime,%mem,%cpu,rss -C java --sort=start
|
ps -o start,etime,%mem,%cpu,rss -C java --sort=start
|
||||||
memoryload+=($(ps --no-headers -o rss -C java))
|
memoryload+=($(ps --no-headers -o rss -C java))
|
||||||
|
@ -311,11 +320,11 @@ if [ -n "$jsonfiles" ] || [ "$export" = "true" ]; then
|
||||||
# restart server to clear memory
|
# restart server to clear memory
|
||||||
if [ "$restarttransform" = "true" ]; then
|
if [ "$restarttransform" = "true" ]; then
|
||||||
echo "save project and restart OpenRefine server..."
|
echo "save project and restart OpenRefine server..."
|
||||||
docker stop -t=5000 ${uuid}
|
${docker[*]} stop -t=5000 ${uuid}
|
||||||
docker rm ${uuid}
|
${docker[*]} rm ${uuid}
|
||||||
sudo docker run -d --name=${uuid} -v ${outputdir}:/data:z felixlohmeier/openrefine:${version} -i 0.0.0.0 -m ${ram} -d /data
|
${docker[*]} run -d --name=${uuid} -v ${outputdir}:/data:z felixlohmeier/openrefine:${version} -i 0.0.0.0 -m ${ram} -d /data
|
||||||
until sudo docker run --rm --link ${uuid} --entrypoint /usr/bin/curl felixlohmeier/openrefine-client --silent -N http://${uuid}:3333 | cat | grep -q -o "OpenRefine" ; do sleep 1; done
|
until ${docker[*]} run --rm --link ${uuid} --entrypoint /usr/bin/curl felixlohmeier/openrefine-client:v0.3.4 --silent -N http://${uuid}:3333 | cat | grep -q -o "OpenRefine" ; do sleep 1; done
|
||||||
docker attach ${uuid} &
|
${docker[*]} attach ${uuid} &
|
||||||
fi
|
fi
|
||||||
echo ""
|
echo ""
|
||||||
done
|
done
|
||||||
|
@ -334,7 +343,7 @@ if [ -n "$jsonfiles" ] || [ "$export" = "true" ]; then
|
||||||
filename=${projectnames[i]%.*}
|
filename=${projectnames[i]%.*}
|
||||||
echo "export to file ${filename}.${exportformat}..."
|
echo "export to file ${filename}.${exportformat}..."
|
||||||
# run client with export command
|
# run client with export command
|
||||||
sudo docker run --rm --link ${uuid} -v ${outputdir}:/data:z felixlohmeier/openrefine-client -H ${uuid} -E --output="${filename}.${exportformat}" "${templating[@]}" ${projectids[i]}
|
${docker[*]} run --rm --link ${uuid} -v ${outputdir}:/data:z felixlohmeier/openrefine-client:v0.3.4 -H ${uuid} -E --output="${filename}.${exportformat}" "${templating[@]}" ${projectids[i]}
|
||||||
# show allocated system resources
|
# show allocated system resources
|
||||||
ps -o start,etime,%mem,%cpu,rss -C java --sort=start
|
ps -o start,etime,%mem,%cpu,rss -C java --sort=start
|
||||||
memoryload+=($(ps --no-headers -o rss -C java))
|
memoryload+=($(ps --no-headers -o rss -C java))
|
||||||
|
@ -344,11 +353,11 @@ if [ -n "$jsonfiles" ] || [ "$export" = "true" ]; then
|
||||||
# restart server to clear memory
|
# restart server to clear memory
|
||||||
if [ "$restartfile" = "true" ]; then
|
if [ "$restartfile" = "true" ]; then
|
||||||
echo "restart OpenRefine server..."
|
echo "restart OpenRefine server..."
|
||||||
docker stop -t=5000 ${uuid}
|
${docker[*]} stop -t=5000 ${uuid}
|
||||||
docker rm ${uuid}
|
${docker[*]} rm ${uuid}
|
||||||
sudo docker run -d --name=${uuid} -v ${outputdir}:/data:z felixlohmeier/openrefine:${version} -i 0.0.0.0 -m ${ram} -d /data
|
${docker[*]} run -d --name=${uuid} -v ${outputdir}:/data:z felixlohmeier/openrefine:${version} -i 0.0.0.0 -m ${ram} -d /data
|
||||||
until sudo docker run --rm --link ${uuid} --entrypoint /usr/bin/curl felixlohmeier/openrefine-client --silent -N http://${uuid}:3333 | cat | grep -q -o "OpenRefine" ; do sleep 1; done
|
until ${docker[*]} run --rm --link ${uuid} --entrypoint /usr/bin/curl felixlohmeier/openrefine-client:v0.3.4 --silent -N http://${uuid}:3333 | cat | grep -q -o "OpenRefine" ; do sleep 1; done
|
||||||
docker attach ${uuid} &
|
${docker[*]} attach ${uuid} &
|
||||||
fi
|
fi
|
||||||
echo ""
|
echo ""
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
# openrefine-batch.sh, Felix Lohmeier, v1.12, 2019-07-29
|
# openrefine-batch.sh, Felix Lohmeier, v1.13, 2019-08-06
|
||||||
# https://github.com/felixlohmeier/openrefine-batch
|
# https://github.com/felixlohmeier/openrefine-batch
|
||||||
|
|
||||||
# declare download URLs for OpenRefine and OpenRefine client
|
# declare download URLs for OpenRefine and OpenRefine client
|
||||||
|
|
Loading…
Reference in New Issue