SEK是Spring Boot+Elasticsearch+Kibana的简称,前期我们学习了这三个技术的基础知识,那么接下来将介绍如何将这几个技术应用到实际项目中去。既然是买卖方向成交量分析,那必定先要获取这方面的数据,本次通过采集某区块链交易平台的公开资产的交易信息(ETH/USDT),来做买卖方向的成交量的分析,从而以实际项目,巩固我们学到的相关知识,加深对知识的理解。
本次实战项目最终的效果如下图所示:
横坐标是时间,纵坐标是交易量,红线代表每分钟的卖出量,绿线代表每分钟的买入量,通过图形化的展示,能更好的把控交易的走势。
本次项目的整体流程如下图所示:
前期准备工作
1、Spring Boot V2.7.4 项目初始化完成
2、Elasticsearch 8.4.2 安装完毕
3、kibana 8.4.2 安装完毕
开始编写代码
目前某交易平台开对外公开了交易数据,可以通过WS方式获取,因此需要在项目中引入WS相关的依赖
<!-- https://mvnrepository.com/artifact/org.java-websocket/Java-WebSocket -->
<dependency>
<groupId>org.java-websocket</groupId>
<artifactId>Java-WebSocket</artifactId>
<version>1.5.3</version>
</dependency>
<!-- https://mvnrepository.com/artifact/com.alibaba/fastjson -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>2.0.14</version>
</dependency>
本次通过Java-WebSocket来建立跟某交易平台的连接,实时获取最新的交易数据,关键代码如下
package com.htkj.aiarb.conf.ws;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import com.htkj.aiarb.dto.ws.WsReceiveMsgDTO;
import org.apache.commons.codec.binary.StringUtils;
import org.java_websocket.client.WebSocketClient;
import org.java_websocket.handshake.ServerHandshake;
import java.net.URI;
public class DemoWebSocketClient extends WebSocketClient {
public DemoWebSocketClient(URI serverUri){
super(serverUri);
}
@Override
public void onOpen(ServerHandshake serverHandshake) {
log.info("Open connection success!");
}
@Override
public void onMessage(String s) {
try{
WsReceiveMsgDTO<JSONObject> wsReceiveMsgDTO = JSON.parseObject(message,WsReceiveMsgDTO.class);
if(!StringUtils.equals(wsReceiveMsgDTO.getEvent(),"update")){
log.info("Receive message success {}",message);
return;
}
tradeBiz.processMessage(wsReceiveMsgDTO.getResult().toJSONString());
}catch (Exception e){
log.error("On message error",e);
}
}
@Override
public void onClose(int i, String s, boolean b) {
log.info("Connection closed normally!");
}
@Override
public void onError(Exception e) {
log.error("Ws conn is closed because of occur error",e);
}
}
WS连接配置代码如下:
@Bean
public BaseWebSocketClient gateSpotAndMarginWsc(){
BaseWebSocketClient webSocketClient = null;
try{
webSocketClient = new BaseWebSocketClient(new URI(spotAndMarginUrl));
webSocketClient.connect();
}catch (Exception e){
log.error("Failed to init gateSpotAndMarginWsc",e);
}
return webSocketClient;
}
通过tradeBiz处理收到的交易信息,关键代码如下:
@Override
public void processMessage(String tradeMsg){
try {
IndexRequest<JsonData> request = IndexRequest.of(i -> i
.index("idx_trade_all")
.document(JsonData.fromJson(tradeMsg))
);
elasticsearchClient.index(request);
} catch (IOException e) {
log.error("Failed to create {}",tradeMsg,e);
}
}
写入ES的配置在之前的文章中已经介绍过了,这里不在展示。代码编写完成后,启动项目开始接收交易数据,接着会将数据写入到ES。
开始配置Kibana图表
打开Kibana地址,本地的化可以输入(http://127.0.0.1),并点击左侧菜单栏的discover,就可以看到已经有数据了
接下来点击左侧菜单栏的Dashboard菜单项,进入图表配置页面
选择需要展示的字段,已经图形的展示方式(折线形式),至此整个项目已经开发完毕。
如果需要本项目的话可以在评论区留言获得。注意:本项目仅做交流演示,不构成任何投资建议,谢谢!