Compare commits
No commits in common. "master" and "v0.2.7" have entirely different histories.
22
config_service/Dockerfile
Normal file
22
config_service/Dockerfile
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
FROM python:3.12-slim
|
||||||
|
|
||||||
|
WORKDIR /
|
||||||
|
COPY docker_dev/config_service/requirements.txt /
|
||||||
|
RUN pip install --upgrade pip --root-user-action=ignore
|
||||||
|
RUN pip install -r /requirements.txt --root-user-action=ignore
|
||||||
|
|
||||||
|
COPY cvttpy /cvttpy
|
||||||
|
|
||||||
|
# Shared Volumes
|
||||||
|
RUN mkdir -p /app/data
|
||||||
|
RUN mkdir /logs
|
||||||
|
|
||||||
|
ENV PYTHONPATH=/
|
||||||
|
CMD [ \
|
||||||
|
"python3.12", \
|
||||||
|
"cvttpy/apps/utils/config_server.py", \
|
||||||
|
"--port=6789", \
|
||||||
|
"--root=/app/data", \
|
||||||
|
"--log_file=/logs/%T.config_service.log" \
|
||||||
|
]
|
||||||
|
|
||||||
42
config_service/HOWTO.md
Normal file
42
config_service/HOWTO.md
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
# Build/Dev Host
|
||||||
|
## Build
|
||||||
|
```bash
|
||||||
|
TgtHostname=cloud16.cvtt.vpn
|
||||||
|
Version=$(cat cvttpy/VERSION)
|
||||||
|
|
||||||
|
cd /home/oleg/develop/cvtt2
|
||||||
|
docker build -t config_service -t config_service:${Version} -f cvttpy/utils/docker/config_service/Dockerfile .
|
||||||
|
|
||||||
|
## Deploy
|
||||||
|
|
||||||
|
docker save -o /tmp/cvtt_config_service.img.tar config_service
|
||||||
|
scp /tmp/cvtt_config_service.img.tar cvtt@${TgtHostname}:/tmp/
|
||||||
|
|
||||||
|
ssh cvtt@${TgtHostname}
|
||||||
|
```
|
||||||
|
|
||||||
|
## On target Machine make sure user can use docker
|
||||||
|
```bash
|
||||||
|
sudo usermod -a -G docker cvtt
|
||||||
|
```
|
||||||
|
**Re-login as cvtt after adding cvtt to the group**
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker rm -f cvtt_config_service
|
||||||
|
docker load -i /tmp/cvtt_config_service.img.tar
|
||||||
|
docker run -d --name=cvtt_config_service -p 6789:6789 -v /home/cvtt/prod/config_service/data:/app/data -v /home/cvtt/prod/logs:/logs config_service
|
||||||
|
```
|
||||||
|
|
||||||
|
## Restarting
|
||||||
|
```bash
|
||||||
|
docker restart cvtt_config_service
|
||||||
|
```
|
||||||
|
|
||||||
|
# Useful Commands
|
||||||
|
```bash
|
||||||
|
docker images
|
||||||
|
docker ps -a
|
||||||
|
docker image rm <image>
|
||||||
|
docker rm <container>
|
||||||
|
docker exec -it <container> /bin/bash
|
||||||
|
```
|
||||||
2
config_service/requirements.txt
Normal file
2
config_service/requirements.txt
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
aiohttp>=3.7.4.post0
|
||||||
|
nest-asyncio>=1.5.5
|
||||||
@ -24,6 +24,7 @@ COPY docker_dev/shared/id_rsa.pub /root/.ssh/id_rsa.pub
|
|||||||
RUN chmod 600 /root/.ssh/id_rsa /root/.ssh/id_rsa.pub
|
RUN chmod 600 /root/.ssh/id_rsa /root/.ssh/id_rsa.pub
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# Shared Volumes
|
# Shared Volumes
|
||||||
RUN mkdir -p /data
|
RUN mkdir -p /data
|
||||||
RUN mkdir /logs
|
RUN mkdir /logs
|
||||||
@ -39,8 +39,8 @@ if [ -z "${DbHost}" ] || [ -z "$Date" ]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
CredKey=""
|
CredKey=""
|
||||||
if [ "${DbHost}" == "cloud28" ] ; then
|
if [ "${DbHost}" == "cvttdata" ] ; then
|
||||||
CredKey=TSDB_MD_CLOUD28_RO
|
CredKey=TSDB_MD_CVTTDATA_RO
|
||||||
elif [ "${DbHost}" == "cloud21" ] ; then
|
elif [ "${DbHost}" == "cloud21" ] ; then
|
||||||
CredKey=TSDB_MD_CLD21_RO
|
CredKey=TSDB_MD_CLD21_RO
|
||||||
else
|
else
|
||||||
3
market_data/md_recorder/.dockerignore
Normal file
3
market_data/md_recorder/.dockerignore
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
.git
|
||||||
|
**/__pycache__
|
||||||
|
.pipenv
|
||||||
25
market_data/md_recorder/Dockerfile
Normal file
25
market_data/md_recorder/Dockerfile
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
FROM python:3.12-slim
|
||||||
|
|
||||||
|
# libpq needed for Timescale
|
||||||
|
RUN apt-get update && apt-get install -y \
|
||||||
|
apt-utils \
|
||||||
|
libpq-dev \
|
||||||
|
build-essential
|
||||||
|
|
||||||
|
COPY requirements.txt /
|
||||||
|
|
||||||
|
RUN pip install --upgrade pip --root-user-action=ignore
|
||||||
|
RUN pip install -r /requirements.txt --root-user-action=ignore
|
||||||
|
|
||||||
|
COPY cvttpy /cvttpy
|
||||||
|
|
||||||
|
RUN mkdir -p /logs /config
|
||||||
|
|
||||||
|
SHELL ["/bin/bash", "-c"]
|
||||||
|
|
||||||
|
ENV PYTHONPATH=/
|
||||||
|
|
||||||
|
COPY entrypoint.sh /entrypoint.sh
|
||||||
|
RUN chmod +x /entrypoint.sh
|
||||||
|
|
||||||
|
ENTRYPOINT ["/entrypoint.sh"]
|
||||||
69
market_data/md_recorder/build.sh
Executable file
69
market_data/md_recorder/build.sh
Executable file
@ -0,0 +1,69 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# --- Settings
|
||||||
|
RegistryService=cloud21.cvtt.vpn:5500
|
||||||
|
ImageName=md_recorder
|
||||||
|
BashFunctionCode=$(realpath $(dirname ${0}))/../../dckr_bld_functions.sh
|
||||||
|
# --- Settings
|
||||||
|
|
||||||
|
usage() {
|
||||||
|
echo "Usage: $0 -V <image_version> -L <library>:<library_version>"
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
# ---------------- cmdline
|
||||||
|
while getopts "V:L:" opt; do
|
||||||
|
case ${opt} in
|
||||||
|
V )
|
||||||
|
ImageVersion=$OPTARG
|
||||||
|
;;
|
||||||
|
L )
|
||||||
|
Library=$OPTARG
|
||||||
|
;;
|
||||||
|
\? )
|
||||||
|
echo "Invalid option: -$OPTARG" >&2
|
||||||
|
usage
|
||||||
|
;;
|
||||||
|
: )
|
||||||
|
echo "Option -$OPTARG requires an argument." >&2
|
||||||
|
usage
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
# ---------------- cmdline
|
||||||
|
|
||||||
|
if [ "${ImageVersion}" == "" ]
|
||||||
|
then
|
||||||
|
usage
|
||||||
|
fi
|
||||||
|
|
||||||
|
Project=
|
||||||
|
ProjectVersion=
|
||||||
|
if [ "${Library}" != "" ] ; then
|
||||||
|
IFS=':' read -ra parts <<< "${Library}"
|
||||||
|
Project=${parts[0]}
|
||||||
|
ProjectVersion=${parts[1]}
|
||||||
|
fi
|
||||||
|
|
||||||
|
DockerDir=$(realpath $(dirname ${0}))
|
||||||
|
|
||||||
|
cd ${DockerDir}
|
||||||
|
source ${BashFunctionCode}
|
||||||
|
|
||||||
|
if [ "${Project}" != "" ]; then
|
||||||
|
get_project_version ${Project} ${ProjectVersion}
|
||||||
|
fi
|
||||||
|
function cleanup {
|
||||||
|
cd ${DockerDir}
|
||||||
|
rm -rf cvttpy
|
||||||
|
}
|
||||||
|
trap cleanup EXIT
|
||||||
|
|
||||||
|
build_docker_image ${ImageName} ${RegistryService} ${ImageVersion} ${Project} ${ProjectVersion}
|
||||||
|
|
||||||
|
|
||||||
|
# echo "**** D E B U G E X I T" && exit
|
||||||
|
echo "***** ${0} D O N E"
|
||||||
|
|
||||||
|
|
||||||
17
market_data/md_recorder/deployment/cloud24/.creds
Normal file
17
market_data/md_recorder/deployment/cloud24/.creds
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
{
|
||||||
|
"__dummy__": null
|
||||||
|
, "TSDB_MD_CLD21": {
|
||||||
|
"host": "cloud21.cvtt.vpn"
|
||||||
|
, "port": 5432
|
||||||
|
, "user": "cvtt"
|
||||||
|
, "database": "cvtt_md"
|
||||||
|
, "password": "ICdIh0JnMM7vM7Pf"
|
||||||
|
}
|
||||||
|
, "TSDB_MD_CVTTDATA": {
|
||||||
|
"host": "cvttdata.cvtt.vpn"
|
||||||
|
, "port": 5432
|
||||||
|
, "user": "cvtt"
|
||||||
|
, "database": "cvtt_md"
|
||||||
|
, "password": "ICdIh0JnMM7vM7Pf"
|
||||||
|
}
|
||||||
|
}
|
||||||
52
market_data/md_recorder/deployment/cloud24/.env
Normal file
52
market_data/md_recorder/deployment/cloud24/.env
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
# ----- cloud24 settings
|
||||||
|
CVTT_USER=1001:1001
|
||||||
|
IMAGE_VERSION=0.0.2
|
||||||
|
|
||||||
|
CONFIG_FILE=/config/md_recorder.cfg
|
||||||
|
CREDS_FILE=/config/.creds
|
||||||
|
|
||||||
|
# bnspot-cvttdata
|
||||||
|
BSCD_CONTAINER_NAME=md_recorder.BNBSPOT_CVTTDATA
|
||||||
|
BSCD_INSTRUMENT_GROUP=BNBSPOT_CVTTDATA
|
||||||
|
BSCD_EXCHANGE_ACCT_NAME=BNBSPOT
|
||||||
|
BSCD_DB_CRED_KEY=TSDB_MD_CVTTDATA
|
||||||
|
|
||||||
|
BSCD_LOG_FILE=/logs/%T.MD_REC.${BSCD_INSTRUMENT_GROUP}.log
|
||||||
|
BSCD_ADD_ARGS=--compress_log
|
||||||
|
|
||||||
|
BSCD_ADMIN_PORT=7201
|
||||||
|
|
||||||
|
# bnspot-cloud21
|
||||||
|
BSCLD21_CONTAINER_NAME=md_recorder.BNBSPOT_CLD21
|
||||||
|
BSCLD21_INSTRUMENT_GROUP=BNBSPOT_CLD21
|
||||||
|
BSCLD21_EXCHANGE_ACCT_NAME=BNBSPOT
|
||||||
|
BSCLD21_DB_CRED_KEY=TSDB_MD_CLD21
|
||||||
|
|
||||||
|
BSCLD21_LOG_FILE=/logs/%T.MD_REC.${BSCLD21_INSTRUMENT_GROUP}.log
|
||||||
|
BSCLD21_ADD_ARGS=--compress_log
|
||||||
|
|
||||||
|
BSCLD21_ADMIN_PORT=7202
|
||||||
|
|
||||||
|
# bnbfut-cloud21
|
||||||
|
BFCLD21_CONTAINER_NAME=md_recorder.BNBFUT_CLD21
|
||||||
|
BFCLD21_INSTRUMENT_GROUP=BNBFUT_CLD21
|
||||||
|
BFCLD21_EXCHANGE_ACCT_NAME=BNBFUT
|
||||||
|
BFCLD21_DB_CRED_KEY=TSDB_MD_CLD21
|
||||||
|
|
||||||
|
BFCLD21_LOG_FILE=/logs/%T.MD_REC.${BFCLD21_INSTRUMENT_GROUP}.log
|
||||||
|
BFCLD21_ADD_ARGS=--compress_log
|
||||||
|
|
||||||
|
BFCLD21_ADMIN_PORT=7203
|
||||||
|
|
||||||
|
# coinbase-cloud21
|
||||||
|
CBCLD21_CONTAINER_NAME=md_recorder.COINBASE_CLD21
|
||||||
|
CBCLD21_INSTRUMENT_GROUP=COINBASE_CLD21
|
||||||
|
CBCLD21_EXCHANGE_ACCT_NAME=COINBASE_AT
|
||||||
|
CBCLD21_DB_CRED_KEY=TSDB_MD_CLD21
|
||||||
|
|
||||||
|
CBCLD21_LOG_FILE=/logs/%T.MD_REC.${CBCLD21_INSTRUMENT_GROUP}.log
|
||||||
|
CBCLD21_ADD_ARGS=--compress_log
|
||||||
|
|
||||||
|
CBCLD21_ADMIN_PORT=7204
|
||||||
|
|
||||||
|
|
||||||
@ -0,0 +1,86 @@
|
|||||||
|
# CVTT Microservices
|
||||||
|
services:
|
||||||
|
bfcld21_md_recorder:
|
||||||
|
image: cloud21.cvtt.vpn:5500/md_recorder:${IMAGE_VERSION}
|
||||||
|
container_name: ${BFCLD21_CONTAINER_NAME}
|
||||||
|
user: ${CVTT_USER:-1001:1001}
|
||||||
|
pull_policy: always
|
||||||
|
restart: unless-stopped
|
||||||
|
environment:
|
||||||
|
CONFIG_SERVICE: ${CONFIG_SERVICE:-cloud16.cvtt.vpn:6789}
|
||||||
|
CONFIG_FILE: ${CONFIG_FILE:-/config/md_recorder.cfg}
|
||||||
|
CREDS_FILE: ${CREDS_FILE}
|
||||||
|
EXCHANGE_ACCT_NAME: ${BFCLD21_EXCHANGE_ACCT_NAME}
|
||||||
|
INSTRUMENT_GROUP: ${BFCLD21_INSTRUMENT_GROUP}
|
||||||
|
DB_CRED_KEY: ${BFCLD21_DB_CRED_KEY}
|
||||||
|
LOG_FILE: ${BFCLD21_LOG_FILE}
|
||||||
|
ADD_ARGS: ${BFCLD21_ADD_ARGS:-}
|
||||||
|
volumes:
|
||||||
|
- ./config:/config
|
||||||
|
- ./logs:/logs
|
||||||
|
ports:
|
||||||
|
- ${BFCLD21_ADMIN_PORT}:7200
|
||||||
|
|
||||||
|
|
||||||
|
cbcld21_md_recorder:
|
||||||
|
image: cloud21.cvtt.vpn:5500/md_recorder:${IMAGE_VERSION}
|
||||||
|
container_name: ${CBCLD21_CONTAINER_NAME}
|
||||||
|
user: ${CVTT_USER:-1001:1001}
|
||||||
|
pull_policy: always
|
||||||
|
restart: unless-stopped
|
||||||
|
environment:
|
||||||
|
CONFIG_SERVICE: ${CONFIG_SERVICE:-cloud16.cvtt.vpn:6789}
|
||||||
|
CONFIG_FILE: ${CONFIG_FILE:-/config/md_recorder.cfg}
|
||||||
|
CREDS_FILE: ${CREDS_FILE}
|
||||||
|
EXCHANGE_ACCT_NAME: ${CBCLD21_EXCHANGE_ACCT_NAME}
|
||||||
|
INSTRUMENT_GROUP: ${CBCLD21_INSTRUMENT_GROUP}
|
||||||
|
DB_CRED_KEY: ${CBCLD21_DB_CRED_KEY}
|
||||||
|
LOG_FILE: ${CBCLD21_LOG_FILE}
|
||||||
|
ADD_ARGS: ${CBCLD21_ADD_ARGS:-}
|
||||||
|
volumes:
|
||||||
|
- ./config:/config
|
||||||
|
- ./logs:/logs
|
||||||
|
ports:
|
||||||
|
- ${CBCLD21_ADMIN_PORT}:7200
|
||||||
|
|
||||||
|
bscld21_md_recorder:
|
||||||
|
image: cloud21.cvtt.vpn:5500/md_recorder:${IMAGE_VERSION}
|
||||||
|
container_name: ${BSCLD21_CONTAINER_NAME}
|
||||||
|
user: ${CVTT_USER:-1001:1001}
|
||||||
|
pull_policy: always
|
||||||
|
restart: unless-stopped
|
||||||
|
environment:
|
||||||
|
CONFIG_SERVICE: ${CONFIG_SERVICE:-cloud16.cvtt.vpn:6789}
|
||||||
|
CONFIG_FILE: ${CONFIG_FILE:-/config/md_recorder.cfg}
|
||||||
|
CREDS_FILE: ${CREDS_FILE}
|
||||||
|
EXCHANGE_ACCT_NAME: ${BSCLD21_EXCHANGE_ACCT_NAME}
|
||||||
|
INSTRUMENT_GROUP: ${BSCLD21_INSTRUMENT_GROUP}
|
||||||
|
DB_CRED_KEY: ${BSCLD21_DB_CRED_KEY}
|
||||||
|
LOG_FILE: ${BSCLD21_LOG_FILE}
|
||||||
|
ADD_ARGS: ${BSCLD21_ADD_ARGS:-}
|
||||||
|
volumes:
|
||||||
|
- ./config:/config
|
||||||
|
- ./logs:/logs
|
||||||
|
ports:
|
||||||
|
- ${BSCLD21_ADMIN_PORT}:7200
|
||||||
|
|
||||||
|
bscd_md_recorder:
|
||||||
|
image: cloud21.cvtt.vpn:5500/md_recorder:${IMAGE_VERSION}
|
||||||
|
container_name: ${BSCD_CONTAINER_NAME}
|
||||||
|
user: ${CVTT_USER:-1001:1001}
|
||||||
|
pull_policy: always
|
||||||
|
restart: unless-stopped
|
||||||
|
environment:
|
||||||
|
CONFIG_SERVICE: ${CONFIG_SERVICE:-cloud16.cvtt.vpn:6789}
|
||||||
|
CONFIG_FILE: ${CONFIG_FILE:-/config/md_recorder.cfg}
|
||||||
|
CREDS_FILE: ${CREDS_FILE}
|
||||||
|
EXCHANGE_ACCT_NAME: ${BSCD_EXCHANGE_ACCT_NAME}
|
||||||
|
INSTRUMENT_GROUP: ${BSCD_INSTRUMENT_GROUP}
|
||||||
|
DB_CRED_KEY: ${BSCD_DB_CRED_KEY}
|
||||||
|
LOG_FILE: ${BSCD_LOG_FILE}
|
||||||
|
ADD_ARGS: ${BSCD_ADD_ARGS:-}
|
||||||
|
volumes:
|
||||||
|
- ./config:/config
|
||||||
|
- ./logs:/logs
|
||||||
|
ports:
|
||||||
|
- ${BSCD_ADMIN_PORT}:7200
|
||||||
206
market_data/md_recorder/deployment/cloud24/md_recorder.cfg
Normal file
206
market_data/md_recorder/deployment/cloud24/md_recorder.cfg
Normal file
@ -0,0 +1,206 @@
|
|||||||
|
{
|
||||||
|
"refdata": {
|
||||||
|
"assets": @inc=http://@env{CONFIG_SERVICE}/refdata/assets
|
||||||
|
, "instruments": @inc=http://@env{CONFIG_SERVICE}/refdata/instruments
|
||||||
|
, "exchange_instruments": @inc=http://@env{CONFIG_SERVICE}/refdata/exchange_instruments
|
||||||
|
, "dynamic_instrument_exchanges": ["ALPACA"]
|
||||||
|
, "exchanges": {
|
||||||
|
"COINBASE_AT": {
|
||||||
|
"exchange_id": "COINBASE"
|
||||||
|
, "name": "Coinbase Advanced Trade"
|
||||||
|
, "type": "SPOT"
|
||||||
|
|
||||||
|
, "mktdata" : {
|
||||||
|
# ****** NEW VAlUE
|
||||||
|
# "class": "cvttpy.exchanges.coinbase.spot.mkt_data.CoinbaseMultiWsFeed"
|
||||||
|
"class": "cvttpy.exchanges.coinbase.spot.mkt_data.CoinbaseMdFeed"
|
||||||
|
# ****** NEW VAlUE
|
||||||
|
|
||||||
|
, "reconnect_secs": 2
|
||||||
|
, "max_connections": 10
|
||||||
|
, "price_throttle": true
|
||||||
|
|
||||||
|
, "ws_url": ["WSS", "wss://ws-feed.exchange.coinbase.com"]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
, "BNBSPOT": {
|
||||||
|
"exchange_id": "BNBSPOT"
|
||||||
|
, "name": "Binance Spot"
|
||||||
|
, "type": "SPOT"
|
||||||
|
|
||||||
|
, "mktdata" : {
|
||||||
|
# -------- NEW VALUE
|
||||||
|
# "class": "cvttpy.exchanges.binance.spot.mkt_data.BnbSpotMultiWsFeed"
|
||||||
|
"class": "cvttpy.exchanges.binance.spot.mkt_data.BnbSpotMktDataFeed"
|
||||||
|
# -------- NEW VALUE
|
||||||
|
, "max_connections": 10
|
||||||
|
, "reconnect_secs": 2.0
|
||||||
|
|
||||||
|
|
||||||
|
, "ws_url": ["WSS", "wss://stream.binance.com/ws"]
|
||||||
|
, "REST": {
|
||||||
|
"depth_snapshot_url": ["GET", "https://api.binance.com/api/v3/depth"],
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
, "BNBFUT": {
|
||||||
|
"exchange_id": "BNBFUT"
|
||||||
|
, "name": "Binance Futures USD-M"
|
||||||
|
, "type": "FUTURES"
|
||||||
|
|
||||||
|
, "mktdata" : {
|
||||||
|
# -------- NEW VALUE
|
||||||
|
# "class": "cvttpy.exchanges.binance.futures.mkt_data.BnbFutMultiWsFeed"
|
||||||
|
"class": "cvttpy.exchanges.binance.futures.mkt_data.BnbFutMktDataFeed"
|
||||||
|
# -------- NEW VALUE
|
||||||
|
, "max_connections": 10
|
||||||
|
, "reconnect_secs": 2.0
|
||||||
|
|
||||||
|
, "ws_url": ["WSS", "wss://fstream.binance.com/ws"]
|
||||||
|
|
||||||
|
, "REST": {
|
||||||
|
# https://fapi.binance.com/fapi/v1/depth?symbol=BNBBTC&limit=1000
|
||||||
|
"depth_snapshot_url": ["GET", "https://fapi.binance.com/fapi/v1/depth"],
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
, "comm": @inc=http://@env{CONFIG_SERVICE}/apps/common/comm
|
||||||
|
|
||||||
|
, "md_recorder": {
|
||||||
|
"instrument_groups": {
|
||||||
|
"BNBFUT_CLD21": [
|
||||||
|
"BNBFUT:PERP-BTC-USDT"
|
||||||
|
, "BNBFUT:PERP-ETH-USDT"
|
||||||
|
]
|
||||||
|
"BNBFUT_CVTTDATA": [
|
||||||
|
"BNBFUT:PERP-BTC-USDT"
|
||||||
|
, "BNBFUT:PERP-ETH-USDT"
|
||||||
|
]
|
||||||
|
, "BNBSPOT_CLD21": [
|
||||||
|
"BNBSPOT:PAIR-ADA-USDT"
|
||||||
|
, "BNBSPOT:PAIR-BCH-USDT"
|
||||||
|
, "BNBSPOT:PAIR-BTC-USDT"
|
||||||
|
, "BNBSPOT:PAIR-DOT-USDT"
|
||||||
|
, "BNBSPOT:PAIR-ETH-USDT"
|
||||||
|
, "BNBSPOT:PAIR-LTC-USDT"
|
||||||
|
, "BNBSPOT:PAIR-SOL-USDT"
|
||||||
|
, "BNBSPOT:PAIR-USDC-USDT"
|
||||||
|
, "BNBSPOT:PAIR-XRP-USDT"
|
||||||
|
]
|
||||||
|
, "BNBSPOT_CVTTDATA": [
|
||||||
|
"BNBSPOT:PAIR-ADA-USDT"
|
||||||
|
, "BNBSPOT:PAIR-BCH-USDT"
|
||||||
|
, "BNBSPOT:PAIR-BTC-USDT"
|
||||||
|
, "BNBSPOT:PAIR-DOT-USDT"
|
||||||
|
, "BNBSPOT:PAIR-ETH-USDT"
|
||||||
|
, "BNBSPOT:PAIR-LTC-USDT"
|
||||||
|
, "BNBSPOT:PAIR-SOL-USDT"
|
||||||
|
, "BNBSPOT:PAIR-USDC-USDT"
|
||||||
|
, "BNBSPOT:PAIR-XRP-USDT"
|
||||||
|
]
|
||||||
|
, "COINBASE_CLD21": [
|
||||||
|
"COINBASE:PAIR-ADA-USD"
|
||||||
|
, "COINBASE:PAIR-BCH-USD"
|
||||||
|
, "COINBASE:PAIR-BTC-USD"
|
||||||
|
, "COINBASE:PAIR-DOT-USD"
|
||||||
|
, "COINBASE:PAIR-ETH-USD"
|
||||||
|
, "COINBASE:PAIR-LTC-USD"
|
||||||
|
, "COINBASE:PAIR-SOL-USD"
|
||||||
|
, "COINBASE:PAIR-XRP-USD"
|
||||||
|
]
|
||||||
|
, "COINBASE_CVTTDATA": [
|
||||||
|
"COINBASE:PAIR-ADA-USD"
|
||||||
|
, "COINBASE:PAIR-BCH-USD"
|
||||||
|
, "COINBASE:PAIR-BTC-USD"
|
||||||
|
, "COINBASE:PAIR-DOT-USD"
|
||||||
|
, "COINBASE:PAIR-ETH-USD"
|
||||||
|
, "COINBASE:PAIR-LTC-USD"
|
||||||
|
, "COINBASE:PAIR-SOL-USD"
|
||||||
|
, "COINBASE:PAIR-XRP-USD"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
, "db": {
|
||||||
|
"class": "cvttpy.tools.db.timescale.tsdb_client.TimescaleDbClient"
|
||||||
|
}
|
||||||
|
, "flush_interval_sec": 0.5
|
||||||
|
|
||||||
|
, "collections": {
|
||||||
|
"__dummy__": null
|
||||||
|
, "ALPACA": {
|
||||||
|
# dynamic instruments names
|
||||||
|
"tables": {
|
||||||
|
"trades": "alpaca_iex.md_trades"
|
||||||
|
, "booktops": "alpaca_iex.md_booktops"
|
||||||
|
, "booksnaps": "alpaca_iex.md_booksnaps"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
, "BNBSPOT": {
|
||||||
|
"instruments": {
|
||||||
|
"PAIR-ADA-USDT": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-BCH-USDT": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-BTC-USDT": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-DOT-USDT": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-ETH-USDT": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-LTC-USDT": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-SOL-USDT": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-USDC-USDT": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-XRP-USDT": ["TRADES", "BOOK_TOP"]
|
||||||
|
}
|
||||||
|
, "tables": {
|
||||||
|
"trades": "bnbspot.md_trades"
|
||||||
|
, "booktops": "bnbspot.md_booktops"
|
||||||
|
, "booksnaps": "bnbspot.md_booksnaps"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
, "BNBFUT": {
|
||||||
|
"instruments": {
|
||||||
|
"PERP-BTC-USDT": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PERP-ETH-USDT": ["TRADES", "BOOK_TOP"]
|
||||||
|
}
|
||||||
|
, "tables": {
|
||||||
|
"trades": "bnbfut.md_trades"
|
||||||
|
, "booktops": "bnbfut.md_booktops"
|
||||||
|
, "booksnaps": "bnbfut.md_booksnaps"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
, "COINBASE": {
|
||||||
|
"instruments": {
|
||||||
|
"PAIR-ADA-USD": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-BCH-USD": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-BTC-USD": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-DOT-USD": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-ETH-USD": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-LTC-USD": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-SOL-USD": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-XRP-USD": ["TRADES", "BOOK_TOP"]
|
||||||
|
}
|
||||||
|
, "tables": {
|
||||||
|
"trades": "coinbase.md_trades"
|
||||||
|
, "booktops": "coinbase.md_booktops"
|
||||||
|
, "booksnaps": "coinbase.md_booksnaps"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# ----------------------------------
|
||||||
|
, "exchanges_settings": {
|
||||||
|
"*": {
|
||||||
|
"order_entry": {
|
||||||
|
"enabled": false
|
||||||
|
, "streaming": false
|
||||||
|
},
|
||||||
|
"mkt_data": {
|
||||||
|
"enabled": true
|
||||||
|
, "streaming": true
|
||||||
|
},
|
||||||
|
"accounting": {
|
||||||
|
"enabled": false
|
||||||
|
, "streaming": false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
17
market_data/md_recorder/deployment/cvtt-md/.creds
Normal file
17
market_data/md_recorder/deployment/cvtt-md/.creds
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
{
|
||||||
|
"__dummy__": null
|
||||||
|
, "TSDB_MD_CLD21": {
|
||||||
|
"host": "cloud21.cvtt.vpn"
|
||||||
|
, "port": 5432
|
||||||
|
, "user": "cvtt"
|
||||||
|
, "database": "cvtt_md"
|
||||||
|
, "password": "ICdIh0JnMM7vM7Pf"
|
||||||
|
}
|
||||||
|
, "TSDB_MD_CVTTDATA": {
|
||||||
|
"host": "cvttdata.cvtt.vpn"
|
||||||
|
, "port": 5432
|
||||||
|
, "user": "cvtt"
|
||||||
|
, "database": "cvtt_md"
|
||||||
|
, "password": "ICdIh0JnMM7vM7Pf"
|
||||||
|
}
|
||||||
|
}
|
||||||
28
market_data/md_recorder/deployment/cvtt-md/.env
Normal file
28
market_data/md_recorder/deployment/cvtt-md/.env
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
# -------- cvtt-md
|
||||||
|
CVTT_USER=1001:1001
|
||||||
|
IMAGE_VERSION=0.0.2
|
||||||
|
|
||||||
|
CONFIG_FILE=/config/md_recorder.cfg
|
||||||
|
CREDS_FILE=/config/.creds
|
||||||
|
|
||||||
|
# bnbfut-cvttdata
|
||||||
|
BFCD_CONTAINER_NAME=md_recorder.BNBFUT_CVTTDATA
|
||||||
|
BFCD_INSTRUMENT_GROUP=BNBFUT_CVTTDATA
|
||||||
|
BFCD_EXCHANGE_ACCT_NAME=BNBFUT
|
||||||
|
BFCD_DB_CRED_KEY=TSDB_MD_CVTTDATA
|
||||||
|
|
||||||
|
BFCD_LOG_FILE=/logs/%T.MD_REC.${BFCD_INSTRUMENT_GROUP}.log
|
||||||
|
BFCD_ADD_ARGS=--compress_log
|
||||||
|
|
||||||
|
BFCD_ADMIN_PORT=7201
|
||||||
|
|
||||||
|
# coinbase-cvttdata
|
||||||
|
CBCD_CONTAINER_NAME=md_recorder.COINBASE_CVTTDATA
|
||||||
|
CBCD_INSTRUMENT_GROUP=COINBASE_CVTTDATA
|
||||||
|
CBCD_EXCHANGE_ACCT_NAME=COINBASE_AT
|
||||||
|
CBCD_DB_CRED_KEY=TSDB_MD_CVTTDATA
|
||||||
|
|
||||||
|
CBCD_LOG_FILE=/logs/%T.MD_REC.${CBCD_INSTRUMENT_GROUP}.log
|
||||||
|
CBCD_ADD_ARGS=--compress_log
|
||||||
|
|
||||||
|
CBCD_ADMIN_PORT=7202
|
||||||
@ -0,0 +1,44 @@
|
|||||||
|
# CVTT Microservices
|
||||||
|
services:
|
||||||
|
bfcd_md_recorder:
|
||||||
|
image: cloud21.cvtt.vpn:5500/md_recorder:${IMAGE_VERSION}
|
||||||
|
container_name: ${BFCD_CONTAINER_NAME}
|
||||||
|
user: ${CVTT_USER:-1001:1001}
|
||||||
|
pull_policy: always
|
||||||
|
restart: unless-stopped
|
||||||
|
environment:
|
||||||
|
CONFIG_SERVICE: ${CONFIG_SERVICE:-cloud16.cvtt.vpn:6789}
|
||||||
|
CONFIG_FILE: ${CONFIG_FILE:-/config/md_recorder.cfg}
|
||||||
|
CREDS_FILE: ${CREDS_FILE}
|
||||||
|
EXCHANGE_ACCT_NAME: ${BFCD_EXCHANGE_ACCT_NAME}
|
||||||
|
INSTRUMENT_GROUP: ${BFCD_INSTRUMENT_GROUP}
|
||||||
|
DB_CRED_KEY: ${BFCD_DB_CRED_KEY}
|
||||||
|
LOG_FILE: ${BFCD_LOG_FILE}
|
||||||
|
ADD_ARGS: ${BFCD_ADD_ARGS:-}
|
||||||
|
volumes:
|
||||||
|
- ./config:/config
|
||||||
|
- ./logs:/logs
|
||||||
|
ports:
|
||||||
|
- ${BFCD_ADMIN_PORT}:7200
|
||||||
|
|
||||||
|
|
||||||
|
cbcd_md_recorder:
|
||||||
|
image: cloud21.cvtt.vpn:5500/md_recorder:${IMAGE_VERSION}
|
||||||
|
container_name: ${CBCD_CONTAINER_NAME}
|
||||||
|
user: ${CVTT_USER:-1001:1001}
|
||||||
|
pull_policy: always
|
||||||
|
restart: unless-stopped
|
||||||
|
environment:
|
||||||
|
CONFIG_SERVICE: ${CONFIG_SERVICE:-cloud16.cvtt.vpn:6789}
|
||||||
|
CONFIG_FILE: ${CONFIG_FILE:-/config/md_recorder.cfg}
|
||||||
|
CREDS_FILE: ${CREDS_FILE}
|
||||||
|
EXCHANGE_ACCT_NAME: ${CBCD_EXCHANGE_ACCT_NAME}
|
||||||
|
INSTRUMENT_GROUP: ${CBCD_INSTRUMENT_GROUP}
|
||||||
|
DB_CRED_KEY: ${CBCD_DB_CRED_KEY}
|
||||||
|
LOG_FILE: ${CBCD_LOG_FILE}
|
||||||
|
ADD_ARGS: ${CBCD_ADD_ARGS:-}
|
||||||
|
volumes:
|
||||||
|
- ./config:/config
|
||||||
|
- ./logs:/logs
|
||||||
|
ports:
|
||||||
|
- ${CBCD_ADMIN_PORT}:7200
|
||||||
206
market_data/md_recorder/deployment/cvtt-md/md_recorder.cfg
Normal file
206
market_data/md_recorder/deployment/cvtt-md/md_recorder.cfg
Normal file
@ -0,0 +1,206 @@
|
|||||||
|
{
|
||||||
|
"refdata": {
|
||||||
|
"assets": @inc=http://@env{CONFIG_SERVICE}/refdata/assets
|
||||||
|
, "instruments": @inc=http://@env{CONFIG_SERVICE}/refdata/instruments
|
||||||
|
, "exchange_instruments": @inc=http://@env{CONFIG_SERVICE}/refdata/exchange_instruments
|
||||||
|
, "dynamic_instrument_exchanges": ["ALPACA"]
|
||||||
|
, "exchanges": {
|
||||||
|
"COINBASE_AT": {
|
||||||
|
"exchange_id": "COINBASE"
|
||||||
|
, "name": "Coinbase Advanced Trade"
|
||||||
|
, "type": "SPOT"
|
||||||
|
|
||||||
|
, "mktdata" : {
|
||||||
|
# ****** NEW VAlUE
|
||||||
|
# "class": "cvttpy.exchanges.coinbase.spot.mkt_data.CoinbaseMultiWsFeed"
|
||||||
|
"class": "cvttpy.exchanges.coinbase.spot.mkt_data.CoinbaseMdFeed"
|
||||||
|
# ****** NEW VAlUE
|
||||||
|
|
||||||
|
, "reconnect_secs": 2
|
||||||
|
, "max_connections": 10
|
||||||
|
, "price_throttle": true
|
||||||
|
|
||||||
|
, "ws_url": ["WSS", "wss://ws-feed.exchange.coinbase.com"]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
, "BNBSPOT": {
|
||||||
|
"exchange_id": "BNBSPOT"
|
||||||
|
, "name": "Binance Spot"
|
||||||
|
, "type": "SPOT"
|
||||||
|
|
||||||
|
, "mktdata" : {
|
||||||
|
# -------- NEW VALUE
|
||||||
|
# "class": "cvttpy.exchanges.binance.spot.mkt_data.BnbSpotMultiWsFeed"
|
||||||
|
"class": "cvttpy.exchanges.binance.spot.mkt_data.BnbSpotMktDataFeed"
|
||||||
|
# -------- NEW VALUE
|
||||||
|
, "max_connections": 10
|
||||||
|
, "reconnect_secs": 2.0
|
||||||
|
|
||||||
|
|
||||||
|
, "ws_url": ["WSS", "wss://stream.binance.com/ws"]
|
||||||
|
, "REST": {
|
||||||
|
"depth_snapshot_url": ["GET", "https://api.binance.com/api/v3/depth"],
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
, "BNBFUT": {
|
||||||
|
"exchange_id": "BNBFUT"
|
||||||
|
, "name": "Binance Futures USD-M"
|
||||||
|
, "type": "FUTURES"
|
||||||
|
|
||||||
|
, "mktdata" : {
|
||||||
|
# -------- NEW VALUE
|
||||||
|
# "class": "cvttpy.exchanges.binance.futures.mkt_data.BnbFutMultiWsFeed"
|
||||||
|
"class": "cvttpy.exchanges.binance.futures.mkt_data.BnbFutMktDataFeed"
|
||||||
|
# -------- NEW VALUE
|
||||||
|
, "max_connections": 10
|
||||||
|
, "reconnect_secs": 2.0
|
||||||
|
|
||||||
|
, "ws_url": ["WSS", "wss://fstream.binance.com/ws"]
|
||||||
|
|
||||||
|
, "REST": {
|
||||||
|
# https://fapi.binance.com/fapi/v1/depth?symbol=BNBBTC&limit=1000
|
||||||
|
"depth_snapshot_url": ["GET", "https://fapi.binance.com/fapi/v1/depth"],
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
, "comm": @inc=http://@env{CONFIG_SERVICE}/apps/common/comm
|
||||||
|
|
||||||
|
, "md_recorder": {
|
||||||
|
"instrument_groups": {
|
||||||
|
"BNBFUT_CLD21": [
|
||||||
|
"BNBFUT:PERP-BTC-USDT"
|
||||||
|
, "BNBFUT:PERP-ETH-USDT"
|
||||||
|
]
|
||||||
|
"BNBFUT_CVTTDATA": [
|
||||||
|
"BNBFUT:PERP-BTC-USDT"
|
||||||
|
, "BNBFUT:PERP-ETH-USDT"
|
||||||
|
]
|
||||||
|
, "BNBSPOT_CLD21": [
|
||||||
|
"BNBSPOT:PAIR-ADA-USDT"
|
||||||
|
, "BNBSPOT:PAIR-BCH-USDT"
|
||||||
|
, "BNBSPOT:PAIR-BTC-USDT"
|
||||||
|
, "BNBSPOT:PAIR-DOT-USDT"
|
||||||
|
, "BNBSPOT:PAIR-ETH-USDT"
|
||||||
|
, "BNBSPOT:PAIR-LTC-USDT"
|
||||||
|
, "BNBSPOT:PAIR-SOL-USDT"
|
||||||
|
, "BNBSPOT:PAIR-USDC-USDT"
|
||||||
|
, "BNBSPOT:PAIR-XRP-USDT"
|
||||||
|
]
|
||||||
|
, "BNBSPOT_CVTTDATA": [
|
||||||
|
"BNBSPOT:PAIR-ADA-USDT"
|
||||||
|
, "BNBSPOT:PAIR-BCH-USDT"
|
||||||
|
, "BNBSPOT:PAIR-BTC-USDT"
|
||||||
|
, "BNBSPOT:PAIR-DOT-USDT"
|
||||||
|
, "BNBSPOT:PAIR-ETH-USDT"
|
||||||
|
, "BNBSPOT:PAIR-LTC-USDT"
|
||||||
|
, "BNBSPOT:PAIR-SOL-USDT"
|
||||||
|
, "BNBSPOT:PAIR-USDC-USDT"
|
||||||
|
, "BNBSPOT:PAIR-XRP-USDT"
|
||||||
|
]
|
||||||
|
, "COINBASE_CLD21": [
|
||||||
|
"COINBASE:PAIR-ADA-USD"
|
||||||
|
, "COINBASE:PAIR-BCH-USD"
|
||||||
|
, "COINBASE:PAIR-BTC-USD"
|
||||||
|
, "COINBASE:PAIR-DOT-USD"
|
||||||
|
, "COINBASE:PAIR-ETH-USD"
|
||||||
|
, "COINBASE:PAIR-LTC-USD"
|
||||||
|
, "COINBASE:PAIR-SOL-USD"
|
||||||
|
, "COINBASE:PAIR-XRP-USD"
|
||||||
|
]
|
||||||
|
, "COINBASE_CVTTDATA": [
|
||||||
|
"COINBASE:PAIR-ADA-USD"
|
||||||
|
, "COINBASE:PAIR-BCH-USD"
|
||||||
|
, "COINBASE:PAIR-BTC-USD"
|
||||||
|
, "COINBASE:PAIR-DOT-USD"
|
||||||
|
, "COINBASE:PAIR-ETH-USD"
|
||||||
|
, "COINBASE:PAIR-LTC-USD"
|
||||||
|
, "COINBASE:PAIR-SOL-USD"
|
||||||
|
, "COINBASE:PAIR-XRP-USD"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
, "db": {
|
||||||
|
"class": "cvttpy.tools.db.timescale.tsdb_client.TimescaleDbClient"
|
||||||
|
}
|
||||||
|
, "flush_interval_sec": 0.5
|
||||||
|
|
||||||
|
, "collections": {
|
||||||
|
"__dummy__": null
|
||||||
|
, "ALPACA": {
|
||||||
|
# dynamic instruments names
|
||||||
|
"tables": {
|
||||||
|
"trades": "alpaca_iex.md_trades"
|
||||||
|
, "booktops": "alpaca_iex.md_booktops"
|
||||||
|
, "booksnaps": "alpaca_iex.md_booksnaps"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
, "BNBSPOT": {
|
||||||
|
"instruments": {
|
||||||
|
"PAIR-ADA-USDT": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-BCH-USDT": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-BTC-USDT": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-DOT-USDT": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-ETH-USDT": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-LTC-USDT": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-SOL-USDT": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-USDC-USDT": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-XRP-USDT": ["TRADES", "BOOK_TOP"]
|
||||||
|
}
|
||||||
|
, "tables": {
|
||||||
|
"trades": "bnbspot.md_trades"
|
||||||
|
, "booktops": "bnbspot.md_booktops"
|
||||||
|
, "booksnaps": "bnbspot.md_booksnaps"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
, "BNBFUT": {
|
||||||
|
"instruments": {
|
||||||
|
"PERP-BTC-USDT": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PERP-ETH-USDT": ["TRADES", "BOOK_TOP"]
|
||||||
|
}
|
||||||
|
, "tables": {
|
||||||
|
"trades": "bnbfut.md_trades"
|
||||||
|
, "booktops": "bnbfut.md_booktops"
|
||||||
|
, "booksnaps": "bnbfut.md_booksnaps"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
, "COINBASE": {
|
||||||
|
"instruments": {
|
||||||
|
"PAIR-ADA-USD": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-BCH-USD": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-BTC-USD": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-DOT-USD": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-ETH-USD": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-LTC-USD": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-SOL-USD": ["TRADES", "BOOK_TOP"]
|
||||||
|
, "PAIR-XRP-USD": ["TRADES", "BOOK_TOP"]
|
||||||
|
}
|
||||||
|
, "tables": {
|
||||||
|
"trades": "coinbase.md_trades"
|
||||||
|
, "booktops": "coinbase.md_booktops"
|
||||||
|
, "booksnaps": "coinbase.md_booksnaps"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# ----------------------------------
|
||||||
|
, "exchanges_settings": {
|
||||||
|
"*": {
|
||||||
|
"order_entry": {
|
||||||
|
"enabled": false
|
||||||
|
, "streaming": false
|
||||||
|
},
|
||||||
|
"mkt_data": {
|
||||||
|
"enabled": true
|
||||||
|
, "streaming": true
|
||||||
|
},
|
||||||
|
"accounting": {
|
||||||
|
"enabled": false
|
||||||
|
, "streaming": false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
22
market_data/md_recorder/entrypoint.sh
Executable file
22
market_data/md_recorder/entrypoint.sh
Executable file
@ -0,0 +1,22 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# runs in container
|
||||||
|
|
||||||
|
|
||||||
|
Cmd="python3.12"
|
||||||
|
Cmd+=" cvttpy/apps/md/md_recorder.py"
|
||||||
|
|
||||||
|
Cmd+=" --config=${CONFIG_FILE:-/config/cvtt_musvc.cfg}"
|
||||||
|
Cmd+=" --credentials_file=${CREDS_FILE:-/config/.creds}"
|
||||||
|
|
||||||
|
Cmd="${Cmd} --instrument_group=${INSTRUMENT_GROUP}"
|
||||||
|
Cmd="${Cmd} --exch_acct_cfgname=${EXCHANGE_ACCT_NAME}"
|
||||||
|
Cmd="${Cmd} --db_credentials_key=${DB_CRED_KEY}"
|
||||||
|
Cmd="${Cmd} --admin_port=7200"
|
||||||
|
|
||||||
|
Cmd+=" --log_file=${LOG_FILE:-/logs/%T.MD_REC.${INSTRUMENT_GROUP}.log}"
|
||||||
|
Cmd+=" ${ADD_ARGS}"
|
||||||
|
|
||||||
|
echo ${Cmd}
|
||||||
|
exec ${Cmd}
|
||||||
|
|
||||||
8
market_data/md_recorder/requirements.txt
Normal file
8
market_data/md_recorder/requirements.txt
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
aiohttp>=3.7.4.post0
|
||||||
|
nest-asyncio>=1.5.5
|
||||||
|
psycopg>=3.2.1
|
||||||
|
hjson>=3.1.0
|
||||||
|
pandas>=1.5.3
|
||||||
|
sortedcontainers>=2.4.0
|
||||||
|
redis>=5.0.8
|
||||||
|
debugpy>=1.8.13
|
||||||
3
market_data/md_recorder_monitor/.dockerignore
Normal file
3
market_data/md_recorder_monitor/.dockerignore
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
.git
|
||||||
|
**/__pycache__
|
||||||
|
.pipenv
|
||||||
25
microservices/.env
Normal file
25
microservices/.env
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
CONFIG_SERVICE=cloud16.cvtt.vpn:6789
|
||||||
|
CONFIG_COMM_SETTINGS=comm/pubsub/redis/docker_microservices
|
||||||
|
CONFIG_FILE="http://${CONFIG_SERVICE}/apps/cvtt_musvc"
|
||||||
|
|
||||||
|
CVTT_USER=1001:1001
|
||||||
|
CVTT_VERSION=0.0.3
|
||||||
|
|
||||||
|
# MDGW_CREDS_FILE=.creds
|
||||||
|
MDGW_LOG_FILE=%T.md_gateway.log
|
||||||
|
MDGW_ADD_ARGS=
|
||||||
|
|
||||||
|
# OEGW_CREDS_FILE=.creds
|
||||||
|
OEGW_LOG_FILE=%T.oe_gateway.log
|
||||||
|
#OEGW_ADD_ARGS="--log_level=DEBUG --debug_mode"
|
||||||
|
OEGW_ADD_ARGS="--debug_mode"
|
||||||
|
|
||||||
|
# ACGW_CREDS_FILE=.creds
|
||||||
|
ACGW_LOG_FILE=%T.ac_gateway.log
|
||||||
|
ACGW_ADD_ARGS=
|
||||||
|
|
||||||
|
PXER_LOG_FILE=%T.pricer.log
|
||||||
|
PXER_ADD_ARGS=
|
||||||
|
|
||||||
|
COORD_LOG_FILE=%T.coordinator.log
|
||||||
|
COORD_ADD_ARGS=
|
||||||
3
microservices/ac_gateway/.dockerignore
Normal file
3
microservices/ac_gateway/.dockerignore
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
.git
|
||||||
|
**/__pycache__
|
||||||
|
.pipenv
|
||||||
19
microservices/ac_gateway/Dockerfile
Normal file
19
microservices/ac_gateway/Dockerfile
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
FROM python:3.12-slim
|
||||||
|
|
||||||
|
COPY requirements.txt /
|
||||||
|
|
||||||
|
RUN pip install --upgrade pip --root-user-action=ignore
|
||||||
|
RUN pip install -r /requirements.txt --root-user-action=ignore
|
||||||
|
|
||||||
|
COPY cvttpy /cvttpy
|
||||||
|
|
||||||
|
RUN mkdir -p /logs /config
|
||||||
|
|
||||||
|
SHELL ["/bin/bash", "-c"]
|
||||||
|
|
||||||
|
ENV PYTHONPATH=/
|
||||||
|
|
||||||
|
COPY entrypoint.sh /entrypoint.sh
|
||||||
|
RUN chmod +x /entrypoint.sh
|
||||||
|
|
||||||
|
ENTRYPOINT ["/entrypoint.sh"]
|
||||||
16
microservices/ac_gateway/entrypoint.sh
Executable file
16
microservices/ac_gateway/entrypoint.sh
Executable file
@ -0,0 +1,16 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
LogDir=/logs
|
||||||
|
|
||||||
|
Cmd="python3.12"
|
||||||
|
Cmd+=" cvttpy/apps/microservices/market_gateways/accounting_gateway.py"
|
||||||
|
|
||||||
|
Cmd+=" --config=${CONFIG_FILE:-/config/cvtt_musvc.cfg}"
|
||||||
|
Cmd+=" --credentials_file=${ACGW_CREDS_FILE:-/config/.creds}"
|
||||||
|
|
||||||
|
Cmd+=" --log_file=${LogDir}/${ACGW_LOG_FILE:-%T.ac_gateway.log}"
|
||||||
|
Cmd+=" ${ACGW_ADD_ARGS}"
|
||||||
|
|
||||||
|
echo ${Cmd}
|
||||||
|
exec ${Cmd}
|
||||||
|
|
||||||
9
microservices/ac_gateway/requirements.txt
Normal file
9
microservices/ac_gateway/requirements.txt
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
aiohttp>=3.7.4.post0
|
||||||
|
nest-asyncio>=1.5.5
|
||||||
|
hjson>=3.1.0
|
||||||
|
sortedcontainers>=2.4.0
|
||||||
|
redis>=5.0.8
|
||||||
|
python-dateutil>=2.8.2
|
||||||
|
types-python-dateutil>=2.8.19.6
|
||||||
|
cryptography>=43.0.0
|
||||||
|
PyJWT>=2.10.1
|
||||||
98
microservices/build.sh
Executable file
98
microservices/build.sh
Executable file
@ -0,0 +1,98 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# --- Settings
|
||||||
|
RegistryService=cloud21.cvtt.vpn:5500
|
||||||
|
ValidImages=(md_gateway oe_gateway ac_gateway pricer coordinator)
|
||||||
|
BashFunctionCode=$(realpath $(dirname ${0}))/../dckr_bld_functions.sh
|
||||||
|
# --- Settings
|
||||||
|
|
||||||
|
usage() {
|
||||||
|
echo "Usage: $0 -I <image_name> -V <image_version> -L <library>:<library_version>"
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
# ---------------- cmdline
|
||||||
|
while getopts "I:V:L:" opt; do
|
||||||
|
case ${opt} in
|
||||||
|
I )
|
||||||
|
ImageName=$OPTARG
|
||||||
|
;;
|
||||||
|
V )
|
||||||
|
ImageVersion=$OPTARG
|
||||||
|
;;
|
||||||
|
L )
|
||||||
|
Library=$OPTARG
|
||||||
|
;;
|
||||||
|
\? )
|
||||||
|
echo "Invalid option: -$OPTARG" >&2
|
||||||
|
usage
|
||||||
|
;;
|
||||||
|
: )
|
||||||
|
echo "Option -$OPTARG requires an argument." >&2
|
||||||
|
usage
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
# ---------------- cmdline
|
||||||
|
|
||||||
|
if [ "${ImageName}" == "" ]
|
||||||
|
then
|
||||||
|
usage
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "${ImageVersion}" == "" ]
|
||||||
|
then
|
||||||
|
usage
|
||||||
|
fi
|
||||||
|
|
||||||
|
Project=
|
||||||
|
ProjectVersion=
|
||||||
|
if [ "${Library}" != "" ] ; then
|
||||||
|
IFS=':' read -ra parts <<< "${Library}"
|
||||||
|
Project=${parts[0]}
|
||||||
|
ProjectVersion=${parts[1]}
|
||||||
|
fi
|
||||||
|
# exit
|
||||||
|
|
||||||
|
build_musvc_image() {
|
||||||
|
ImageName=${1}
|
||||||
|
Project=${2}
|
||||||
|
ProjectVersion=${3}
|
||||||
|
|
||||||
|
DockerDir=$(realpath $(dirname ${0})/${ImageName})
|
||||||
|
cd ${DockerDir}
|
||||||
|
|
||||||
|
if [ "${Project}" != "" ]; then
|
||||||
|
get_project_version ${Project} ${ProjectVersion}
|
||||||
|
fi
|
||||||
|
|
||||||
|
function cleanup {
|
||||||
|
cd ${DockerDir}
|
||||||
|
rm -rf cvttpy
|
||||||
|
}
|
||||||
|
trap cleanup RETURN
|
||||||
|
|
||||||
|
build_docker_image ${ImageName} ${RegistryService} ${ImageVersion} ${Project} ${ProjectVersion}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
source ${BashFunctionCode}
|
||||||
|
if [ "${ImageName}" == "__ALL__" ]; then
|
||||||
|
Images=(${ValidImages[@]})
|
||||||
|
else
|
||||||
|
if [[ " ${ValidImages[*]} " == *" ${ImageName}"* ]]; then
|
||||||
|
Images=(${ImageName})
|
||||||
|
else
|
||||||
|
echo "ERROR: invalid image name \"${ImageName}\""
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
for ImageName in "${Images[@]}"; do
|
||||||
|
build_musvc_image ${ImageName} ${Project} ${ProjectVersion}
|
||||||
|
done
|
||||||
|
|
||||||
|
# echo "**** D E B U G E X I T" && exit
|
||||||
|
echo "***** ${0} D O N E"
|
||||||
|
|
||||||
|
|
||||||
3
microservices/coordinator/.dockerignore
Normal file
3
microservices/coordinator/.dockerignore
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
.git
|
||||||
|
**/__pycache__
|
||||||
|
.pipenv
|
||||||
19
microservices/coordinator/Dockerfile
Normal file
19
microservices/coordinator/Dockerfile
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
FROM python:3.12-slim
|
||||||
|
|
||||||
|
COPY requirements.txt /
|
||||||
|
|
||||||
|
RUN pip install --upgrade pip --root-user-action=ignore
|
||||||
|
RUN pip install -r /requirements.txt --root-user-action=ignore
|
||||||
|
|
||||||
|
COPY cvttpy /cvttpy
|
||||||
|
|
||||||
|
RUN mkdir -p /logs /config
|
||||||
|
|
||||||
|
SHELL ["/bin/bash", "-c"]
|
||||||
|
|
||||||
|
ENV PYTHONPATH=/
|
||||||
|
|
||||||
|
COPY entrypoint.sh /entrypoint.sh
|
||||||
|
RUN chmod +x /entrypoint.sh
|
||||||
|
|
||||||
|
ENTRYPOINT ["/entrypoint.sh"]
|
||||||
14
microservices/coordinator/entrypoint.sh
Executable file
14
microservices/coordinator/entrypoint.sh
Executable file
@ -0,0 +1,14 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
LogDir=/logs
|
||||||
|
|
||||||
|
Cmd="python3.12"
|
||||||
|
Cmd+=" cvttpy/apps/microservices/coordinator/coordinator.py"
|
||||||
|
|
||||||
|
Cmd+=" --config=${CONFIG_FILE:-/config/cvtt_musvc.cfg}"
|
||||||
|
|
||||||
|
Cmd+=" --log_file=${LogDir}/${COORD_LOG_FILE:-%T.coordinator.log}"
|
||||||
|
Cmd+=" ${COORD_ADD_ARGS}"
|
||||||
|
echo ${Cmd}
|
||||||
|
exec ${Cmd}
|
||||||
|
|
||||||
9
microservices/coordinator/requirements.txt
Normal file
9
microservices/coordinator/requirements.txt
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
aiohttp>=3.7.4.post0
|
||||||
|
nest-asyncio>=1.5.5
|
||||||
|
hjson>=3.1.0
|
||||||
|
sortedcontainers>=2.4.0
|
||||||
|
redis>=5.0.8
|
||||||
|
python-dateutil>=2.8.2
|
||||||
|
types-python-dateutil>=2.8.19.6
|
||||||
|
cryptography>=43.0.0
|
||||||
|
PyJWT>=2.10.1
|
||||||
102
microservices/docker-compose.yml
Normal file
102
microservices/docker-compose.yml
Normal file
@ -0,0 +1,102 @@
|
|||||||
|
# CVTT Microservices
|
||||||
|
services:
|
||||||
|
coordinator:
|
||||||
|
image: cloud21.cvtt.vpn:5500/coordinator:${CVTT_VERSION}
|
||||||
|
container_name: cvtt-coordinator
|
||||||
|
pull_policy: always
|
||||||
|
user: ${CVTT_USER:-1001:1001}
|
||||||
|
environment:
|
||||||
|
CONFIG_SERVICE: ${CONFIG_SERVICE:-cloud16.cvtt.vpn:6789}
|
||||||
|
CONFIG_COMM_SETTINGS: ${CONFIG_COMM_SETTINGS:-comm/pubsub/redis/docker_microservices}
|
||||||
|
CONFIG_FILE: ${CONFIG_FILE:-cvtt_musvc.cfg}
|
||||||
|
COORD_LOG_FILE: ${COORD_LOG_FILE:-%T.coordinator.log}
|
||||||
|
COORD_ADD_ARGS: ${COORD_ADD_ARGS:-}
|
||||||
|
volumes:
|
||||||
|
- ./config:/config
|
||||||
|
- ./logs:/logs
|
||||||
|
depends_on:
|
||||||
|
- pricer
|
||||||
|
# - quant
|
||||||
|
# - trader
|
||||||
|
# - riskmgr
|
||||||
|
- redis
|
||||||
|
|
||||||
|
pricer:
|
||||||
|
image: cloud21.cvtt.vpn:5500/pricer:${CVTT_VERSION}
|
||||||
|
container_name: cvtt-pricer
|
||||||
|
pull_policy: always
|
||||||
|
user: ${CVTT_USER:-1001:1001}
|
||||||
|
environment:
|
||||||
|
CONFIG_SERVICE: ${CONFIG_SERVICE:-cloud16.cvtt.vpn:6789}
|
||||||
|
CONFIG_COMM_SETTINGS: ${CONFIG_COMM_SETTINGS:-comm/pubsub/redis/docker_microservices}
|
||||||
|
CONFIG_FILE: ${CONFIG_FILE:-http://${CONFIG_SERVICE}/apps/cvtt_musvc}
|
||||||
|
COORD_LOG_FILE: ${COORD_LOG_FILE:-%T.pricer.log}
|
||||||
|
COORD_ADD_ARGS: ${COORD_ADD_ARGS:-}
|
||||||
|
volumes:
|
||||||
|
- ./config:/config
|
||||||
|
- ./logs:/logs
|
||||||
|
depends_on:
|
||||||
|
- md_gateway
|
||||||
|
- redis
|
||||||
|
|
||||||
|
md_gateway:
|
||||||
|
image: cloud21.cvtt.vpn:5500/md_gateway:${CVTT_VERSION}
|
||||||
|
container_name: md_gateway
|
||||||
|
pull_policy: always
|
||||||
|
user: ${CVTT_USER:-1001:1001}
|
||||||
|
environment:
|
||||||
|
CONFIG_SERVICE: ${CONFIG_SERVICE:-cloud16.cvtt.vpn:6789}
|
||||||
|
CONFIG_COMM_SETTINGS: ${CONFIG_COMM_SETTINGS:-comm/pubsub/redis/docker_microservices}
|
||||||
|
CONFIG_FILE: ${CONFIG_FILE:-http://${CONFIG_SERVICE}/apps/cvtt_musvc}
|
||||||
|
MDGW_CREDS_FILE: ${MDGW_CREDS_FILE:-/config/.creds}
|
||||||
|
MDGW_LOG_FILE: ${MDGW_LOG_FILE:-%T.md_gateway.log}
|
||||||
|
MDGW_ADD_ARGS: ${MDGW_ADD_ARGS:-}
|
||||||
|
volumes:
|
||||||
|
- ./config:/config
|
||||||
|
- ./logs:/logs
|
||||||
|
depends_on:
|
||||||
|
- redis
|
||||||
|
|
||||||
|
oe_gateway:
|
||||||
|
image: cloud21.cvtt.vpn:5500/oe_gateway:${CVTT_VERSION}
|
||||||
|
container_name: oe_gateway
|
||||||
|
pull_policy: always
|
||||||
|
user: ${CVTT_USER:-1001:1001}
|
||||||
|
environment:
|
||||||
|
CONFIG_SERVICE: ${CONFIG_SERVICE:-cloud16.cvtt.vpn:6789}
|
||||||
|
CONFIG_COMM_SETTINGS: ${CONFIG_COMM_SETTINGS:-comm/pubsub/redis/docker_microservices}
|
||||||
|
CONFIG_FILE: ${CONFIG_FILE:-http://${CONFIG_SERVICE}/apps/cvtt_musvc}
|
||||||
|
OEGW_CREDS_FILE: ${OEGW_CREDS_FILE:-/config/.creds}
|
||||||
|
OEGW_LOG_FILE: ${OEGW_LOG_FILE:-%T.oe_gateway.log}
|
||||||
|
OEGW_ADD_ARGS: ${OEGW_ADD_ARGS:-}
|
||||||
|
volumes:
|
||||||
|
- ./config:/config
|
||||||
|
- ./logs:/logs
|
||||||
|
depends_on:
|
||||||
|
- redis
|
||||||
|
|
||||||
|
ac_gateway:
|
||||||
|
image: cloud21.cvtt.vpn:5500/ac_gateway:${CVTT_VERSION}
|
||||||
|
container_name: ac_gateway
|
||||||
|
pull_policy: always
|
||||||
|
user: ${CVTT_USER:-1001:1001}
|
||||||
|
environment:
|
||||||
|
CONFIG_SERVICE: ${CONFIG_SERVICE:-cloud16.cvtt.vpn:6789}
|
||||||
|
CONFIG_COMM_SETTINGS: ${CONFIG_COMM_SETTINGS:-comm/pubsub/redis/docker_microservices}
|
||||||
|
CONFIG_FILE: ${CONFIG_FILE:-http://${CONFIG_SERVICE}/apps/cvtt_musvc}
|
||||||
|
ACGW_CREDS_FILE: ${ACGW_CREDS_FILE:-/config/.creds}
|
||||||
|
ACGW_LOG_FILE: ${ACGW_LOG_FILE:-%T.ac_gateway.log}
|
||||||
|
ACGW_ADD_ARGS: ${ACGW_ADD_ARGS:-}
|
||||||
|
volumes:
|
||||||
|
- ./config:/config
|
||||||
|
- ./logs:/logs
|
||||||
|
depends_on:
|
||||||
|
- redis
|
||||||
|
|
||||||
|
redis:
|
||||||
|
image: redis:latest
|
||||||
|
container_name: redis-cvtt
|
||||||
|
ports:
|
||||||
|
- "16379:6379"
|
||||||
|
volumes:
|
||||||
|
- ./data/redis:/data
|
||||||
3
microservices/md_gateway/.dockerignore
Normal file
3
microservices/md_gateway/.dockerignore
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
.git
|
||||||
|
**/__pycache__
|
||||||
|
.pipenv
|
||||||
19
microservices/md_gateway/Dockerfile
Normal file
19
microservices/md_gateway/Dockerfile
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
FROM python:3.12-slim
|
||||||
|
|
||||||
|
COPY requirements.txt /
|
||||||
|
|
||||||
|
RUN pip install --upgrade pip --root-user-action=ignore
|
||||||
|
RUN pip install -r /requirements.txt --root-user-action=ignore
|
||||||
|
|
||||||
|
COPY cvttpy /cvttpy
|
||||||
|
|
||||||
|
RUN mkdir -p /logs /config
|
||||||
|
|
||||||
|
SHELL ["/bin/bash", "-c"]
|
||||||
|
|
||||||
|
ENV PYTHONPATH=/
|
||||||
|
|
||||||
|
COPY entrypoint.sh /entrypoint.sh
|
||||||
|
RUN chmod +x /entrypoint.sh
|
||||||
|
|
||||||
|
ENTRYPOINT ["/entrypoint.sh"]
|
||||||
15
microservices/md_gateway/entrypoint.sh
Executable file
15
microservices/md_gateway/entrypoint.sh
Executable file
@ -0,0 +1,15 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
LogDir=/logs
|
||||||
|
|
||||||
|
Cmd="python3.12"
|
||||||
|
Cmd+=" cvttpy/apps/microservices/market_gateways/md_gateway.py"
|
||||||
|
|
||||||
|
Cmd+=" --config=${CONFIG_FILE:-/config/cvtt_musvc.cfg}"
|
||||||
|
Cmd+=" --credentials_file=${MDGW_CREDS_FILE:-/config/.creds}"
|
||||||
|
|
||||||
|
Cmd+=" --log_file=${LogDir}/${MDGW_LOG_FILE:-%T.md_gateway.log}"
|
||||||
|
Cmd+=" ${MDGW_ADD_ARGS}"
|
||||||
|
echo ${Cmd}
|
||||||
|
exec ${Cmd}
|
||||||
|
|
||||||
9
microservices/md_gateway/requirements.txt
Normal file
9
microservices/md_gateway/requirements.txt
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
aiohttp>=3.7.4.post0
|
||||||
|
nest-asyncio>=1.5.5
|
||||||
|
hjson>=3.1.0
|
||||||
|
sortedcontainers>=2.4.0
|
||||||
|
redis>=5.0.8
|
||||||
|
python-dateutil>=2.8.2
|
||||||
|
types-python-dateutil>=2.8.19.6
|
||||||
|
cryptography>=43.0.0
|
||||||
|
PyJWT>=2.10.1
|
||||||
3
microservices/oe_gateway/.dockerignore
Normal file
3
microservices/oe_gateway/.dockerignore
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
.git
|
||||||
|
**/__pycache__
|
||||||
|
.pipenv
|
||||||
19
microservices/oe_gateway/Dockerfile
Normal file
19
microservices/oe_gateway/Dockerfile
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
FROM python:3.12-slim
|
||||||
|
|
||||||
|
COPY requirements.txt /
|
||||||
|
|
||||||
|
RUN pip install --upgrade pip --root-user-action=ignore
|
||||||
|
RUN pip install -r /requirements.txt --root-user-action=ignore
|
||||||
|
|
||||||
|
COPY cvttpy /cvttpy
|
||||||
|
|
||||||
|
RUN mkdir -p /logs /config
|
||||||
|
|
||||||
|
SHELL ["/bin/bash", "-c"]
|
||||||
|
|
||||||
|
ENV PYTHONPATH=/
|
||||||
|
|
||||||
|
COPY entrypoint.sh /entrypoint.sh
|
||||||
|
RUN chmod +x /entrypoint.sh
|
||||||
|
|
||||||
|
ENTRYPOINT ["/entrypoint.sh"]
|
||||||
15
microservices/oe_gateway/entrypoint.sh
Executable file
15
microservices/oe_gateway/entrypoint.sh
Executable file
@ -0,0 +1,15 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
LogDir=/logs
|
||||||
|
|
||||||
|
Cmd="python3.12"
|
||||||
|
Cmd+=" cvttpy/apps/microservices/market_gateways/order_entry_gateway.py"
|
||||||
|
|
||||||
|
Cmd+=" --config=${CONFIG_FILE:-/config/cvtt_musvc.cfg}"
|
||||||
|
Cmd+=" --credentials_file=${OEGW_CREDS_FILE:-/config/.creds}"
|
||||||
|
|
||||||
|
Cmd+=" --log_file=${LogDir}/${OEGW_LOG_FILE:-%T.oe_gateway.log}"
|
||||||
|
Cmd+=" ${OEGW_ADD_ARGS}"
|
||||||
|
echo ${Cmd}
|
||||||
|
exec ${Cmd}
|
||||||
|
|
||||||
11
microservices/oe_gateway/requirements.txt
Normal file
11
microservices/oe_gateway/requirements.txt
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
aiohttp>=3.7.4.post0
|
||||||
|
nest-asyncio>=1.5.5
|
||||||
|
hjson>=3.1.0
|
||||||
|
sortedcontainers>=2.4.0
|
||||||
|
redis>=5.0.8
|
||||||
|
python-dateutil>=2.8.2
|
||||||
|
types-python-dateutil>=2.8.19.6
|
||||||
|
cryptography>=43.0.0
|
||||||
|
PyJWT>=2.10.1
|
||||||
|
|
||||||
|
|
||||||
3
microservices/pricer/.dockerignore
Normal file
3
microservices/pricer/.dockerignore
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
.git
|
||||||
|
**/__pycache__
|
||||||
|
.pipenv
|
||||||
19
microservices/pricer/Dockerfile
Normal file
19
microservices/pricer/Dockerfile
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
FROM python:3.12-slim
|
||||||
|
|
||||||
|
COPY requirements.txt /
|
||||||
|
|
||||||
|
RUN pip install --upgrade pip --root-user-action=ignore
|
||||||
|
RUN pip install -r /requirements.txt --root-user-action=ignore
|
||||||
|
|
||||||
|
COPY cvttpy /cvttpy
|
||||||
|
|
||||||
|
RUN mkdir -p /logs /config
|
||||||
|
|
||||||
|
SHELL ["/bin/bash", "-c"]
|
||||||
|
|
||||||
|
ENV PYTHONPATH=/
|
||||||
|
|
||||||
|
COPY entrypoint.sh /entrypoint.sh
|
||||||
|
RUN chmod +x /entrypoint.sh
|
||||||
|
|
||||||
|
ENTRYPOINT ["/entrypoint.sh"]
|
||||||
14
microservices/pricer/entrypoint.sh
Executable file
14
microservices/pricer/entrypoint.sh
Executable file
@ -0,0 +1,14 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
LogDir=/logs
|
||||||
|
|
||||||
|
Cmd="python3.12"
|
||||||
|
Cmd+=" cvttpy/apps/microservices/pricer/pricer.py"
|
||||||
|
|
||||||
|
Cmd+=" --config=${CONFIG_FILE:-/config/cvtt_musvc.cfg}"
|
||||||
|
Cmd+=" --log_file=${LogDir}/${PXER_LOG_FILE:-%T.pricer.log}"
|
||||||
|
|
||||||
|
Cmd+=" ${PXER_ADD_ARGS}"
|
||||||
|
echo ${Cmd}
|
||||||
|
exec ${Cmd}
|
||||||
|
|
||||||
9
microservices/pricer/requirements.txt
Normal file
9
microservices/pricer/requirements.txt
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
aiohttp>=3.7.4.post0
|
||||||
|
nest-asyncio>=1.5.5
|
||||||
|
hjson>=3.1.0
|
||||||
|
sortedcontainers>=2.4.0
|
||||||
|
redis>=5.0.8
|
||||||
|
python-dateutil>=2.8.2
|
||||||
|
types-python-dateutil>=2.8.19.6
|
||||||
|
cryptography>=43.0.0
|
||||||
|
PyJWT>=2.10.1
|
||||||
21
test/rsync_test/Dockerfile
Normal file
21
test/rsync_test/Dockerfile
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
FROM python:3.12-slim
|
||||||
|
|
||||||
|
ARG FROM_DIR=docker_dev/test/rsync_test
|
||||||
|
|
||||||
|
COPY ${FROM_DIR}/test.sh /test.sh
|
||||||
|
|
||||||
|
RUN apt-get update && apt-get install -y rsync openssh-client
|
||||||
|
|
||||||
|
COPY docker_dev/shared/id_rsa /root/.ssh/id_rsa
|
||||||
|
COPY docker_dev/shared/id_rsa.pub /root/.ssh/id_rsa.pub
|
||||||
|
|
||||||
|
RUN chmod 600 /root/.ssh/id_rsa /root/.ssh/id_rsa.pub
|
||||||
|
|
||||||
|
# Shared Volumes
|
||||||
|
RUN chmod +x /test.sh
|
||||||
|
|
||||||
|
WORKDIR /
|
||||||
|
SHELL ["/bin/bash", "-c"]
|
||||||
|
ENV PYTHONPATH=/
|
||||||
|
ENTRYPOINT [ "/test.sh" ]
|
||||||
|
|
||||||
19
test/rsync_test/test.sh
Executable file
19
test/rsync_test/test.sh
Executable file
@ -0,0 +1,19 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
date > /testfile.txt
|
||||||
|
|
||||||
|
Source=/testfile.txt
|
||||||
|
Targets=
|
||||||
|
Targets="${Targets} cvtt@cloud21.cvtt.vpn:/tmp/"
|
||||||
|
Targets="${Targets} cvtt@hs01.cvtt.vpn:/tmp/"
|
||||||
|
|
||||||
|
|
||||||
|
for tgt in ${Targets}
|
||||||
|
do
|
||||||
|
Cmd="/usr/bin/rsync -ahv"
|
||||||
|
Cmd+=" -e 'ssh -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null'"
|
||||||
|
Cmd+=" ${Source} ${tgt}"
|
||||||
|
echo $Cmd
|
||||||
|
eval $Cmd
|
||||||
|
done
|
||||||
|
|
||||||
Loading…
x
Reference in New Issue
Block a user