Java中JVM常用参数配置(提供配置示例)

目录

    • 前言
    • 一、内存参数配置
    • 二、垃圾收集器配置
    • 三、GC策略配置
      • 3.1、基础通用配置
      • 3.2、Parallel 和 Parallel Old 常用参数配置
      • 3.3、CMS 常用参数配置
      • 3.4、G1 常用参数配置
    • 四、GC日志配置
    • 五、dump 日志参数配置
      • 5.1、OutOfMemory异常时生成dump文件
      • 5.2、发生Full GC时生成dump文件
    • 六、其它参数配置
    • 七、配置示例
      • 7.1、在IDEA中配置JVM参数
      • 7.2、通过 Java -jar 启动配置

前言

      在实际开发和部署中一个合格的码农都会对JVM的一些参数做合理的配置,比如内存配置参数、GC策略配置参数、日志配置参数、异常信息参数等,本文会列出一些常用的JVM参数以及通过一些例子演示配置后的效果。

PS:本文使用JDK1.8

一、内存参数配置

// 设置JVM使Server模式,特点是启动速度较慢,但运行时性能和内存管理效率很高,适用于生产环境。在具有64位能力的JDK环境下默认启用该模式。
-server // 设置元空间最大值, 默认是-1, 即不限制, 或者说只受限于本地内存大小,如果超过这个值会内存溢出。
-XX:MaxMetaspaceSize=256m
// 指定元空间触发Fullgc的初始阈值(元空间无固定初始大小), 以字节为单位,默认是21M,达到该值就会触发full gc进行类型卸载, 同时收集器会对该值进行调整: 如果释放了大量的空间, 就适当降低该值; 如果释放了很少的空间, 那么在不超过-XX:MaxMetaspaceSize(如果设置了的话) 的情况下, 适当提高该值。这个跟早期jdk版本的-XX:PermSize参数意思不一样,-XX:PermSize代表永久代的初始容量。
// 触发一次元空间Full GC后就会重新计算该值,建议设置成和最大内存一致
-XX:MetaspaceSize=256m// 设置最大堆内存,默认是物理内存的1/4,内存的单位可以是m g,并且不区分大小写
-Xmx2g 或者 -XX:MaxHeapSize=2048m
// 设置初始值堆内存,默认是物理内存的1/64,内存的单位可以是m g,并且不区分大小写
-Xms2g 或者 -XX:InitialHeapSize=2048m
// 设置年轻代内存大小,默认和老年代1\2,-XX:NewSize初始化年轻代大小 -XX:MaxNewSize最大年轻代大小
-Xmn1g 或者 -XX:NewSize=1g -XX:MaxNewSize=1g
// 设置每个线程的堆栈大小 默认是1024k,这个是最大内存并不是开启一个线程马上就会消耗这么多内存
-Xss512k 或者 -XX:ThreadStackSize=512k// 年轻代占用堆比例(如果有配置-Xmn,那么会以-Xmn配置为准)
// 默认 -XX:NewRatio=2新生代占1,老年代占2,年轻代占整个堆的1/3
// 假如 -XX:NewRatio=4新生代占1,老年代占4,年轻代占整个堆的1/5 NewRatio值就是设置老年代的占比,剩下的1给新生代
-XX:NewRatio=2 
// 用来设置新生代中eden空间和from/to空间的比例.含义:-设置为8代表 eden使用80%的新生代内存 from和to各用10%,默认为8
-XX:SurvivorRatio=8
// 禁用Survivor区自适应策略默认是开启的,如果不关闭这个配置新生代eden区和s0 s1区会在gc后自动调整大小,如果设置了-XX:SurvivorRatio也只有在没有GC之前有效只要GC后就会重新动态计算
-XX:-UseAdaptiveSizePolicy// 扩张堆内存的时机
// 堆内存使用率大于70时扩张堆内存,如果最大堆内存=初始堆内存时该参数无效,默认值70
-XX:MaxHeapFreeRatio=70
// 缩小堆内存的时机
// 堆内存使用率小于40时缩减堆内存,如果最大堆内存=初始堆内存时该参数无效,默认值40
-XX:MinHeapFreeRatio=40// 字符串常量池hash桶大小 类似于HashTable,最小值1009 默认60013 不可动态扩容
-XX:StringTableSize=60013// 设置直接内存大小,NIO(Non-blocking I/O)中通过ByteBuffer等对象分配的堆外内存
// 默认情况下,直接内存的大小可能会与Java堆的最大值 (-Xmx) 相同
-XX:MaxDirectMemorySize=512m

二、垃圾收集器配置

// 配置使用Serial单线程垃圾收集器,虚拟机运行在Client模式下的默认值
// 新生代使用Serial  老年代则使用SerialOld
-XX:+UseSerialGC// 配置使用ParNew垃圾收集器
// 新生代使用ParNew 老年代则使用Serial Old
-XX:+UseParNewGC// 配置使用Parallel Scavenge垃圾收集器,虚拟机运行在Server模式下的默认值
// 新生代使用Parallel Scavenge 老年代使用Parallel Old收集器
-XX:+UseParallelGC// 配置使用Parallel Old垃圾收集器
// 新生代使用Parallel Scavenge 老年代使用Parallel Old收集器
-XX:+UseParallelOldGC// 配置使用CMS垃圾收集器
// 新生代使用ParNew 老年代使用CMS+Serial Old收集器
-XX:+UseConcMarkSweepGC// 配置使用G1垃圾收集器
-XX:+UseG1GC

可以通过jinfo -flags 进程号查看对应Java程序启动参数,我本地使用的JDK1.8默认使用的ParallelGC
在这里插入图片描述

三、GC策略配置

3.1、基础通用配置

// GC停顿时间,垃圾收集器会尝试用各种手段达到这个时间,比如减小年轻代
-XX:MaxGCPauseMillis // 新生代晋升老年代阈值 默认是15 不同回收算法不同
-XX:MaxTenuringThreshold=15// 对象动态年龄判断默认50%  当一批对象大小>=survivor区的50%时这批对象会直接放入老年代
-XX:TargetSurvivorRatio=50// 默认值是0没有限制 大于这个值的参数直接在老年代分配
// 这样做的目的是避免在Eden区和两个Survivor区之间发生大量的内存复制XX:PretenureSizeThreshold=1m// 忽略手动调用GC, System.gc()的调用就会变成一个空调用,完全不触发GC
-XX:+DisableExplicitGC // 内存页的大小
-XX:LargePageSizeInBytes=128m // 设定GMT区域,避免CentOS坑爹的时区设置
-Duser.timezone=GMT+8// FullGC 前执行MinorGC  默认是开启的
-XX:+ScavengeBeforeFullGC

3.2、Parallel 和 Parallel Old 常用参数配置

// 调整垃圾回收的时间和总时间的占比 公式 1/(1+ratio)  ratio默认是99,100分钟运行时间默认不能超过1分钟的GC时间,ratio一般设置为19
-XX:GCTimeRatio=99// GC最大暂停毫秒数 默认是200毫秒 和-XX:+GCTimeRatio有冲突,堆内存小回收速度才会快,而-XX:+GCTimeRatio需要保证一定时间内GC时间不能超过一个临界值需要增加内存才能减小GC时间比,需要找到一个两个参数的合理值
-XX:MaxGCPauseMillis=200ms// 设置垃圾回收线程数量 默认是CUP内核数量
-XX:ParallelGCThreads=4

3.3、CMS 常用参数配置

// GC最大暂停毫秒数 默认是200毫秒
-XX:MaxGCPauseMillis=200ms// 为了加快此阶段处理速度,减少停顿时间,可以开启初始标记并行化
-XX:+CMSParallelInitialMarkEnabled// CMS并行线程数量,并行线程用于执行 CMS 垃圾回收器的并行阶段,如初始标记阶段和重新标记阶段
// 默认值为系统的逻辑处理器数量减1,目的是为了保留一个处理器用于应用程序线程
-XX:ParallelCMSThreads=3// CMS并发线程数量,并发线程用于执行 CMS 垃圾回收器的并发阶段,如初始标记阶段、并发标记阶段和并发清理阶段。
// 默认值为系统的逻辑处理器数量减1,目的是为了保留一个处理器用于应用程序线程
-XX:ConcGCThreads=3// 执行CMS的内存占比 percent=80 当我的老年代内存达到80%触发垃圾回收 默认是92% 应为CMS采用标记清除需要给浮动垃圾(在最后一步并发清除时其它没有被标记的垃圾遗留)预留空间 
-XX:CMSInitiatingOccupancyFraction=percent// 该参数需要配合XX:CMSInitiatingOccupancyFraction使用,只使用设定的回收阈值(-XX:CMSInitiatingOccupancyFraction设 定的值),如果不指定,JVM仅在第一次使用设定值,后续则会自动调整
-XX:+UseCMSInitiatingOccupancyOnly // 重新标记阶段前提前进行一次新生代GC,因为重新标记也会判断新生代对象是否引用老年代对象,有些时候新生代对象已经没有被GC root对象引用但是还没有GC时,重新标记会扫描到新生代对象并且保留新生代对象引用的老年代对象,默认关闭false
-XX:CMSScavengeBeforeRemark=true// 执行完Full GC后对内存空间进行压缩整理 默认开启
-XX:+UseCMSCompactAtFullGollection// 设置在执行多少次Full GC后对内存空间进行压缩整理 默认0次,只要触发Full GC就会进行内存压缩
-XX:CMSFullGCsBeforeCompaction=0// 垃圾回收时是否同时卸载不用的class信息,默认关闭
-XX:+CMSClassUnloadingEnabled

3.4、G1 常用参数配置

// 指定分区大小(1MB~32MB,且必须是2的N次幂),不设置默认会根据堆大小分配
// 堆内存为1G默认1024个1MB分区、堆内存为2G默认2048个1MB分区、堆内存为4G默认2048个2MB分区、堆内存为4G默认2048个2MB分区、堆内存为6G默认6144个1MB分区、堆内存为8G默认2048个4MB分区、以此类推
-XX:G1HeapRegionSize=2m// 目标暂停时间(默认200ms) 
-XX:MaxGCPauseMillis=200ms// 新生代内存初始空间(默认整堆5%) 
-XX:G1NewSizePercent=5// 新生代内存最大空间 (默认整堆60%) 
-XX:G1MaxNewSizePercent=60// Survivor区的填充容量(默认50%),Survivor区域里的一批对象(年龄1+年龄2+年龄n的多个 年龄对象)总和超过了Survivor区域的50%,此时就会把年龄n(含)以上的对象都放入老年代 
-XX:TargetSurvivorRatio=50// 最大年龄阈值(默认15) 
-XX:MaxTenuringThreshold=15// 老年代占用空间达到整堆内存阈值(默认45%),则执行新生代和老年代的混合收集(MixedGC) 
-XX:InitiatingHeapOccupancyPercent=45// region中的存活对象低于这个值时才会回收该region,如果超过这个值,存活对象过多,回收的的意义不大(默认65%)。 
-XX:G1MixedGCLiveThresholdPercent=65// 在一次回收过程中指定做几次筛选回收(默认8次),在最后一个筛选回收阶段可以回收一会,然后暂停回收,恢复系统运行,一会再开始回收,这样可以让系统不至于单次停顿时间过长。 
-XX:G1MixedGCCountTarget=8// gc过程中空出来的region是否充足阈值,在混合回收的时候,对Region回收都是基于复制算法进行的,都是把要回收的Region里的存活对象放入其他Region,然后这个Region中的垃圾对象全部清理掉,这样的话在回收过程就会不断空出来新的Region,一旦空闲出来的Region数量达到了堆内存的5%,此时就会立即停止混合回收,意味着本次混合回收就结束了(默认5%)。
-XX:G1HeapWastePercent=5

四、GC日志配置

// 设置日志目录和日志名称
-Xloggc:/data/logs/gc-%t.log// 开启滚动生成日志 默认关闭
-XX:+UseGCLogFileRotation
// 滚动GC日志文件数,默认0不滚动,保留最多5个日志文件
-XX:NumberOfGCLogFiles=5
// GC文件滚动大小,需开启UseGCLogFileRotation,每个文件最大为20MB
-XX:GCLogFileSize=20M // 在进行GC的前后打印出堆的信息
-XX:+PrintHeapAtGC 
// 打印新生代晋升详情
-XX:+PrintTenuringDistribution
// 打印字符串常量池堆信息
-XX:+PrintStringTableStatistics
// 打印GC信息
-verbose:gc 
// 打印GC详细信息 
-XX:+PrintGCDetails
// 输出GC的时间戳(以基准时间的形式)
-XX:+PrintGCTimeStamps
// 输出GC的时间戳(以日期的形式,如 2013-05-04T21:53:59.234+0800)
-XX:+PrintGCDateStamps 
// 打印当前JVM参数信息 建议在每个程序中都添加上
-XX:+PrintCommandLineFlags
// 产生GC的原因(默认开启)
-XX:+PrintGCCause

五、dump 日志参数配置

5.1、OutOfMemory异常时生成dump文件

// 默认关闭
// 可以通过jinfo -flag [+|-]HeapDumpOnOutOfMemoryError <pid> 或 jinfo -flag HeapDumpOnOutOfMemoryError=<value> <pid> 来动态开启或设置值
-XX:+HeapDumpOnOutOfMemoryError
// 设置文件存储路径
// 当HeapDumpOnOutOfMemoryError开启的时候,dump文件的保存路径,默认为工作目录下的,可以通过配置指定保存路径
-XX:HeapDumpPath=/data/dump/jvm.hprof

5.2、发生Full GC时生成dump文件

不推荐开启会增加整体停顿时间

// 在Full GC前dump
-XX:+HeapDumpBeforeFullGC
// 在Full GC后dump
-XX:+HeapDumpAfterFullGC
// 设置Dump保存的路径
-XX:HeapDumpPath=/data/dump/jvm.hprof

六、其它参数配置

// JVM自身故障导致进程奔溃时,会有一个日志文件生成,它包含了导致crash的重要信息,通过分析文件来查找crash原因
-XX:ErrorFile=/data/logs/error.log// JDK1.6开始,默认server模式下开启了这个参数,意为当jvm检测到程序在重复抛一个异常
// 在执行若干次后会将异常吞掉,这里的若干次在jdk1.7测得是20707。即执行20707次后,stackTrace 长度会为0。有时这不利于我们排错,通过指定OmitStackTraceInFastThrow,可禁用这功能
-XX:-OmitStackTraceInFastThrow

七、配置示例

需要配置的参数信息

// 配置新生代使用Parallel Scavenge 老年代将会使用Parallel Old收集器
-XX:+UseParallelOldGC
// 配置元空间最大内存和初始内存
-XX:MaxMetaspaceSize=256m -XX:MetaspaceSize=256m
// 配置最大堆内存、初始内存、新生代占用内存
-Xmx512m -Xms512m -Xmn256m
// 配置关闭动态调整新生代eden和from to大小比例
-XX:-UseAdaptiveSizePolicy
// 配置忽略手动调用GC和时区
-XX:+DisableExplicitGC -Duser.timezone=GMT+8
// 配置开启记录OOM Dump信息和存储地址
-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=./jvm.hprof
// 配置打印当前JVM参数信息
-XX:+PrintCommandLineFlags
// 配置开启GC日志输出
-verbose:gc -XX:+PrintGCDetails -XX:+PrintHeapAtGC -XX:+PrintGCDateStamps -Xloggc:./gc-%t.log
// 配置关闭重复多次抛同一个异常不输出
-XX:-OmitStackTraceInFastThrow
// 配置JVM自身故障导致宕机时日志输出目录
-XX:ErrorFile=./error.log

7.1、在IDEA中配置JVM参数

  • 配置参数(注意文件的输出目录,我这里会直接输出在当前目录)
-XX:+UseParallelOldGC
-XX:MaxMetaspaceSize=256m -XX:MetaspaceSize=256m
-Xmx20m -Xms20m -Xmn10m
-XX:-UseAdaptiveSizePolicy
-XX:+DisableExplicitGC -Duser.timezone=GMT+8
-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=./jvm.hprof
-XX:+PrintCommandLineFlags
-verbose:gc -XX:+PrintGCDetails -XX:+PrintHeapAtGC -XX:+PrintGCDateStamps -Xloggc:./gc-%t.log
-XX:-OmitStackTraceInFastThrow
-XX:ErrorFile=./error.log
  • 配置流程
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

7.2、通过 Java -jar 启动配置

# 应用配置示例
nohup java -XX:+UseParallelOldGC -XX:MaxMetaspaceSize=256m -XX:MetaspaceSize=256m -Xmx512m -Xms512m -Xmn256m -XX:-UseAdaptiveSizePolicy -XX:+DisableExplicitGC -Duser.timezone=GMT+8 -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=./jvm.hprof -XX:+PrintCommandLineFlags -verbose:gc -XX:+PrintGCDetails -XX:+PrintHeapAtGC -XX:+PrintGCDateStamps -Xloggc:./gc-%t.log -XX:-OmitStackTraceInFastThrow -XX:ErrorFile=./error.log -jar app.jar > app.log 2>&1 &

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

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

相关文章

QT安装与helloworld

文章目录 QT安装与helloworld1.概念&#xff1a;2.安装QT3.配置环境变量4.创建项目5.运行效果 QT安装与helloworld 1.概念&#xff1a; Qt Creator是一个用于Qt开发的轻量级跨平台集成开发环境。Qt Creator可带来两大关键益处&#xff1a;提供首个专为支持跨平台开发而设计的…

在Python中执行Linux Shell脚本详解

概要 随着 Python 的增长和普及,目前它已经成为自动化各种任务,包括执行 shell 脚本的主要工具。这篇文章将详细描述如何在 Python 中执行 shell 脚本,并提供丰富的示例帮助你理解和实践。 什么是Shell脚本? Shell脚本是一个由命令行解释器执行的文本文件。这些脚本包含控…

数据结构第九天(堆排序)

目录 前言 概述 源码&#xff1a; 主函数&#xff1a; 运行结果&#xff1a; 其他 前言 哈哈&#xff0c;这个堆排序算法很久之前就已经敲过一遍了&#xff0c;时间一久&#xff0c;思路有点淡忘。今天重新看过一遍之后&#xff0c;又亲自撸代码&#xff0c;幸运的是&am…

【MATLAB源码-第137期】基于matlab的NOMA系统和OFDMA系统对比仿真。

操作环境&#xff1a; MATLAB 2022a 1、算法描述 NOMA&#xff08;非正交多址&#xff09;和OFDMA&#xff08;正交频分多址&#xff09;是两种流行的无线通信技术&#xff0c;广泛应用于现代移动通信系统中&#xff0c;如4G、5G和未来的6G网络。它们的设计目标是提高频谱效…

如何使用C#调用LabVIEW算法

新建一个工程 这是必须的&#xff1b; 创建项目 项目 点击完成&#xff1b; 将项目另存为&#xff1b;方便后续的使用&#xff1b; 创建 一个测试VI 功能很简单&#xff0c;用的一个加法&#xff1b;将加数A&#xff0c;B设置为输入&#xff0c;和C设置为输出&#xff0c;…

正点原子--STM32通用定时器学习笔记(2)

1. 通用定时器输入捕获部分框图介绍 捕获/比较通道的输入部分&#xff08;通道1&#xff09; 输入通道映射CC1S[1:0]→采样频率CKD[1:0]→滤波方式IC1F[3:0]→边沿检测方式CC1P→捕获分频ICPS[1:0]→使能捕获CC1E 输入部分对相应的TIx输入信号采样&#xff0c;并产生一个滤波后…

MPLS——多协议标签交换

目录 1 多协议标签交换 MPLS 1.1 MPLS 的工作原理 1.1.1 MPLS 工作特点 1.1.2 MPLS 协议的基本原理 1.1.3 MPLS 的基本工作过程 1.2 转发等价类 FEC 1.2.1 FEC 用于负载平衡 1.3 MPLS 首部的位置与格式 1.3.1 MPLS 首部的位置 1.3.2 MPLS 首部的格式 1.4 新一代的…

STM32 HAL NTC(3950 10k)查表法

NTC&#xff08;Negative Temperature Coefficient&#xff09;是指随温度上升电阻呈指数关系减小、具有负温度系数的热敏电阻现象和材料。该材料是利用锰、铜、硅、钴、铁、镍、锌等两种或两种以上的金属氧化物进行充分混合、成型、烧结等工艺而成的半导体陶瓷&#xff0c;可制…

vue项目开发vscode配置

配置代码片段 步骤如下&#xff1a; 文件->首选项->配置用户代码片段新增全局代码片段起全局代码片段文件名“xxx.code-snippets” 这里以配置vue2初始代码片段为例&#xff0c;配置具体代码片段 {"name": "vue-sph","version": "…

modelsim仿真使用到vivado的IP,该如何使用!

modelsim仿真时&#xff0c;如果使用到了vivado的IP就会报错&#xff0c;本次就告诉大家如何将vivado的IP添加到modelsim中直接仿真。 一、生成ini文件以及IP打包 打开vivado&#xff0c;点击上方的Tools-->Compile Simulation Libraries得到如下界面 simulator&#xff1…

【Python基础】案例分析:泰坦尼克分析

泰坦尼克分析 1 目的&#xff1a; 熟悉数据集熟悉seaborn各种操作作 import pandas as pd import seaborn as sns import numpy as np import matplotlib.pyplot as plt %matplotlib inline home rdata df sns.load_dataset(titanic, data_homehome) df.head()survivedpcl…

mmdetection使用自己的voc数据集训练模型实战

一.自己数据集整理 将labelimg格式数据集进行整理 1.1. 更换图片后缀为jpg import os import shutilroot_path/media/ai-developer/imgfileos.listdir(root_path)for img in file:if img.endswith(jpeg) or img.endswith(JPG) or img.endswith(png):img_pathos.path.join(root…

理想汽车学华为,年终奖红包有点大(含算法原题)

理想年终奖红包 2月5日&#xff0c;有微博用户发帖称&#xff0c;脉脉上看到&#xff0c;今年理想汽车的年终奖红包有点大。 对此&#xff0c;李想转发并评论&#xff1a; ❝ 不能只学华为的流程&#xff0c;而不学华为的利益分配。奖罚不分明&#xff0c;是组织低效的最大原因…

C++ lambda [],[=] ,[],[this] 的使用

在c11标准中引入了lambda表达式&#xff0c;一般用于定义匿名函数 [],[] ,[&],[this] 都是捕获列表 [] 的作用&#xff1a; 什么也不捕获 [] 的作用&#xff1a; 按值捕获所有变量 [&] 的作用&#xff1a; 引用捕获所有外部作用域内的变量 [this]的作用&#xf…

怎么理解 Redis 事务

背景 在面试中经常会被问到&#xff0c;redis支持事务吗&#xff1f;事务是怎么实现的&#xff1f;事务会回滚吗&#xff1f;又是一键三连&#xff0c;我下面分析下&#xff0c;看看能不能吊打面试官 什么是Redis事务 事务是一个单独的隔离操作&#xff1a;事务中的所有命令…

企业为什么选择SASE?香港电讯专家给你答案!

2019年&#xff0c;Gartner发布了全新的网络安全模型&#xff1a;安全访问服务边缘&#xff08;Secure Access Service Edge, SASE&#xff09;&#xff0c;并预测到2025年80%的企业将使用SASE/SSE架构统一网络、云服务和私人应用程序的安全访问。那么企业为什么选择SASE&#…

Web课程学习笔记--CSS-Position学习

CSS Position学习 CSS Position有四个属性&#xff1a; relativeabsolutefixedstatic&#xff08;默认&#xff09; 样例 <div id"parent"><div id"sub1">sub1</div><div id"sub2">sub2</div> </div>su…

Git合并多个commit

git rebase -i commitId 假设想要合并最后3个commit&#xff0c; git log显示 commit id 1 commit id 2 commit id 3 commit id 4 则执行git rebase -i commitId4. 注意是4&#xff0c;不是3. 然后&#xff0c;pick最老的commit (commit id 3). https://blog.csdn.net/qiao…

企业计算机服务器中了mallox勒索病毒怎么办,mallox勒索病毒处理流程

由于网络技术的不断发展与应用&#xff0c;越来越多的企业开始依赖计算机技术来提高企业效率。然而&#xff0c;网络安全威胁无处不在&#xff0c;严重影响着企业计算机服务器中的数据安全。近期&#xff0c;云天数据恢复中心接到许多中大型企业的求助&#xff0c;企业的多台服…

Quicker读取浏览器的书签(包括firefox火狐)

从edge换了火狐&#xff0c;但是quicker不能读取本地的bookmarks文件了&#xff0c;就研究了一下。 方法1&#xff1a;读取本地Bookmarks文件&#xff08;仅谷歌内核浏览器&#xff09; 谷歌内核的浏览器本地会有Bookmarks文件&#xff0c;放了所有的书签数据&#xff0c;直接…