progress
This commit is contained in:
parent
90fa146190
commit
df761027ec
@ -1 +1 @@
|
|||||||
1.3.3
|
1.3.4
|
||||||
|
|||||||
126
research/load_crypto_md.sh
Executable file
126
research/load_crypto_md.sh
Executable file
@ -0,0 +1,126 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
usage() {
|
||||||
|
echo "Usage: $0 [-h <host (homestore*/cloud21)>] [-d <YYYYMMDD> (yesterday*)] [-s <source> (cvttdata/cloud21*)>]"
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
is_valid() {
|
||||||
|
local inst=$1
|
||||||
|
local valid_instances=$2
|
||||||
|
|
||||||
|
for valid_inst in "${valid_instances[@]}";
|
||||||
|
do
|
||||||
|
if [[ "$inst" == "$valid_inst" ]]; then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
|
||||||
|
date=""
|
||||||
|
host=homestore
|
||||||
|
source=cloud21
|
||||||
|
|
||||||
|
while getopts ":h:d:s:" opt; do
|
||||||
|
case ${opt} in
|
||||||
|
d )
|
||||||
|
date=$OPTARG
|
||||||
|
;;
|
||||||
|
h )
|
||||||
|
host=$OPTARG
|
||||||
|
;;
|
||||||
|
s )
|
||||||
|
source=$OPTARG
|
||||||
|
;;
|
||||||
|
\? )
|
||||||
|
echo "Invalid option: -$OPTARG" >&2
|
||||||
|
usage
|
||||||
|
;;
|
||||||
|
: )
|
||||||
|
echo "Option -$OPTARG requires an argument." >&2
|
||||||
|
usage
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
if [ "${date}" == "" ] ; then
|
||||||
|
date="yesterday"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "$date $host $source"
|
||||||
|
|
||||||
|
valid_hosts=('homestore' 'cloud21')
|
||||||
|
if ! is_valid "${host}" "${valid_hosts[@]}" ; then
|
||||||
|
echo h
|
||||||
|
usage
|
||||||
|
fi
|
||||||
|
|
||||||
|
valid_sources=('cloud21' 'cvttdata')
|
||||||
|
if ! is_valid ${source} ${valid_sources[@]} ; then
|
||||||
|
echo s
|
||||||
|
usage
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
if [ "${host}" == "cloud21" ] ; then
|
||||||
|
SourceHost=cloud21.cvtt.vpn
|
||||||
|
SourceUser=cvtt
|
||||||
|
SourceRootDir="/opt/store/cvtt/md_archive/crypto/${source}"
|
||||||
|
elif [ "${host}" == "homestore" ]; then
|
||||||
|
SourceHost=homestore.cvtt.vpn
|
||||||
|
SourceUser=oleg
|
||||||
|
SourceRootDir=/works/cvtt/md_archive/crypto/${source}
|
||||||
|
else
|
||||||
|
usage
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "${SourceHost} ${SourceUser} ${SourceRootDir}"
|
||||||
|
|
||||||
|
SourceFile=$(date -d ${date} "+%Y%m%d.mktdata.db")
|
||||||
|
SourceFileZip="${SourceFile}.gz"
|
||||||
|
SourceFilePath=$(date -d ${date} "+${SourceRootDir}/%Y/%m/${SourceFileZip}")
|
||||||
|
|
||||||
|
TargetDir="/opt/jupyter_gpu/data/crypto_md"
|
||||||
|
TargetFile=$(date -d ${date} "+%Y%m%d.mktdata.ohlcv.db")
|
||||||
|
TargetFilePath="${TargetDir}/${TargetFile}"
|
||||||
|
|
||||||
|
echo ${SourceFile}
|
||||||
|
tmp_dir=$(mktemp -d)
|
||||||
|
|
||||||
|
function cleanup {
|
||||||
|
cd ${HOME}
|
||||||
|
rm -rf ${tmp_dir}
|
||||||
|
}
|
||||||
|
trap cleanup EXIT
|
||||||
|
|
||||||
|
function download_file {
|
||||||
|
|
||||||
|
Cmd="rsync"
|
||||||
|
Cmd="${Cmd} -ahv"
|
||||||
|
if tty -s; then
|
||||||
|
Cmd="${Cmd} --progress=info2"
|
||||||
|
fi
|
||||||
|
Cmd="${Cmd} ${SourceUser}@${SourceHost}:${SourceFilePath} ${tmp_dir}/"
|
||||||
|
echo ${Cmd}
|
||||||
|
eval ${Cmd}
|
||||||
|
ls -lh ${tmp_dir}
|
||||||
|
Cmd="gunzip ${tmp_dir}/${SourceFileZip}"
|
||||||
|
echo ${Cmd} && eval ${Cmd}
|
||||||
|
ls -lh ${tmp_dir}
|
||||||
|
|
||||||
|
rm -f ${TargetFilePath}
|
||||||
|
touch ${TargetFilePath}
|
||||||
|
|
||||||
|
for table in bnbfut_ohlcv_1min bnbspot_ohlcv_1min coinbase_ohlcv_1min
|
||||||
|
do
|
||||||
|
Cmd="sqlite3 ${tmp_dir}/${SourceFile} \".dump ${table}\" | sqlite3 ${TargetFilePath}"
|
||||||
|
echo ${Cmd}
|
||||||
|
eval ${Cmd}
|
||||||
|
done
|
||||||
|
chmod 600 ${TargetFilePath}
|
||||||
|
ls -lh ${TargetFilePath}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
download_file
|
||||||
Loading…
x
Reference in New Issue
Block a user