解决数据丢失问题--互联网业务可回溯的优化、提升

如果你在金融行业工作过,那么你应该很熟悉“可回溯”这个概念。在金融行业,可回溯通常用于记录用户的所有操作以及交互状态,以便在出现纠纷时进行证据溯源。此外,金融监管部门也要求金融机构必须具备可回溯能力,以确保监管红线的合规性。

最近从领导处接到一个需求,解决当前线上投保项目回溯过程中的“数据丢失”问题:用户投保的相关操作没有没有被记录制下来 ☜(`o´)

这是个严重问题,了解需求后,赶紧去线上查找问题发生原因,经定位,发现一些特殊的场景不能被正确的录制,联系供应商反馈还在解决中,未给出解决方案时间表 (╯°Д°)╯ ┻━┻

悲催,只能自己动手了,去线上找找看是否有案,功夫不复有心人,终于在npmjs 上找到一款回溯库,可以很好的解决当前数据录制丢失的问题,重点是接入简单、改造成本非常小(〃^∇^)o

npm库地址: @zxyf/ztrack - npm

参照对接文档,把回溯接入到本地工程做了基础测试,步骤如下:

1. 安装回溯依赖

npm install @zxyf/ztrack
或
yarn add @zxyf/ztrack

2. 录制初始化

// 引入录制库
import ZTrackRecorder from '@zxyf/ztrack';

// 初始化参数
const params = {
  autoStart: true // 是否自动开始
};

// 通过构造函数实例化后再执行初始化
const recorder = new ZTrackRecorder();
recorder.init(params).then(() => {
  console.log('录制初始化成功,开始录制');
});
// 初始化成功后可以通过recorder.bizUuid 获取当前bizUuid
// bizUuid 也可以放到params中作为初始化参数

3 开始录制

// 如果初始化参数 autoStart 为true,则无需调用  
recorder.start().then(() =>{
  console.log('开始录制');
});

4 添加回溯业务节点

// 添加的业务节点可以在回溯视频中直接查看,业务节点KEY值、名称可以在后台进行设置
​
recorder.addBizNode('VIEW_NOTICE').then(() =>{
  console.log('添加“查看须知”业务节点');
});  // 添加业务节点,可以通过 recorder.bizNodes 获取,非必须

5 停止录制

// 停止录制,停止录制后继续调用 recorder.start() 可以继续录制
recorder.stop().then(() => {
  console.log('录制停止');
});

6 完成录制

// 完成录制,表示业务已完成,后续不可继续录制
recorder.finish().then(() => {
  console.log('录制完成');
});

7 回溯效果播放

初始化成功后通过recorder.bizUuid 可以获取当前bizUuid,
回溯完成后通过可以下链接查看,其中XXXX是录制时传入的bizUuid
​
https://dev.helisoft.cn/ztrack-simple-player/?bizUuid=XXXX

8 管理后台播放效果

9 其他测试

同时,我们又针对一些其他场景、特性做了调试,发现支持良好

  1. iframe 页面操作行为录制--正常

  2. canvas 页面行为(以echarts图表为例)--正常

  3. 不同链接间的页面跳转--正常

  4. 页面滚动、输入、选择等操作--正常

  5. 视频图像录制--正常

  6. 客户敏感信息以*号替换--支持

  7. 业务节点展示--支持

  8. 回溯码防篡改--支持

    替换回溯库后部署上线,跑了一周数据,所有投保数据录制正常,任务完美完成,晚饭加个鸡腿ヾ(^-^)ノ

    兄弟们开发过程中若遇到回溯相关问题,欢迎留言交流、沟通

     

  • 4
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
图的着色问题可以使用回溯算法来解决回溯算法是一种试探性的算法,通过不断地尝试所有可能的解决方案,找到符合条件的最优解。 在图的着色问题中,我们要为每个节点选择一种颜色进行着色,使得相邻节点的颜色不相同。具体的回溯算法实现如下: 1. 首先,选择一个未着色的节点作为当前节点。 2. 枚举当前节点可以使用的颜色,如果该颜色和相邻节点的颜色不同,则将当前节点着色为该颜色,并将下一个未着色的节点作为当前节点。 3. 如果所有的节点都已经着色,则找到了一组可行解。 4. 如果当前节点无法找到可用的颜色,则回溯到上一个节点,重新选择颜色。 Java 代码实现如下: ``` public class GraphColoring { private int numOfVertex; // 节点数 private int numOfColor; // 颜色数 private int[] colors; // 节点的颜色 private int[][] graph; // 图 public GraphColoring(int[][] graph, int numOfColor) { this.numOfVertex = graph.length; this.numOfColor = numOfColor; this.colors = new int[numOfVertex]; this.graph = graph; } public void solve() { if(backtrack(0)) { System.out.println("Solution exists!"); printSolution(); } else { System.out.println("Solution does not exist!"); } } private boolean backtrack(int vertex) { if(vertex == numOfVertex) { // 所有节点都已着色 return true; } for(int color=1; color<=numOfColor; color++) { if(isValid(vertex, color)) { colors[vertex] = color; // 着色 if(backtrack(vertex+1)) { // 着色下一个节点 return true; } colors[vertex] = 0; // 回溯 } } return false; } private boolean isValid(int vertex, int color) { for(int i=0; i<numOfVertex; i++) { if(graph[vertex][i] == 1 && colors[i] == color) { // 相邻节点颜色相同 return false; } } return true; } private void printSolution() { for(int i=0; i<numOfVertex; i++) { System.out.println("Vertex " + (i+1) + " is colored with " + colors[i]); } } } ``` 其中,`graph` 表示图的邻接矩阵,`numOfColor` 表示颜色的种数。调用 `solve()` 方法即可求解该问题

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值