Skip to content

Commit

Permalink
Initial commit
Browse files Browse the repository at this point in the history
  • Loading branch information
ZaneYork committed Apr 2, 2020
0 parents commit 6ef7766
Show file tree
Hide file tree
Showing 1,065 changed files with 90,904 additions and 0 deletions.
6 changes: 6 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
.DS_Store
*/target/
.idea/
**/*.iml
*.ipr
*.iws
236 changes: 236 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,236 @@
七喜开源数字货币交易系统
=====================================

七喜是一个基于ZTUO开源代码进行二次开发的的数字货币交易系统。

## 与ZTUO开源版本相比的优化
1. 修复系统内的余额锁BUG,既在高并发场景下的结算异常问题

2. 修改升级market项目处理逻辑,使之支持多节点集群部署,处理效率更高

3. 新增接口缓存功能,利用redis提供数据二级缓存,减少数据库压力

4. 支持mysql主从复制模式部署

5. 支持Redis哨兵模式集群环境

6. 引入Redission框架,并利用它实现分布式锁

7. 升级spring-session框架

8. 升级spring-boot框架

9. 引入xxl-job框架,利用它实现分布式自动任务调度

## 愿景

我们的使命是用Java开发世界上最好的、高性能的、安全的、开源的(重点)数字货币交易系统。

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

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


## 警告

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

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

2. 系统安全知识.

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

3. 法律风险

- 法律风险第一条:不要触犯中华人民共和国的法律条例。

- 技术无罪,请在法律范围内使用七喜框架。

- 如果你想使用七喜作为商业应用,最好请个律师,确保你的商业应用在法律允许的范围内。一切用于商业化项目所带来的法律和经济问题,七喜团队概不负责。

4. 你需要知道的基本知识

- 法律知识(安全第一条,法律最重要)
- Java知识(主要是spring)
- linux知识(CentOS、Ubuntu等等)
- 安全知识


### 主要技术
- 后端:Spring、SpringMVC、SpringData、SpringCloud、SpringBoot

- 数据库:Mysql、Mongodb

- 其他:redis、kafka、阿里云OSS、腾讯防水校验


### 开源许可协议
MIT

---

# 架构设计

#### ![](https://images.gitee.com/uploads/images/2019/0824/101549_9dea9664_1725492.png)

## 模块介绍

1. cloud

- 提供SpringCloud微服务注册中心功能,为基础模块,必须部署
- 依赖服务:无

2. ucenter-api

- 提供用户相关的接口(如登录、注册、资产列表),该模块为基础为基础模块,必须部署
- 依赖服务:mysql,kafka,redis,mongodb,短信接口,邮箱账号

3. otc-api

- 提供场外交易功能接口,没有场外交易的可以不部署
- 依赖服务:mysql,redis,mongodb,短信接口

4. exchange-api

- 提供币币交易接口,没有币币交易的项目可以不部署
- 依赖服务:mysql,redis,mongodb,kafka

5. gateway

- 微服务网关

6. admin

- 提供管理后台的所有服务接口,必须部署
- 依赖服务:mysql,redis,mongodb

7. wallet

- 提供充币、提币、获取地址等钱包服务,为基础模块,必须部署
- 依赖服务:mysql,mongodb,kafka,cloud

8. market

- 提供币种价格、k线、实时成交等接口服务,场外交易不需要部署
- 依赖服务:mysql,redis,mongodb,kafka,cloud

9. exchange

- 提供撮合交易服务,场外交易不需要部署
- 依赖服务:mysql,mongodb,kafka

## 重点业务介绍

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

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

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

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

## 环境搭建

#### CentOS环境搭建()

## 服务部署准备

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构建打包服务

```
cd /项目路径/framework
mvn clean package
```
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 &
```
### 提问和建议
- 使用Isuse,我们会及时跟进解答。
Loading

0 comments on commit 6ef7766

Please sign in to comment.