分布式金融项目业务记录

 

 

 

 

Spring cloud 主要采用阿里云的 nacos (对标网飞的Eureka)做服务注册与发现;使用openfeign做微服务的远程调用,应用案例为,用户注册是,判断该电话号码是否注册成功,此时主要是查询业务在core的微服务下实现的,而发送短信的判断则是在sms微服务,需要在sms微服务使用enable client组件,并且配置好路径,用http进行服务调用,完成了这个功能。其中熔断器为sentinel (对标网飞的Hystrix),防止出现停止一直等待,造成雪崩等,可以业务继续进行下去。最后采用gateway实现了网关,(外网网关用nginx),同时它也是一个微服务。

核心业务实现的细节:

一:汇付宝的设计文档,要求使用post。

补充:

1、OPTIONS
返回服务器针对特定资源所支持的HTTP请求方法,也可以利用向web服务器发送‘*’的请求来测试服务器的功能性
2、HEAD
向服务器索与GET请求相一致的响应,只不过响应体将不会被返回。这一方法可以再不必传输整个响应内容的情况下,就可以获取包含在响应小消息头中的元信息。
3、GET
向特定的资源发出请求。注意:GET方法不应当被用于产生“副作用”的操作中,例如在Web Application中,其中一个原因是GET可能会被网络蜘蛛等随意访问。Loadrunner中对应get请求函数:web_link和web_url
4、POST
向指定资源提交数据进行处理请求(例如提交表单或者上传文件)。数据被包含在请求体中。POST请求可能会导致新的资源的建立和/或已有资源的修改。 Loadrunner中对应POST请求函数:web_submit_data,web_submit_form
5、PUT
向指定资源位置上传其最新内容
6、DELETE
请求服务器删除Request-URL所标识的资源
7、TRACE
回显服务器收到的请求,主要用于测试或诊断
8、CONNECT
HTTP/1.1协议中预留给能够将连接改为管道方式的代理服务器。

二:尚融宝向汇付宝发送请求,需要验签sign,采用的MD5加密;

三: user_info 用use_id 与user_bind做了一个关联。两个都有一个bindCode,

 汇付宝返回的信息,一个是返回前端页面到user,一个是返回参数到后端微服务的业务中,后端进行相应的数据更新。

知识点

在用户绑定时有一个很巧妙的设计,由于在跟汇付宝发生远程调用时,不清楚会不会出现网络连接中断的问题,此时在更新srb数据库userbind 设置了一个绑定是否成功的标志为,此时置为0。(同时这里为了防止没有绑定成功的用户,多次执行绑定的方法,一定要提前对用户做一个判断!!,一个用人两个账号,用同样的身份证,手机号做账户绑定)

 四、借款人借款额度申请

 五、借款人申请借款 以及管理员审批

六、标lend的管理 (主要是对lend表的填充,以及在用户端界面显示)

七、投资人充值

 接口幂等性就是用户对于同一操作发起的一次请求或者多次请求的结果是一致的,不会因为多次调用而产生了副作用。

幂等性判断 :hfb会有一个流水号,通过流水号来判断幂等性。当然如果我们没有在代码层面设计幂等性判断,我们可以在数据库设置唯一索引来判断,重复实现数据库底层的自动回滚,但是会让系统报错,用户体验不好。

八、投资人投资

 

一个投资人投资,会生成一lend-item表,用于表示投资记录表,同时通过回调更新lend,usercount,流水表的数据。

 九、平台放款:(重要)

还款与回款,主要通过回款中的lend return id来关联。最重要的,项目采用先计算所有投资人每期的回款计划来  计算出  还款人每期的还款计划。

 

 

 

 

 

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值