Giter Site home page Giter Site logo

ztuoexchange_framework's Introduction

ZTuo 开源数字货币交易系统

本源码仅限于交流学习,凡涉及到法律问题与本人无关

=====================================


捐赠:

您的捐赠是我们开源最大的动力

  • BTC/USDT(比特币/USDT):1Dwwqhw9pV9iSSQwuJc8nAygda7XfahaoW
  • ETH/USDT(以太坊/USDT):0x4f1ea0f10aa99f608f31f70b4d3119f6928693ed
  • LTC(莱特币):LXr4TMtDhCSpdAo98vg2sbvX3UXDVPQvMa

ZTuo是一个免费的、开源的数字货币交易系统,她使用目前最流行的Java框架和相关技术开发而成。

愿景

我们的使命是用Java开发世界上最好的、高性能的、安全的、开源的(重点)数字货币交易系统。(请忽略我们的牛逼,因为牛逼吹得多了,可能慢慢就真的牛逼了)

我们希望通过开源社区的力量能相互交流,共同改进。

非常感谢您的帮助(issue  or money。好吧,more money!),请随时提交请求或公开问题。

警告(自行脑补FBI warning 画面)

  1. 运营一家交易所是非常不容易的.

    Ztuo 框架可以使你很容易的建立一套数字货币交易系统,但是,她远远比搭建一个网站要难的多得多.不要以为简单的就是点击下一步,下一步即可完成。整个体系架构分为了很多的组件,需要专业的知识或者团队才能运行成功,好在有我们,可以随时联系我们。

  2. 系统安全知识.

    Ztuo 框架不能保护你的数字资产安全,也不能保证你的系统运行安全。在部署过程中,需要注意网络安全的设置,如果你不在行的话,可以找一个专业的运维人员。

  3. 法律风险

  • 法律风险第一条:不要触犯中华人民共和国的法律条例。
  • 技术无罪,请在法律范围内使用Ztuo框架。
  • 如果你想使用Ztuo作为商业应用,最好请个律师,确保你的商业应用在法律允许的范围内。一切用于商业化项目所带来的法律和经济问题,ztuo团队概不负责。
  1. 你需要知道的基本知识
  • 法律知识(安全第一条,法律最重要)
  • Java知识(主要是spring)
  • linux知识(CentOS、Ubuntu等等)
  • 安全知识

主要技术

  • 后端:Spring、SpringMVC、SpringData、SpringCloud、SpringBoot
  • 数据库:Mysql、Mongodb
  • 其他:redis、kafka、阿里云OSS、腾讯防水校验、环信推送
  • 前端:Vue、iView、less
  • 同时提供IOS和Android版本。

项目资源

测试环境

  • 测试环境仅供学习参考!!!请各位学习的小伙伴合理运用。

  • 测试环境地址 : 一年十几万的费用实在是扛不住了,请小伙伴们耐心等待我们本地的测试地址

加入我们

为方便大家交流和学习,请各位小伙伴加入QQ交流群:
*区块链交易所技术知识交流群【QQ群:735446452】

开源许可协议

Apache

整体架构

Topology-Image

逻辑架构

Topology-Image

部署架构

Topology-Image

依赖关系

Topology-Image

模块介绍

  1. cloud
  • 提供SpringCloud微服务注册中心功能,为基础模块,必须部署
  • 依赖服务:无
  1. ucenter-api
  • 提供用户相关的接口(如登录、注册、资产列表),该模块为基础为基础模块,必须部署
  • 依赖服务:mysql,kafka,redis,mongodb,短信接口,邮箱账号
  1. otc-api
  • 提供场外交易功能接口,没有场外交易的可以不部署
  • 依赖服务:mysql,redis,mongodb,短信接口
  1. exchange-api
  • 提供币币交易接口,没有币币交易的项目可以不部署
  • 依赖服务:mysql,redis,mongodb,kafka
  1. chat
  • 提供实时通讯接口,基础模块,需要部署
  • 依赖服务:mysql,redis,mongodb
  1. admin
  • 提供管理后台的所有服务接口,必须部署
  • 依赖服务:mysql,redis,mongodb
  1. wallet
  • 提供充币、提币、获取地址等钱包服务,为基础模块,必须部署
  • 依赖服务:mysql,mongodb,kafka,cloud
  1. market
  • 提供币种价格、k线、实时成交等接口服务,场外交易不需要部署
  • 依赖服务:mysql,redis,mongodb,kafka,cloud
  1. exchange
  • 提供撮合交易服务,场外交易不需要部署
  • 依赖服务:mysql,mongodb,kafka

重点业务介绍

后端框架的核心模块为 exchange,market模块。

其中exhcnge模块完全采用Java内存处理队列,大大加快处理逻辑,中间不牵涉数据库操作,保证处理速度快,其中项目启动后采用继承ApplicationListener方式,自动运行;

启动后自动加载未处理的订单,重新加载到JVM中,从而保证数据的准确,exchange将订单处理后,将成交记录发送到market;

market模块主要都是数据库操作,将用户变化信息持久化到数据库中。主要难点在于和前端交互socket推送,socket推送采用两种方式,web端socket采用SpringSocket,移动端采用Netty推送,其中netty推送通过定时任务处理。

环境搭建

  • Centos 6.8
  • MySQL 5.5.16
  • Redis-x64-3.2.100
  • Mongodb 3.6.13
  • kafka_2.11-2.2.1
  • nginx-1.16.0
  • JRE 8u241
  • JDK 1.8
  • Vue
  • Zookeeper

生产环境建议配置

Topology-Image

服务部署准备

  1. 项目用了Lombok插件,无论用什么IDE工具,请务必先安装Lombok插件
  2. 项目用了QueryDsl,如果遇见以Q开头的类找不到,请先编译一下对应的core模块,例如core、exchange-core、xxx-core这种模块
  3. 找不到的jar包在项目jar文件夹下
  4. jdk版本1.8以上
  5. 初始化sql在sql文件夹中配置文件 配置文件打开这个设置会自动建表 #jpa spring.jpa.hibernate.ddl-auto=update

修改服务配置文件

请根据服务实际部署情况修改以下配置。配置文件位置如下,如果配置文件中没有某一项配置,说明该模块未使用到该项功能,无需添加:

各个模块/src/main/resources/dev/application.properties

mysql数据库:

spring.datasource.**

reids

redis.**

mongodb(主要存储K线图相关数据)

spring.data.mongodb.uri

kafka

spring.kafka.bootstrap-servers

阿里云OSS,图片资源上传

aliyun.**

短信配置

sms.**

邮件认证

spring.mail.**

腾讯防水校验

water.proof.app.**

服务启动

  1. maven构建打包服务

  2. 将各个模块target文件夹下的XX.jar上传到自己的服务器

  3. 先启动cloud模块,再启动market,exchange模块,剩下的没有顺序。

  4. 启动服务

    例:

    nohup  java  -jar  /自己的jar包路径/cloud.jar  >/dev/null 2>&1 &
    
    nohup  java  -jar  /web/app/cloud.jar  >/dev/null 2>&1 &
    nohup  java  -jar  /web/app/exchange.jar  >/dev/null 2>&1 &
    nohup  java  -jar  /web/app/market.jar  >/dev/null 2>&1 &
    nohup  java  -jar  /web/app/exchange-api.jar  >/dev/null 2>&1 &
    nohup  java  -jar  /web/app/ucenter-api.jar  >/dev/null 2>&1 &
    nohup  java  -jar  /web/app/otc-api.jar  >/dev/null 2>&1 & 
    nohup  java  -jar  /web/app/chat.jar  >/dev/null 2>&1 & 
    nohup  java  -jar  /web/app/wallet.jar  >/dev/null 2>&1 & 
    nohup  java  -jar  /web/app/admin.jar  >/dev/null 2>&1 &
    

提问和建议

  • 使用Issuse,我们会及时跟进解答。
  • 加入交流群:区块链交易所技术知识交流群【QQ群:735446452】
  • E-mail:[email protected]

更新说明

ztuoexchange_framework's People

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar

ztuoexchange_framework's Issues

缺少实体类

缺少很多实体类
cn.ztuo.bitrade.entity.QMemberWallet;
cn.ztuo.bitrade.entity.QMember;

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.