主要技术
- 后端:Spring、SpringMVC、SpringData、SpringCloud、SpringBoot
- 数据库:Mysql、Mongodb
- 其他:redis、kafka、阿里云OSS、腾讯防水校验
模块介绍
- cloud
- 提供SpringCloud微服务注册中心功能,为基础模块,必须部署
- 依赖服务:无
- ucenter-api
- 提供用户相关的接口(如登录、注册、资产列表),该模块为基础为基础模块,必须部署
- 依赖服务:mysql,kafka,redis,mongodb,短信接口,邮箱账号
- otc-api
- 提供场外交易功能接口,没有场外交易的可以不部署
- 依赖服务:mysql,redis,mongodb,短信接口
- exchange-api
- 提供币币交易接口,没有币币交易的项目可以不部署
- 依赖服务:mysql,redis,mongodb,kafka
- gateway
- 微服务网关
- admin
- 提供管理后台的所有服务接口,必须部署
- 依赖服务:mysql,redis,mongodb
- wallet
- 提供充币、提币、获取地址等钱包服务,为基础模块,必须部署
- 依赖服务:mysql,mongodb,kafka,cloud
- market
- 提供币种价格、k线、实时成交等接口服务,场外交易不需要部署
- 依赖服务:mysql,redis,mongodb,kafka,cloud
- exchange
- 提供撮合交易服务,场外交易不需要部署
- 依赖服务:mysql,mongodb,kafka
重点业务介绍
后端框架的核心模块为 exchange,market模块。
其中exhcnge模块完全采用Java内存处理队列,大大加快处理逻辑,中间不牵涉数据库操作,保证处理速度快,其中项目启动后采用继承ApplicationListener方式,自动运行;
启动后自动加载未处理的订单,重新加载到JVM中,从而保证数据的准确,exchange将订单处理后,将成交记录发送到market;
market模块主要都是数据库操作,将用户变化信息持久化到数据库中。主要难点在于和前端交互socket推送,socket推送采用两种方式,web端socket采用SpringSocket,移动端采用Netty推送,其中netty推送通过定时任务处理。
环境搭建
CentOS环境搭建()
服务部署准备
- 项目用了Lombok插件,无论用什么IDE工具,请务必先安装Lombok插件
- 项目用了QueryDsl,如果遇见以Q开头的类找不到,请先编译一下对应的core模块,例如core、exchange-core、xxx-core这种模块
- 找不到的jar包在项目jar文件夹下
- jdk版本1.8以上
- 初始化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.**
服务启动
- maven构建打包服务
cd /项目路径/framework mvn clean package
- 将各个模块target文件夹下的XX.jar上传到自己的服务器
- 先启动cloud模块,再启动market,exchange模块,剩下的没有顺序。
- 启动服务例:
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 &
阅读全文
下载说明:
1、本站所有资源均从互联网上收集整理而来,仅供学习交流之用,因此不包含技术服务请大家谅解!
2、本站不提供任何实质性的付费和支付资源,所有需要积分下载的资源均为网站运营赞助费用或者线下劳务费用!
3、本站所有资源仅用于学习及研究使用,您必须在下载后的24小时内删除所下载资源,切勿用于商业用途,否则由此引发的法律纠纷及连带责任本站和发布者概不承担!
4、本站站内提供的所有可下载资源,本站保证未做任何负面改动(不包含修复bug和完善功能等正面优化或二次开发),但本站不保证资源的准确性、安全性和完整性,用户下载后自行斟酌,我们以交流学习为目的,并不是所有的源码都100%无错或无bug!如有链接无法下载、失效或广告,请联系客服处理!
5、本站资源除标明原创外均来自网络整理,版权归原作者或本站特约原创作者所有,如侵犯到您的合法权益,请立即告知本站,本站将及时予与删除并致以最深的歉意!
6、如果您也有好的资源或教程,您可以投稿发布,成功分享后有站币奖励和额外收入!
7、如果您喜欢该资源,请支持官方正版资源,以得到更好的正版服务!
8、请您认真阅读上述内容,注册本站用户或下载本站资源即您同意上述内容!
原文链接:https://www.shuli.cc/?p=9508,转载请注明出处。
1、本站所有资源均从互联网上收集整理而来,仅供学习交流之用,因此不包含技术服务请大家谅解!
2、本站不提供任何实质性的付费和支付资源,所有需要积分下载的资源均为网站运营赞助费用或者线下劳务费用!
3、本站所有资源仅用于学习及研究使用,您必须在下载后的24小时内删除所下载资源,切勿用于商业用途,否则由此引发的法律纠纷及连带责任本站和发布者概不承担!
4、本站站内提供的所有可下载资源,本站保证未做任何负面改动(不包含修复bug和完善功能等正面优化或二次开发),但本站不保证资源的准确性、安全性和完整性,用户下载后自行斟酌,我们以交流学习为目的,并不是所有的源码都100%无错或无bug!如有链接无法下载、失效或广告,请联系客服处理!
5、本站资源除标明原创外均来自网络整理,版权归原作者或本站特约原创作者所有,如侵犯到您的合法权益,请立即告知本站,本站将及时予与删除并致以最深的歉意!
6、如果您也有好的资源或教程,您可以投稿发布,成功分享后有站币奖励和额外收入!
7、如果您喜欢该资源,请支持官方正版资源,以得到更好的正版服务!
8、请您认真阅读上述内容,注册本站用户或下载本站资源即您同意上述内容!
原文链接:https://www.shuli.cc/?p=9508,转载请注明出处。
评论0