美文网首页区块链/数字货币交易所技术
基于Java开发的开源比特币交易所 | BTC交易所 | ETH

基于Java开发的开源比特币交易所 | BTC交易所 | ETH

作者: 爱吃咸鹅 | 来源:发表于2020-03-23 16:06 被阅读0次

    crypto-exchange

    介绍

    基于Java开发的比特币交易所 | BTC交易所 | ETH交易所 | 数字货币交易所 | 交易平台 | 撮合交易引擎。本项目基于SpringCloud微服务开发,可用来搭建和二次开发数字货币交易所,有完整的撮合交易引擎源码、后台管理(后端+前端)、前台(交易页面、活动页面、个人中心等)、安卓APP源码、苹果APP源码、币种钱包RPC源码。

    Gitee:https://gitee.com/cexchange/CoinExchange

    系统架构概要

    系统运行环境

    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

    文件目录说明

    00_framework

    └─———admin 后台管理API

    └─———bitrade-job 任务管理

    └─———chat OTC聊天

    └─———cloud SpringCloud微服务管理

    └─———core 核心

    └─———exchange 撮合交易引擎

    └─———exchange-api 撮合交易API

    └─———exchange-core 撮合交易核心

    └─———jar 第三方类库

    └─———market 市场行情API、K线生成

    └─———otc-api OTC交易API

    └─———otc-core OTC核心

    └─———sql SQL脚本

    └─———ucenter-api 用户个人中心API

    └─———wallet 钱包资产管理,负责与RPC对接

    01_wallet_rpc

    └─———act

    └─———bch

    └─———bitcoin

    └─———bsv

    └─———btm

    └─———ect

    └─———eos

    └─———erc-eusdt

    └─———erc-token

    └─———eth

    └─———eth-support

    └─———lib

    └─———ltc

    └─———rpc-common

    └─———usdt

    └─———xmr

    02_App_Android

    03_App_IOS

    04_Web_Admin

    05_Web_Front

    使用教程

    准备mysql数据库,创建名称为“xxxx”的数据库

    准备redis缓存数据库

    准备kafka流式处理环境(先配置运行zookper,接着配置运行kafka)

    准备mongodb数据库环境,创建用户admin、xxxx,创建bitrade数据库

    准备阿里云OSS(修改项目中需要配置的地方)

    准备nginx,修改配置文件(可选,正式上线需配置)

    修改framework代码中的配置文件为准备环境配置参数

    编译生成jar可执行文件

    运行cloud.jar(微服务注册中心)

    运行market.jar(行情中心)

    运行exchange.jar(交易中心)

    运行ucenter.jar(用户中心)

    运行其他模块

    打开mysql,导入framework代码中的sql文件夹中xxxxxxx.sql文件,注意,trigger的sql如果报错,需要针对wallet表添加trigger

    运行前端vue项目

    运行后端vue项目

    运行钱包RPC

    运行自动交易机器人程序(本部分代码未上传,但不影响)

    注意事项

    当内存不足时,在linux控制台输入top可以查看java进程占用了大量内存(一个java进程占用1G以上),因为有很多jar包需要运行,所以需要控制某些jar包使用的内存,目前控制以下4个:

    java -jar -Xms128m -Xmx128m -Xmn200m -Xss256k admin-api.jar

    java -jar -Xms512m -Xmx512m -Xmn200m -Xss256k cloud.jar

    java -jar -Xms512m -Xmx512m -Xmn200m -Xss256k wallet.jar

    java -jar -Xms512m -Xmx512m -Xmn200m -Xss256k activity.jar

    关于邮件&短信

    本系统支持邮件、短信发送系统运营状态

    系统通知/报警支持:用户注册、用户认证、用户充值/提现、币种RPC运行状态、系统资源使用监控等24种监控

    关于数据库脚本的问题

    有朋友反映没有完整的SQL文件,这是因为编译成功的Jar,首次运行后会自动将Entity映射成数据库结构,项目中的SQL只是完成一些Springcloud无法完成的数据库结构。 数据库自动生成配置位于application.properties配置文件:

    #jpa spring.jpa.show-sql=true spring.data.jpa.repositories.enabled=true spring.jpa.hibernate.ddl-auto=update

    spring.jpa.hibernate.ddl-auto=update 这个配置会自动更新数据库结构。

    核心功能说明(用户端)

    注册/登录/实名认证/审核(目前仅支持手机,二次开发可加入邮件,很简单)

    Banner/公告/帮助/定制页面(Banner支持PC与APP分开设置,帮助支持各种分类模式)

    法币C2C交易/法币OTC交易(支持两种法币模式,项目早期可由平台承担C2C法币兑换,后期可开放OTC交易)

    币币交易(支持限价委托、市价委托,二次开发可加入其它委托模式)

    邀请注册/推广合伙人(支持对邀请推广人数、佣金进行以日、周、月的排行统计)

    创新实验室(该部分支持功能较多,分项说明。另,APP暂不全部支持该功能)

    6-1. 首发抢购活动模式(如发行新交易对时,可对交易对设置一定数量的币种进行抢购)

    6-2. 首发分摊活动模式(如发行BTC/USDT交易对之前,官方拿出5BTC做活动,根据用户充值抵押的USDT多少进行均分BTC)

    6-3. 控盘抢购模式(如发行ZZZ/USDT交易对之前,ZZZ币种价格为5USDT,官方发行活动价为0.5USDT,则可使用该模式)

    6-4. 控盘均摊模式(如6-3,只不过平均分配)

    6-5. 矿机活动模式(支持用户抵押一定数量的币种,由官方承诺每月返还一定数量的币种)

    红包功能(支持平台及官方发放一定数量币种的红包,此功能适合用户裂变)

    用户资产管理、流水管理、委托管理、实名管理等各种基础管理

    核心功能说明(管理端)

    概要(查看平台运行数据,包含交易额、注册人数、充值等)

    会员管理(会员信息管理、会员实名审核、会员实名管理、会员余额管理、会员充值/冻结余额等)

    邀请管理(会员邀请信息、会员邀请排行管理)

    CTC管理(CTC订单管理、流水管理、承兑商管理)

    内容管理(PC广告管理、APP广告管理、公告管理、帮助管理)

    财务管理(充值提现管理、财务流水管理、对账管理、币种钱包余额管理)

    币币管理(新建交易对、管理交易对、新建交易机器人、设置交易机器人参数、设置行情引擎/交易引擎、撤销所有委托)

    活动管理(新建活动、矿机认购、抢购/瓜分管理)

    红包管理(平台红包管理、用户红包管理)

    系统管理(角色管理、部门管理、用户管理、权限管理、币种管理、RPC管理、版本管理)

    保证金管理(此功能设计时考虑到,但实际运营期间未使用到)

    OTC管理(广告管理、订单管理、OTC币种管理、退保管理等,此功能未获得实际运营检验)

    系统展示(PC前端)

    系统运行展示(APP前端)

    系统运行展示(后端)

    相关文章

      网友评论

        本文标题:基于Java开发的开源比特币交易所 | BTC交易所 | ETH

        本文链接:https://www.haomeiwen.com/subject/rqvwyhtx.html