daily sim for docker.initial
This commit is contained in:
parent
3e49b5bf27
commit
9eb4f8e117
@ -1,112 +1,54 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# SQLite DDL for simulation
|
|
||||||
# =========================
|
|
||||||
|
|
||||||
|
|
||||||
# -- md_quotes
|
|
||||||
|
|
||||||
# -- md_1min_bars
|
|
||||||
|
|
||||||
|
|
||||||
usage() {
|
|
||||||
echo -n "Usage: $0"
|
|
||||||
echo -n " -d YYYMMDD Date>"
|
|
||||||
echo -n " [-O <output dir (./) >]"
|
|
||||||
echo -n " [-S <archive_source_host (cloud21)>]"
|
|
||||||
echo -n " [-D <orig_db_source> (cloud21)]"
|
|
||||||
echo
|
|
||||||
exit 1
|
|
||||||
}
|
|
||||||
|
|
||||||
# --------------------- Settings
|
# --------------------- Settings
|
||||||
SourceHost=cloud21
|
SOURCE_HOST=cloud21.cvtt.vpn
|
||||||
SourceRootDir=/opt/store/cvtt/md_archive/crypto
|
SOURCE_ROOT_DIR=/opt/store/cvtt/md_archive/crypto
|
||||||
DbSource=cloud21
|
DB_SOURCE=cloud28
|
||||||
|
OUTPUT_DIR=/tmp
|
||||||
|
DATE=20250516
|
||||||
# --------------------- Settings
|
# --------------------- Settings
|
||||||
|
|
||||||
while getopts ":d:O:S:D:" opt; do
|
if [ -z ${DATE} ] ; then
|
||||||
case ${opt} in
|
DATE=$(date -d 'yesterday' +'%Y%m%d')
|
||||||
d )
|
|
||||||
Date=$OPTARG
|
|
||||||
;;
|
|
||||||
O )
|
|
||||||
OutputDir=$OPTARG
|
|
||||||
;;
|
|
||||||
S )
|
|
||||||
SourceHost=$OPTARG
|
|
||||||
;;
|
|
||||||
D )
|
|
||||||
DbSource=$OPTARG
|
|
||||||
;;
|
|
||||||
\? )
|
|
||||||
echo "Invalid option: -$OPTARG" >&2
|
|
||||||
usage
|
|
||||||
;;
|
|
||||||
: )
|
|
||||||
echo "Option -$OPTARG requires an argument." >&2
|
|
||||||
usage
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
|
|
||||||
if [ -z ${Date} ] ; then
|
|
||||||
echo "date is not specified"
|
|
||||||
usage
|
|
||||||
fi
|
|
||||||
if [ -z ${OutputDir} ] ; then
|
|
||||||
OutputDir=.
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
SourceHost+=".cvtt.vpn"
|
if [ -z ${OUTPUT_DIR} ] ; then
|
||||||
mkdir -p ${OutputDir}
|
OUTPUT_DIR=.
|
||||||
|
fi
|
||||||
|
|
||||||
# --- Binance
|
echo "DATE=${DATE} SOURCE_HOST=${SOURCE_HOST}"
|
||||||
Instruments=( PAIR-ADA-USDT )
|
|
||||||
Instruments+=( PAIR-BCH-USDT )
|
|
||||||
Instruments+=( PAIR-BTC-USDT )
|
|
||||||
Instruments+=( PAIR-DOT-USDT )
|
|
||||||
Instruments+=( PAIR-ETH-USDT )
|
|
||||||
Instruments+=( PAIR-LTC-USDT )
|
|
||||||
Instruments+=( PAIR-SOL-USDT )
|
|
||||||
Instruments+=( PAIR-USDC-USDT )
|
|
||||||
Instruments+=( PAIR-XRP-USDT )
|
|
||||||
|
|
||||||
# --- Coinbase
|
mkdir -p ${OUTPUT_DIR}
|
||||||
Instruments+=( PAIR-ADA-USD )
|
|
||||||
Instruments+=( PAIR-BCH-USD )
|
|
||||||
Instruments+=( PAIR-BTC-USD )
|
|
||||||
Instruments+=( PAIR-DOT-USD )
|
|
||||||
Instruments+=( PAIR-ETH-USD )
|
|
||||||
Instruments+=( PAIR-LTC-USD )
|
|
||||||
Instruments+=( PAIR-SOL-USD )
|
|
||||||
Instruments+=( PAIR-XRP-USD )
|
|
||||||
|
|
||||||
echo "Date=${Date} Instruments=${Instruments[@]} OutputDir=${OutputDir}"
|
year=$(date -d ${DATE} +"%Y")
|
||||||
echo Getting data from ${DataHost} ...
|
month=$(date -d ${DATE} +"%m")
|
||||||
|
SourceDir="${SOURCE_ROOT_DIR}/${DB_SOURCE}/${year}/${month}"
|
||||||
year=$(date -d ${Date} +"%Y")
|
SourceFile="${SourceDir}/${DATE}.mktdata.db.gz"
|
||||||
month=$(date -d ${Date} +"%m")
|
|
||||||
SourceDir="${SourceRootDir}/${DbSource}/${year}/${month}"
|
|
||||||
SourceFile="${SourceDir}/${Date}.mktdata.db.gz"
|
|
||||||
|
|
||||||
Cmd="rsync -ahv"
|
Cmd="rsync -ahv"
|
||||||
Cmd+=" ${SourceHost}:${SourceFile}"
|
Cmd+=" -e 'ssh -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null'"
|
||||||
Cmd+=" $OutputDir/"
|
Cmd+=" ${SOURCE_HOST}:${SourceFile}"
|
||||||
|
Cmd+=" $OUTPUT_DIR/"
|
||||||
echo ${Cmd}
|
echo ${Cmd}
|
||||||
eval ${Cmd}
|
eval ${Cmd}
|
||||||
|
|
||||||
Cmd="(cd ${OutputDir} && gunzip *.db.gz)"
|
Cmd="(cd ${OUTPUT_DIR} && gunzip -f *.db.gz)"
|
||||||
echo ${Cmd}
|
echo ${Cmd}
|
||||||
eval ${Cmd}
|
eval ${Cmd}
|
||||||
|
|
||||||
SourceDbFile="${OutputDir}/${Date}.mktdata.db"
|
SourceDbFile="${OUTPUT_DIR}/${DATE}.mktdata.db"
|
||||||
ResultDbFile="${OutputDir}/${Date}.crypto_sim_md.db"
|
ResultDbFile="${OUTPUT_DIR}/${DATE}.crypto_sim_md.db"
|
||||||
|
|
||||||
|
echo "SourceDbFile=${SourceDbFile}"
|
||||||
echo "Creating Result Database File ${ResultDbFile}"
|
echo "Creating Result Database File ${ResultDbFile}"
|
||||||
|
cleanup() {
|
||||||
|
rm ${SourceDbFile}
|
||||||
|
}
|
||||||
|
trap cleanup EXIT
|
||||||
|
|
||||||
echo "Creating table md_trades ..."
|
echo "Creating table md_trades ..."
|
||||||
sqlite3 ${ResultDbFile} <<EOF
|
sqlite3 ${ResultDbFile} <<EOF
|
||||||
|
.echo ON
|
||||||
CREATE TABLE IF NOT EXISTS md_trades (
|
CREATE TABLE IF NOT EXISTS md_trades (
|
||||||
tstamp text,
|
tstamp text,
|
||||||
tstamp_ns integer,
|
tstamp_ns integer,
|
||||||
@ -119,12 +61,14 @@ CREATE TABLE IF NOT EXISTS md_trades (
|
|||||||
condition text,
|
condition text,
|
||||||
tape text
|
tape text
|
||||||
);
|
);
|
||||||
|
|
||||||
CREATE UNIQUE INDEX IF NOT EXISTS md_trades_uidx
|
CREATE UNIQUE INDEX IF NOT EXISTS md_trades_uidx
|
||||||
ON md_trades(tstamp_ns, exchange_id, instrument_id);
|
ON md_trades(tstamp_ns, exchange_id, instrument_id);
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
echo "Creating table md_quotes ..."
|
echo "Creating table md_quotes ..."
|
||||||
sqlite3 ${ResultDbFile} <<EOF
|
sqlite3 ${ResultDbFile} <<EOF
|
||||||
|
.echo ON
|
||||||
CREATE TABLE IF NOT EXISTS md_quotes (
|
CREATE TABLE IF NOT EXISTS md_quotes (
|
||||||
tstamp text,
|
tstamp text,
|
||||||
tstamp_ns integer,
|
tstamp_ns integer,
|
||||||
@ -143,6 +87,7 @@ EOF
|
|||||||
|
|
||||||
echo "Creating table md_1min_bars ..."
|
echo "Creating table md_1min_bars ..."
|
||||||
sqlite3 ${ResultDbFile} <<EOF
|
sqlite3 ${ResultDbFile} <<EOF
|
||||||
|
.echo ON
|
||||||
CREATE TABLE IF NOT EXISTS md_1min_bars (
|
CREATE TABLE IF NOT EXISTS md_1min_bars (
|
||||||
tstamp text,
|
tstamp text,
|
||||||
tstamp_ns integer,
|
tstamp_ns integer,
|
||||||
@ -162,6 +107,7 @@ EOF
|
|||||||
|
|
||||||
echo "Loading md_trades ..."
|
echo "Loading md_trades ..."
|
||||||
sqlite3 ${ResultDbFile} <<EOF
|
sqlite3 ${ResultDbFile} <<EOF
|
||||||
|
.echo ON
|
||||||
ATTACH '${SourceDbFile}' AS source_db;
|
ATTACH '${SourceDbFile}' AS source_db;
|
||||||
BEGIN;
|
BEGIN;
|
||||||
INSERT OR IGNORE INTO md_trades SELECT
|
INSERT OR IGNORE INTO md_trades SELECT
|
||||||
@ -199,6 +145,7 @@ EOF
|
|||||||
|
|
||||||
echo "Loading md_quotes ..."
|
echo "Loading md_quotes ..."
|
||||||
sqlite3 ${ResultDbFile} <<EOF
|
sqlite3 ${ResultDbFile} <<EOF
|
||||||
|
.echo ON
|
||||||
ATTACH '${SourceDbFile}' AS source_db;
|
ATTACH '${SourceDbFile}' AS source_db;
|
||||||
BEGIN;
|
BEGIN;
|
||||||
INSERT OR IGNORE INTO md_quotes SELECT
|
INSERT OR IGNORE INTO md_quotes SELECT
|
||||||
@ -237,6 +184,7 @@ EOF
|
|||||||
|
|
||||||
echo "Loading md_1min_bars ..."
|
echo "Loading md_1min_bars ..."
|
||||||
sqlite3 ${ResultDbFile} <<EOF
|
sqlite3 ${ResultDbFile} <<EOF
|
||||||
|
.echo ON
|
||||||
ATTACH '${SourceDbFile}' AS source_db;
|
ATTACH '${SourceDbFile}' AS source_db;
|
||||||
BEGIN;
|
BEGIN;
|
||||||
INSERT OR IGNORE INTO md_1min_bars SELECT
|
INSERT OR IGNORE INTO md_1min_bars SELECT
|
||||||
@ -273,16 +221,13 @@ COMMIT;
|
|||||||
DETACH source_db;
|
DETACH source_db;
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
Cmd="rm ${SourceDbFile}"
|
exit
|
||||||
echo ${Cmd}
|
|
||||||
eval ${Cmd}
|
|
||||||
|
|
||||||
|
|
||||||
Cmd="gzip ${ResultDbFile}"
|
Cmd="gzip ${ResultDbFile}"
|
||||||
echo ${Cmd}
|
echo ${Cmd}
|
||||||
eval ${Cmd}
|
eval ${Cmd}
|
||||||
|
|
||||||
Cmd="rsync -ahvv ${ResultDbFile}.gz cvtt@hs01.cvtt.vpn:/works/cvtt/md_archive/crypto/sim/"
|
Cmd="rsync -ahvv ${ResultDbFile}.gz "
|
||||||
echo ${Cmd}
|
echo ${Cmd}
|
||||||
eval ${Cmd}
|
eval ${Cmd}
|
||||||
|
|
||||||
@ -104,6 +104,7 @@ echo "Creating Result Database File ${ResultDbFile}"
|
|||||||
|
|
||||||
echo "Creating table md_trades ..."
|
echo "Creating table md_trades ..."
|
||||||
sqlite3 ${ResultDbFile} <<EOF
|
sqlite3 ${ResultDbFile} <<EOF
|
||||||
|
.echo ON
|
||||||
CREATE TABLE IF NOT EXISTS md_trades (
|
CREATE TABLE IF NOT EXISTS md_trades (
|
||||||
tstamp text,
|
tstamp text,
|
||||||
tstamp_ns integer,
|
tstamp_ns integer,
|
||||||
@ -122,6 +123,7 @@ EOF
|
|||||||
|
|
||||||
echo "Creating table md_quotes ..."
|
echo "Creating table md_quotes ..."
|
||||||
sqlite3 ${ResultDbFile} <<EOF
|
sqlite3 ${ResultDbFile} <<EOF
|
||||||
|
.echo ON
|
||||||
CREATE TABLE IF NOT EXISTS md_quotes (
|
CREATE TABLE IF NOT EXISTS md_quotes (
|
||||||
tstamp text,
|
tstamp text,
|
||||||
tstamp_ns integer,
|
tstamp_ns integer,
|
||||||
@ -166,6 +168,7 @@ for sym in ${Symbols[@]}; do
|
|||||||
|
|
||||||
echo "Loading md_trades and md_quotes from ${src_qat_db} ..."
|
echo "Loading md_trades and md_quotes from ${src_qat_db} ..."
|
||||||
sqlite3 ${ResultDbFile} <<EOF
|
sqlite3 ${ResultDbFile} <<EOF
|
||||||
|
.echo ON
|
||||||
ATTACH '${src_qat_db}' AS source_db;
|
ATTACH '${src_qat_db}' AS source_db;
|
||||||
BEGIN;
|
BEGIN;
|
||||||
INSERT OR IGNORE INTO md_trades SELECT
|
INSERT OR IGNORE INTO md_trades SELECT
|
||||||
@ -200,6 +203,7 @@ EOF
|
|||||||
|
|
||||||
echo "Loading md_1min_bars from ${src_hbar_db} ..."
|
echo "Loading md_1min_bars from ${src_hbar_db} ..."
|
||||||
sqlite3 ${ResultDbFile} <<EOF
|
sqlite3 ${ResultDbFile} <<EOF
|
||||||
|
.echo ON
|
||||||
ATTACH '${src_hbar_db}' AS source_db;
|
ATTACH '${src_hbar_db}' AS source_db;
|
||||||
BEGIN;
|
BEGIN;
|
||||||
INSERT OR IGNORE INTO md_1min_bars SELECT
|
INSERT OR IGNORE INTO md_1min_bars SELECT
|
||||||
Loading…
x
Reference in New Issue
Block a user