Trim unnecesary stuff left from marketstore copy, also fix elastic config name for docker build, add elasticsearch to dependencies
parent
0dc24bd475
commit
17a4fe4b2f
|
@ -8,4 +8,4 @@ COPY elasticsearch.yml /usr/share/elasticsearch/config/
|
||||||
|
|
||||||
RUN printf "password" | ./bin/elasticsearch-keystore add -f -x "bootstrap.password"
|
RUN printf "password" | ./bin/elasticsearch-keystore add -f -x "bootstrap.password"
|
||||||
|
|
||||||
EXPOSE 9200
|
EXPOSE 9200
|
||||||
|
|
|
@ -65,49 +65,6 @@ _config = {
|
||||||
'log_level': 'debug',
|
'log_level': 'debug',
|
||||||
}
|
}
|
||||||
|
|
||||||
_yaml_config = '''
|
|
||||||
# piker's ``elasticsearch`` config.
|
|
||||||
|
|
||||||
# mount this config using:
|
|
||||||
# sudo docker run \
|
|
||||||
# -itd \
|
|
||||||
# --rm \
|
|
||||||
# --network=host \
|
|
||||||
# --mount type=bind,source="$(pwd)"/elastic,target=/usr/share/elasticsearch/data \
|
|
||||||
# --env "elastic_username=elastic" \
|
|
||||||
# --env "elastic_password=password" \
|
|
||||||
# --env "xpack.security.enabled=false" \
|
|
||||||
# elastic
|
|
||||||
|
|
||||||
root_directory: data
|
|
||||||
port: {port}
|
|
||||||
log_level: {log_level}
|
|
||||||
queryable: true
|
|
||||||
stop_grace_period: 0
|
|
||||||
wal_rotate_interval: 5
|
|
||||||
stale_threshold: 5
|
|
||||||
enable_add: true
|
|
||||||
enable_remove: false
|
|
||||||
|
|
||||||
triggers:
|
|
||||||
- module: ondiskagg.so
|
|
||||||
on: "*/1Sec/OHLCV"
|
|
||||||
config:
|
|
||||||
# filter: "nasdaq"
|
|
||||||
destinations:
|
|
||||||
- 1Min
|
|
||||||
- 5Min
|
|
||||||
- 15Min
|
|
||||||
- 1H
|
|
||||||
- 1D
|
|
||||||
|
|
||||||
- module: stream.so
|
|
||||||
on: '*/*/*'
|
|
||||||
# config:
|
|
||||||
# filter: "nasdaq"
|
|
||||||
|
|
||||||
'''.format(**_config)
|
|
||||||
|
|
||||||
|
|
||||||
def start_elasticsearch(
|
def start_elasticsearch(
|
||||||
client: docker.DockerClient,
|
client: docker.DockerClient,
|
||||||
|
@ -122,156 +79,30 @@ def start_elasticsearch(
|
||||||
The equivalent cli cmd to this code is:
|
The equivalent cli cmd to this code is:
|
||||||
|
|
||||||
sudo docker run \
|
sudo docker run \
|
||||||
-itd \
|
-itd \
|
||||||
--rm \
|
--rm \
|
||||||
--network=host \
|
--network=host \
|
||||||
--mount type=bind,source="$(pwd)"/elastic,target=/usr/share/elasticsearch/data \
|
--mount type=bind,source="$(pwd)"/elastic,target=/usr/share/elasticsearch/data \
|
||||||
--env "elastic_username=elastic" \
|
--env "elastic_username=elastic" \
|
||||||
--env "elastic_password=password" \
|
--env "elastic_password=password" \
|
||||||
--env "xpack.security.enabled=false" \
|
--env "xpack.security.enabled=false" \
|
||||||
elastic
|
elastic
|
||||||
|
|
||||||
'''
|
'''
|
||||||
import os
|
|
||||||
import docker
|
import docker
|
||||||
from .. import config
|
|
||||||
get_console_log('info', name=__name__)
|
get_console_log('info', name=__name__)
|
||||||
|
|
||||||
esdir = os.path.join(config._config_dir, 'elasticsearch')
|
|
||||||
|
|
||||||
# create dirs when dne
|
|
||||||
if not os.path.isdir(config._config_dir):
|
|
||||||
os.mkdir(config._config_dir)
|
|
||||||
|
|
||||||
if not os.path.isdir(esdir):
|
|
||||||
os.mkdir(esdir)
|
|
||||||
|
|
||||||
yml_file = os.path.join(esdir, 'es.yml')
|
|
||||||
if not os.path.isfile(yml_file):
|
|
||||||
log.warning(
|
|
||||||
f'No `elasticsearch` config exists?: {yml_file}\n'
|
|
||||||
'Generating new file from template:\n'
|
|
||||||
f'{_yaml_config}\n'
|
|
||||||
)
|
|
||||||
with open(yml_file, 'w') as yf:
|
|
||||||
yf.write(_yaml_config)
|
|
||||||
|
|
||||||
# create a mount from user's local piker config dir into container
|
|
||||||
config_dir_mnt = docker.types.Mount(
|
|
||||||
target='/etc',
|
|
||||||
source=esdir,
|
|
||||||
type='bind',
|
|
||||||
)
|
|
||||||
|
|
||||||
# create a user config subdir where the elasticsearch
|
|
||||||
# backing filesystem database can be persisted.
|
|
||||||
persistent_data_dir = os.path.join(
|
|
||||||
esdir, 'data',
|
|
||||||
)
|
|
||||||
if not os.path.isdir(persistent_data_dir):
|
|
||||||
os.mkdir(persistent_data_dir)
|
|
||||||
|
|
||||||
data_dir_mnt = docker.types.Mount(
|
|
||||||
target='/data',
|
|
||||||
source=persistent_data_dir,
|
|
||||||
type='bind',
|
|
||||||
)
|
|
||||||
|
|
||||||
dcntr: DockerContainer = client.containers.run(
|
dcntr: DockerContainer = client.containers.run(
|
||||||
'elastic',
|
'elastic',
|
||||||
ports={
|
network='host',
|
||||||
'9200':9200,
|
|
||||||
},
|
|
||||||
mounts=[
|
|
||||||
config_dir_mnt,
|
|
||||||
data_dir_mnt,
|
|
||||||
],
|
|
||||||
# log_config=log_cf,
|
|
||||||
detach=True,
|
detach=True,
|
||||||
# stop_signal='SIGINT',
|
remove=True,
|
||||||
# init=True,
|
|
||||||
# remove=True,
|
|
||||||
)
|
)
|
||||||
|
|
||||||
return (
|
return (
|
||||||
dcntr,
|
dcntr,
|
||||||
_config,
|
{},
|
||||||
|
|
||||||
# expected startup and stop msgs
|
# expected startup and stop msgs
|
||||||
"launching listener for all services...",
|
"launching listener for all services...",
|
||||||
"exiting...",
|
"exiting...",
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
_tick_tbk_ids: tuple[str, str] = ('1Sec', 'TICK')
|
|
||||||
_tick_tbk: str = '{}/' + '/'.join(_tick_tbk_ids)
|
|
||||||
|
|
||||||
_tick_dt = [
|
|
||||||
# these two are required for as a "primary key"
|
|
||||||
('Epoch', 'i8'),
|
|
||||||
('Nanoseconds', 'i4'),
|
|
||||||
('IsTrade', 'i1'),
|
|
||||||
('IsBid', 'i1'),
|
|
||||||
('Price', 'f4'),
|
|
||||||
('Size', 'f4')
|
|
||||||
]
|
|
||||||
|
|
||||||
_quote_dt = [
|
|
||||||
# these two are required for as a "primary key"
|
|
||||||
('Epoch', 'i8'),
|
|
||||||
('Nanoseconds', 'i4'),
|
|
||||||
|
|
||||||
('Tick', 'i4'), # (-1, 0, 1) = (on bid, same, on ask)
|
|
||||||
# ('fill_time', 'f4'),
|
|
||||||
('Last', 'f4'),
|
|
||||||
('Bid', 'f4'),
|
|
||||||
('Bsize', 'i8'),
|
|
||||||
('Asize', 'i8'),
|
|
||||||
('Ask', 'f4'),
|
|
||||||
('Size', 'i8'),
|
|
||||||
('Volume', 'i8'),
|
|
||||||
# ('brokerd_ts', 'i64'),
|
|
||||||
# ('VWAP', 'f4')
|
|
||||||
]
|
|
||||||
|
|
||||||
_quote_tmp = {}.fromkeys(dict(_quote_dt).keys(), np.nan)
|
|
||||||
_tick_map = {
|
|
||||||
'Up': 1,
|
|
||||||
'Equal': 0,
|
|
||||||
'Down': -1,
|
|
||||||
None: np.nan,
|
|
||||||
}
|
|
||||||
|
|
||||||
_ohlcv_dt = [
|
|
||||||
# these two are required for as a "primary key"
|
|
||||||
('Epoch', 'i8'),
|
|
||||||
# ('Nanoseconds', 'i4'),
|
|
||||||
|
|
||||||
# ohlcv sampling
|
|
||||||
('Open', 'f4'),
|
|
||||||
('High', 'f4'),
|
|
||||||
('Low', 'f4'),
|
|
||||||
('Close', 'f4'),
|
|
||||||
('Volume', 'f4'),
|
|
||||||
]
|
|
||||||
|
|
||||||
|
|
||||||
ohlc_key_map = bidict({
|
|
||||||
'Epoch': 'time',
|
|
||||||
'Open': 'open',
|
|
||||||
'High': 'high',
|
|
||||||
'Low': 'low',
|
|
||||||
'Close': 'close',
|
|
||||||
'Volume': 'volume',
|
|
||||||
})
|
|
||||||
|
|
||||||
# # map of seconds ints to "time frame" accepted keys
|
|
||||||
tf_in_1s = bidict({
|
|
||||||
1: '1Sec',
|
|
||||||
60: '1Min',
|
|
||||||
60*5: '5Min',
|
|
||||||
60*15: '15Min',
|
|
||||||
60*30: '30Min',
|
|
||||||
60*60: '1H',
|
|
||||||
60*60*24: '1D',
|
|
||||||
})
|
|
||||||
|
|
Loading…
Reference in New Issue