假ArrayList导致的线上事故......
假ArrayList导致的线上事故…
线上事故回顾
- 晚饭时,当我正沉迷于排骨煲肉质鲜嫩,汤汁浓郁时,产研沟通群内发出一条消息,显示用户存在可用劵,但进去劵列表却什么也没有,并附含了一个视频。于是我一边吃了排骨,一边查看消息点开了视频,en~,视频跟描述一样。但没有系统告警,用户界面也没有明显的报错提示,怀疑是小部分特殊情况导致的,查看消息后几秒,我直接被@来处理问题,擦,只好把外卖盒重新盖好,先去处理问题。
处理经过
-
通过群内产品发的用户邮箱查到了用户id,再根据接口的相关日志结合uid在日志平台进行关联查询,查到日志后,再拿到traceId进行链路查询,果不其然,发现了异常日志,如下部分日志所示
-
java.lang.UnsupportedOperationException: nullat java.util.AbstractList.add(AbstractList.java:148) ~[na:1.8.0_151]at java.util.AbstractList.add(AbstractList.java:108) ~[na:1.8.0_151] -
这
UnsupportedOperationException是个什么玩意 -
@Slf4j @SpringBootTest public class Demo {public void test(Context context) { context.getList().add("皮皮虾");}}@Data class Context {private List<String> list;} -
基本操作就是拿到上下文中的List,然后再add一个元素
-
讲道理,add操作是不会有问题的,有问题的还得是List,追根溯源,让我康康这个List是怎么来的于是我一顿狂点,来到了set这个list的位置
-
@Slf4j @SpringBootTest public class Demo {public void test(Context context) {context.setList(Arrays.asList("皮皮虾"));}}@Data class Context {private List<String> list;} -
context.setList(Arrays.asList("Code皮皮虾"));这行看起来好像没问题啊Arrays.asList(T... a)我们平时也会用,传入一个数组,返回出一个List没啥问题呀 -
那我再试试
add方法 ,擦,问题复现了,还真是Arrays.asList(T... a)生成的List的add方法报错,由于线上存在问题,则先修改为以下代码上线,也就是修改为我们平时正常的写法, 上线后,观察了下日志,群里回复已解决问题,也让用户重试,发现没问题,自此问题解决。
追根溯源
-
进入
asList方法,发现底层new了一个ArrayList,并将数组传入作为List的元素 -
@SafeVarargs @SuppressWarnings("varargs") public static <T> List<T> asList(T... a) {return new ArrayList<>(a); } -
emm,看起来很简单啊,没问题啊,咋会报错呢?别着急,咱们在点开这个
ArrayList瞅瞅 -
private static class ArrayList<E> extends AbstractList<E>implements RandomAccess, java.io.Serializable {private static final long serialVersionUID = -2764017481108945198L;private final E[] a;ArrayList(E[] array) {a = Objects.requireNonNull(array);}// ... 省略 } -
擦,这
ArrayList是Arrays类的一个静态内部类,不是我们经常用的java.util.ArrayList继续看,这个静态内部类ArrayList继承了AbstractList,而且默认是没有实现add方法的.也就是说调用add方法会直接调用父类,也就是AbstractList的add方法,源码点开一看,真相大白了.AbstractList的add方法直接抛出UnsupportedOperationException异常,跟线上报错一模一样!!
相关文章:
假ArrayList导致的线上事故......
假ArrayList导致的线上事故… 线上事故回顾 晚饭时,当我正沉迷于排骨煲肉质鲜嫩,汤汁浓郁时,产研沟通群内发出一条消息,显示用户存在可用劵,但进去劵列表却什么也没有,并附含了一个视频。于是我一边吃了排…...
K8S精进之路-控制器Deployment-(1)
在K8S中,最小运行单位为POD,它是一个逻辑概念,其实是一组共享了某些资源的容器组。POD是能运行多个容器的,Pod 里的所有容器,共享的是同一个 Network Namespace,并且可以声明共享同一个 Volume。在POD中能够hold住网络…...
flutter iOS 视频mov格式转MP4格式
flutter iOS 视频mov格式转MP4格式 前言一、使用video_compress压缩视频总结 前言 今天在写项目的时候,突然发现iOS 里面的有些视频格式是mov的格式,这就导致在视频播放组件无法播放的问题,期间试过替换视频格式,但是又不想存储文…...
datafilecopy header validation failure for file +DATA/orcl/datafile/file1.ora
环境 linux 6.8 oracle 11.2.0.4 rac 未打补丁 现象: 数据库日志中显示 datafilecopy header validation failure for file DATA/orcl/datafile/file1.ora原因 用rman的backup as copy 对数据文件进行了copy或者叫位置更改时候,在sqlplus中对文件名进行…...
[机缘参悟-119] :一个IT人的反思:反者道之动;弱者,道之用 VS 恒者恒强,弱者恒弱的马太效应
目录 前言: 一、道家的核心思想 二、恒者恒强,弱者恒弱的马太效应 三、马太效应与道家思想的统一 3.1 大多数的理解 3.2 个人的理解 四、矛盾的对立统一 前言: 马太效应和强弱互转的道家思想,都反应了自然规律和社会规律&…...
CentOS用nginx搭建文件下载服务器
Nginx 是开源、高性能、高可靠的 Web 和反向代理服务器,而且支持热部署,几乎可以做到 7 * 24 小时不间断运行,即使运行几个月也不需要重新启动。在工作中,我们经常会用到需要搭建文件服务器的情况,这里就以在linux下搭…...
Ubuntu下载离线安装包
旧版Ubuntu下载地址 https://old-releases.ubuntu.com/releases/ 下载离线包 sudo apt-get --download-only -odir::cache/ncayu install net-tools下载snmp离线安装包 sudo apt-get --download-only -odir::cache/root/snmp install snmp snmpd snmp-mibs-downloadersudo a…...
【UE】线框材质
一、方式1 新建一个材质,混合模式设置为“已遮罩”,勾选“双面” 勾选“线框” 然后可以随便给一个自发光颜色,这样最基本的线框材质就完成了 二、方式2 新建一个材质,混合模式设置为“已遮罩”,勾选“双面”&#x…...
物联网网关在工业行业的应用与优势
物联网网关在工业行业的应用与优势 随着科技的发展,物联网(IoT)在各个行业得到了广泛应用。工业行业是其中的一个重要领域。工业行业涉及到许多生产和运输环节,需要不断地监测和控制各个环节的数据和参数。物联网网关(…...
【excel技巧】单元格内的公式如何隐藏?
Excel文件中最重要的除了数据还有就是一些公式了,但是只要点击单元格,公式就能显示出来,如果不想别人看到公式应该如何设置呢?今天分享隐藏excel单元格数据的方法。 选中单元格,点击右键打开【设置单元格格式】&#x…...
展开语法、剩余语法
展开语法定义 展开语法Spread Syntax,可以在函数调用/数组构造时,将数组表达式或者string在语法层面展开;还可以在构造字面量对象时,将对象表达式按照key-value的方式展开。(字面量一般指[1, 2, 3]或者{name:"md…...
MongoDB归并连续号段-(待验证)
实现按照不同条件归并连续号段的方式与具体的数据模型和查询需求有关,以下是一种常见的方式: 假设有一个文档集合,包含如下字段: {"_id": ObjectId("613c3050d5d9b45a0de7c290"),"group": "…...
【每日一题】设计循环队列(C语言)
循环队列是我们可以对队列有更深一步的理解的题目,而且可以进一步加强其他方面的知识(例如对循环数组的取模运算,指针的解引用),是个蛮不错的巩固习题,话不多说,进入正题。 链接在此࿱…...
logic-flow 使用过程中遇到的bug - 拖动节点到画布的时候,鼠标松开,节点不落在画布,仍旧跟着鼠标走
背景: 插件:logicFlow 用途:画流程图 bug表现: 初始化的样子: bug的样子: 拖动第一个节点的时候,一切正常(无论哪个节点作为第一个节点,都是正常的,但是拖动…...
el-tree结合el-switch实现状态切换
<template><div><el-col :span"24"><el-card class"tree-card"><div class"sketch_content selectFile"><span class"span_title">组织列表 </span><div style"display: flex; jus…...
汽车智能座舱/智能驾驶SOC -1
看到华为&小康的 AITO问界M6、M7各种广告营销、宣传、测评、好评如潮水般席卷网络各APP平台。翻看了中信和海通对特斯拉M3和比亚迪元的拆解报告,也好奇华为的汽车芯片平台又能做出哪些新花样,下面是Mark开头,也学习下智能座舱和智能驾驶芯…...
2023 年爆肝将近 20 万字讲解最新 JavaEE 全栈工程师基础教程(更新中)
1. Java 语言基本概述 Java 是一种广泛使用的编程语言,由 James Gosling 在 Sun Microsystems(现在是 Oracle Corporation 的一部分)于 1995 年发表。Java 是一种静态类型的、类基础的、并发性的、面向对象的编程语言。Java 广泛应用于企业级…...
目标检测YOLO实战应用案例100讲-基于改进YOLOv5s的道路目标检测(续)
目录 3.3融合注意力模块 3.3.1注意力机制 3.3.2 SENet 3.3.3 CBAM 3.3.4ECA 3.3.5改进后的算法网络结构...
Laravel/Lumen 任务调度简易入门说明
前提 Laravel 中任务调度简化了服务器系统中 Cron 的操作,使得 计划任务 的实现更为简便。 这里主要以 Laravel 自带的消息队列进行说明,了解其间运行关系可以让我们更清晰的进行代码实现。 下方代码以 Lumen 9.x 框架进行举例,与 Laravel…...
目标检测 详解SSD原理,数据处理与复现
原理详解 前言 今天我们要读的这篇VGGNet(《Very Deep Convolutional Networks For Large-Scale Image Recognition》),就是在AlexNet基础上对深度对网络性能的影响做了进一步的探索。它是ImageNet 2014年亚军,相比于AlexNet&am…...
告别ABAP代码:SQVI表连接功能详解,教你5步关联多表生成复杂ALV报表
零代码实现SAP多表联查:SQVI图形化关联实战指南 在SAP日常业务中,销售部门需要查看订单状态时,往往要同时关联VBAK(销售订单主数据)、VBAP(销售订单行项目)、LIKP(交货单抬头&#x…...
【2026金地杯】C题满分思路全景拆解:核桃油品质分析的特征提取、筛选与综合评价(纯净文字解析版)
引言在2026年“金地杯”山西省大学生数学建模挑战赛中,C题“核桃油品质分析特征提取筛选与评价”是一道披着传统理化分析外衣,实则极度考验高维数据挖掘与复杂系统评价能力的硬核赛题。核桃油的品质并非由单一指标决定,而是由脂肪酸组分、微量…...
终极指南:如何用GHelper轻松掌控华硕笔记本性能
终极指南:如何用GHelper轻松掌控华硕笔记本性能 【免费下载链接】g-helper Lightweight Armoury Crate alternative for Asus laptops with nearly the same functionality. Works with ROG Zephyrus, Flow, TUF, Strix, Scar, ProArt, Vivobook, Zenbook, Expertbo…...
LLMPapers:社区驱动的LLM论文知识库,助力研究者高效追踪前沿
1. 项目概述:一个为LLM研究者量身打造的论文仓库如果你正在或即将踏入大语言模型(LLM)的研究领域,那么你大概率会遇到一个经典难题:信息过载与信息孤岛并存。每天都有数十篇甚至上百篇相关论文在arXiv、ACL、NeurIPS等…...
图卷积网络
图卷积网络 (Graph convolutional net, GCN) 能够聚合图中的单跳或多跳邻域信息,更好学习到图结构。或者说调节图上的平滑度。前置知识:核心要素:标准化图拉普拉斯矩阵:Lnorm I − D−1/2AD−1/2 其中A是邻接矩阵,D是…...
如何快速实现网站离线备份:3步完成完整下载方案
如何快速实现网站离线备份:3步完成完整下载方案 【免费下载链接】WebSite-Downloader 项目地址: https://gitcode.com/gh_mirrors/web/WebSite-Downloader 在信息时代,网站内容随时可能消失或变更,你是否担心重要资料丢失?…...
技术解密:VMware macOS解锁工具Unlocker的逆向工程与虚拟化边界突破
技术解密:VMware macOS解锁工具Unlocker的逆向工程与虚拟化边界突破 【免费下载链接】unlocker VMware Workstation macOS 项目地址: https://gitcode.com/gh_mirrors/unloc/unlocker 在虚拟化技术领域,VMware Workstation长期占据着企业级和个人…...
Deno Deploy部署Azure OpenAI代理:零成本解决API兼容问题
1. 项目概述:在Deno Deploy上搭建一个免费的Azure OpenAI代理如果你正在折腾各种开源的ChatGPT WebUI项目,比如ChatGPT-Next-Web、Lobe Chat,或者想在自己的应用里集成GPT能力,大概率会遇到一个头疼的问题:这些项目默认…...
ColabFold终极指南:5个步骤实现零基础蛋白质结构预测
ColabFold终极指南:5个步骤实现零基础蛋白质结构预测 【免费下载链接】ColabFold Making Protein folding accessible to all! 项目地址: https://gitcode.com/gh_mirrors/co/ColabFold ColabFold是一款革命性的开源AI生物信息学工具,它将复杂的蛋…...
从零开始使用Taotoken在十分钟内完成第一个AI应用调用
🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 从零开始使用Taotoken在十分钟内完成第一个AI应用调用 1. 注册与初始准备 打开浏览器,访问Taotoken官方网站。注册流程…...
