このトピックでは、TairSearchを使用して株式のローソク足チャートを生成する方法について説明します。
背景情報
ローソク足チャートは、トレーダーや投資家が株価パターンのテクニカル分析を実行し、可能な価格変動を判断するためによく使用されます。 さらに、ローソク足は株式の基本的かつ中核的な技術指標です。 他の複数の指標は燭台から派生しています。 各ローソク足は、特定の時間枠内の株式の始値、高値、安値、終値を示します。 ローソク足は、多くの場合、30分、日、週、月、または四半期ごとに生成されます。
証券セクターの組織は通常、証券取引所から株価に関するほぼリアルタイムの生データを受け取ります。 次に、このデータを使用して、毎日のローソク足や5分のローソク足などのローソク足を生成します。 投資家やトレーダーは、データの適時性に対する高い要件を持っています。 これは、株式情報供給者が多数のリアルタイムコンピューティングおよびアクセス要求を処理するという大きな課題を提起する。
TairSearchは、メモリ内のフルテキスト検索データ構造で、キャッシュとコンピューティングを統合してリアルタイムのデータ取得を実現します。 これにより、ホットデータキャッシュやリアルタイムコンピューティングでローソク足を生成するのに理想的な選択肢となります。 このトピックでは、TairSearchを使用して株式の3分間のローソク足を生成する方法の例を示します。
例:
株式のスキーマを作成する
この例では、データレコードは3秒ごとに生成されます。 TFT.CREATEINDEX
コマンドを実行して、ストックコードをキーとしてスキーマを作成できます。 スキーマには、high
、low
、open
、close
、amount
、volume
、およびdate
のフィールドが含まれます。 日付
フィールドがインデックスとして指定されます。
TFT.UPDATEINDEX
コマンドを実行します。 サンプルコード:
TFT.CREATEINDEX 58Z074 '{
"mappings": {
"properties": {
"high": {"index": false、"type": "double"} 、
"low": {"index": false、"type": "double"} 、
"open": {"index": false、"type": "double"} 、
"close": {"index": false、"type": "double"} 、
"volume": {"index": false、"type": "long"} 、
"amount": {"index": false、"type": "long"} 、
"date": {"index": true,"type": "long"}
}
}
}'
OK
株式に関するデータのインポート
TairSearchドキュメントにデータを書き込みます。 サンプルコード:
TFT.ADDDOC 58Z074 '{
"high": 1237.53、
"low": 887.54、
"open": 987.36、
"close": 997.53、
"volume": 110、
"amount": 2809、
"date": 1659922202
} '
ローソク足をリアルタイムで生成する
- オープン価格を計算します:
TFT.SEARCH 58Z074 '{ "size": 1, "_source": {"includes": "open"} 、 "sort": [{"date": {"order": "asc"}}] 、 "query": {"range": {"date": {"gte": 1659922200,"lte": 1659922380 }}} } '
- 終値を計算します:
TFT.SEARCH 58Z074 '{ "size": 1, "_source": {"includes": "close"} 、 "sort": [{"date": {"order": "desc"}}] 、 "query": {"range": {"date": {"gte": 1659922200,"lte": 1659922380 }}} } '
- TFT.SEARCH 58Z074 '{高価格と低価格を計算します:
「サイズ」: 0、 "query": {"range": {"date": {"gte": 1659922200、"lte": 1659922380 }}}、 "aggs": {"high": {"max": {"field": "high" }}, "low": {"min": {"field": "low" }}} } '
株式のローソク足チャートを生成する
パフォーマンスデータ
- オープン価格とクローズ価格:
Command:
redis-benchmark -r 1 -n 100000 TFT.SEARCH 58Z074 '{"size": 1、"_source": {"includes": "open"} 、"sort": [{"date": {"order": "asc"}}] 、"query": {"range": {"date": {"gte"): 1659922200、"lte": 1659922380 }}}}'
出力:
100.00% <= 5ミリ秒 12078.75リクエスト /秒
- 高価格と低価格:
Command:
redis-benchmark -r 1 -n 100000 TFT.SEARCH 58Z074 '{"size": 0,"query": {"range": {"date": {"gte": 1659922200,"lte": 1659922380 }}}, "aggs": {"high": {"field" high "}}," low ": " {min "" {"field": "low" }}}}'
出力:
100.00% <= 2ミリ秒 65019.51リクエスト /秒