当前位置: 首页 > news >正文

Spark使用过程中的 15 个常见问题、详细解决方案

目录

      • 问题 1:Spark 作业超时
        • 问题描述
        • 解决方案
        • Python 实现
      • 问题 2:内存溢出
        • 问题描述
        • 解决方案
        • Python 实现
      • 问题 3:Shuffle 性能问题
        • 问题描述
        • 解决方案
        • Python 实现
      • 问题 4:Spark 作业调度不均
        • 问题描述
        • 解决方案
        • Python 实现
      • 问题 5:任务失败
        • 问题描述
        • 解决方案
        • Python 实现
      • 问题 6:GC 频繁
        • 问题描述
        • 解决方案
        • Python 实现
      • 问题 7:数据倾斜
        • 问题描述
        • 解决方案
        • Python 实现
      • 问题 8:Executor 失败
        • 问题描述
        • 解决方案
        • Python 实现
      • 问题 9:JVM 参数配置不当
        • 问题描述
        • 解决方案
        • Python 实现
      • 问题 10:资源不足导致调度延迟
        • 问题描述
        • 解决方案
        • Python 实现
      • 问题 11:SQL 查询性能差
        • 问题描述
        • 解决方案
        • Python 实现
      • 问题 12:无法读取数据源
        • 问题描述
        • 解决方案
        • Python 实现
      • 问题 13:Zookeeper 配置问题
        • 问题描述
        • 解决方案
        • Python 实现
      • 问题 14:HDFS 数据读取失败
        • 问题描述
        • 解决方案
        • Python 实现
      • 问题 15:Spark 集群失去联系
        • 问题描述
        • 解决方案
        • Python 实现

以下是关于 Spark 使用过程中的 15 个常见问题、详细解决方案及 Python 面向对象代码实现的总结。对于每个问题,给出了实际代码示例和解决方案。


问题 1:Spark 作业超时

问题描述

Spark 作业可能会因为资源不足或任务调度不当而超时。

解决方案
  1. 增加 Spark 的超时时间。
  2. 调整 Spark 的资源分配,确保每个作业都能获得足够的 CPU 和内存。
Python 实现
from pyspark.sql import SparkSessionclass SparkJobTimeoutConfig:def __init__(self, spark):self.spark = sparkdef update_timeout(self, spark_conf, timeout_ms):print(f"设置 Spark 作业超时为 {timeout_ms} 毫秒。")self.spark.conf.set(spark_conf, timeout_ms)# 示例
spark = SparkSession.builder.appName("TimeoutExample").getOrCreate()
configurer = SparkJobTimeoutConfig(spark)
configurer.update_timeout("spark.network.timeout", 120000)  # 设置超时为120秒

问题 2:内存溢出

问题描述

Spark 作业可能由于内存配置不足而导致内存溢出。

解决方案
  1. 增加 executor 的内存,使用 spark.executor.memory 配置。
  2. 增加分区数,减少单个任务的内存占用。
Python 实现
class SparkMemoryConfig:def __init__(self, spark):self.spark = sparkdef configure_memory(self, memory_size):print(f"配置每个 Executor 的内存为 {memory_size}。")self.spark.conf.set("spark.executor.memory", memory_size)# 示例
spark = SparkSession.builder.appName("MemoryConfigExample").getOrCreate()
memory_configurer = SparkMemoryConfig(spark)
memory_configurer.configure_memory("4g")

问题 3:Shuffle 性能问题

问题描述

Spark 在进行 shuffle 操作时,性能可能会显著下降,尤其是在大规模数据集下。

解决方案
  1. 增加 shuffle 文件的压缩。
  2. 调整 shuffle 的分区数,避免过多或过少的分区。
Python 实现
class ShuffleOptimizer:def __init__(self, spark):self.spark = sparkdef optimize_shuffle(self, shuffle_partitions=200, shuffle_compression="snappy"):print(f"设置 shuffle 分区数为 {shuffle_partitions} 和压缩格式为 {shuffle_compression}。")self.spark.conf.set("spark.sql.shuffle.partitions", shuffle_partitions)self.spark.conf.set("spark.shuffle.compress", "true")self.spark.conf.set("spark.shuffle.spill.compress", "true")self.spark.conf.set("spark.io.compression.codec", shuffle_compression)# 示例
spark = SparkSession.builder.appName("ShuffleOptimization").getOrCreate()
shuffle_optimizer = ShuffleOptimizer(spark)
shuffle_optimizer.optimize_shuffle(shuffle_partitions=300, shuffle_compression="lz4")

问题 4:Spark 作业调度不均

问题描述

Spark 作业调度不均可能导致一些节点被过度利用,而其他节点处于空闲状态。

解决方案
  1. 使用 Fair SchedulerCapacity Scheduler 进行作业调度。
  2. 调整 spark.scheduler.mode 参数,选择公平调度或容量调度模式。
Python 实现
class SchedulerConfig:def __init__(self, spark):self.spark = sparkdef configure_scheduler(self, scheduler_mode="FAIR"):print(f"设置 Spark 调度模式为 {scheduler_mode}。")self.spark.conf.set("spark.scheduler.mode", scheduler_mode)# 示例
spark = SparkSession.builder.appName("SchedulerConfigExample").getOrCreate()
scheduler_config = SchedulerConfig(spark)
scheduler_config.configure_scheduler(scheduler_mode="FAIR")

问题 5:任务失败

问题描述

Spark 任务失败可能是由于资源不足、数据损坏或代码错误导致的。

解决方案
  1. 增加任务的重试次数,使用 spark.task.maxFailures 配置。
  2. 调整 spark.speculation 配置启用任务推测执行。
Python 实现
class TaskFailureHandler:def __init__(self, spark):self.spark = sparkdef set_retry_policy(self, max_failures=4, enable_speculation=True):print(f"设置任务最大重试次数为 {max_failures},启用推测执行: {enable_speculation}")self.spark.conf.set("spark.task.maxFailures", max_failures)self.spark.conf.set("spark.speculation", enable_speculation)# 示例
spark = SparkSession.builder.appName("TaskFailureHandler").getOrCreate()
failure_handler = TaskFailureHandler(spark)
failure_handler.set_retry_policy(max_failures=6, enable_speculation=True)

问题 6:GC 频繁

问题描述

频繁的垃圾回收 (GC) 会影响 Spark 作业的性能。

解决方案
  1. 调整 Spark 的内存设置,确保每个任务使用的内存合理。
  2. 增加 executor 的数量,减少每个 executor 的内存压力。
Python 实现
class GCOptimizer:def __init__(self, spark):self.spark = sparkdef adjust_gc_settings(self, executor_cores=2, executor_memory="2g"):print(f"调整 GC 设置,executor 核心数为 {executor_cores},内存为 {executor_memory}。")self.spark.conf.set("spark.executor.cores", executor_cores)self.spark.conf.set("spark.executor.memory", executor_memory)# 示例
spark = SparkSession.builder.appName("GCOptimization").getOrCreate()
gc_optimizer = GCOptimizer(spark)
gc_optimizer.adjust_gc_settings(executor_cores=4, executor_memory="4g")

问题 7:数据倾斜

问题描述

Spark 中的某些操作(如 join、groupBy)可能导致数据倾斜,导致部分任务处理数据过多而其他任务几乎没有数据。

解决方案
  1. 对数据进行分区,使用 salting 技术进行均衡。
  2. 使用 broadcast 变量进行广播小表以避免数据倾斜。
Python 实现
class DataSkewHandler:def __init__(self, spark):self.spark = sparkdef handle_skew(self, df):print("处理数据倾斜,使用广播变量优化 join 操作。")# 假设 `small_df` 是一个小表small_df = self.spark.read.parquet("/path/to/small_df")broadcasted_df = self.spark.broadcast(small_df)result_df = df.join(broadcasted_df, on="key", how="left")return result_df# 示例
spark = SparkSession.builder.appName("DataSkewExample").getOrCreate()
df = spark.read.parquet("/path/to/large_df")
skew_handler = DataSkewHandler(spark)
result = skew_handler.handle_skew(df)

问题 8:Executor 失败

问题描述

Executor 失败可能由于内存溢出、硬件故障或长时间运行的任务。

解决方案
  1. 增加 executor 的内存配置,使用 spark.executor.memory 配置。
  2. 设置合适的任务分配,避免 executor 资源过载。
Python 实现
class ExecutorFailureHandler:def __init__(self, spark):self.spark = sparkdef configure_executor(self, memory_size="4g", cores=2):print(f"配置 executor 内存为 {memory_size},核心数为 {cores}。")self.spark.conf.set("spark.executor.memory", memory_size)self.spark.conf.set("spark.executor.cores", cores)# 示例
spark = SparkSession.builder.appName("ExecutorFailureExample").getOrCreate()
executor_handler = ExecutorFailureHandler(spark)
executor_handler.configure_executor(memory_size="6g", cores=4)

问题 9:JVM 参数配置不当

问题描述

Spark 的 JVM 参数配置不当,可能会影响性能或导致任务失败。

解决方案

通过 spark.driver.extraJavaOptionsspark.executor.extraJavaOptions 配置 JVM 参数。

Python 实现
class JVMConfig:def __init__(self, spark):self.spark = sparkdef configure_jvm(self, java_options="-Xmx4g"):print(f"配置 JVM 参数: {java_options}")self.spark.conf.set("spark.driver.extraJavaOptions", java_options)self.spark.conf.set("spark.executor.extraJavaOptions", java_options)# 示例
spark = SparkSession.builder.appName("JVMConfigExample").getOrCreate()
jvm_configurer = JVMConfig(spark)
jvm_configurer.configure_jvm(java_options="-Xmx8g")

问题 10:资源不足导致调度延迟

问题描述

Spark 作业可能因为资源不足,导致调度延迟,影响作业执行时间。

解决方案
  1. 增加集群的资源,确保足够的 executor 和内存。
  2. 使用动态资源分配 (spark.dynamicAllocation.enabled) 来提高资源利用率。
Python 实现
class ResourceAllocation:def __init__(self, spark):self.spark = sparkdef enable_dynamic_allocation(self, min_executors=2, max_executors=10):print(f"启用动态资源分配,最小 Executors 为 {min_executors},最大 Executors 为 {max_executors}。")self.spark.conf.set("spark.dynamicAllocation.enabled", "true")self.spark.conf.set("spark.dynamicAllocation.minExecutors", min_executors)self.spark.conf.set("spark.dynamicAllocation.maxExecutors", max_executors)# 示例
spark = SparkSession.builder.appName("ResourceAllocationExample").getOrCreate()
resource_allocator = ResourceAllocation(spark)
resource_allocator.enable_dynamic_allocation(min_executors=3, max_executors=15)

问题 11:SQL 查询性能差

问题描述

SQL 查询执行时性能较差,尤其是在大数据量下。

解决方案
  1. 使用 cache()persist() 方法缓存数据。
  2. 调整 Spark SQL 配置,优化查询性能。
Python 实现
class SQLPerformanceOptimizer:def __init__(self, spark):self.spark = sparkdef optimize_sql(self, df):print("优化 SQL 查询,缓存数据。")df.cache()df.show()# 示例
spark = SparkSession.builder.appName("SQLPerformanceExample").getOrCreate()
df = spark.read.parquet("/path/to/data")
optimizer = SQLPerformanceOptimizer(spark)
optimizer.optimize_sql(df)

问题 12:无法读取数据源

问题描述

Spark 可能无法读取数据源,可能是因为数据路径错误、格式不支持等问题。

解决方案
  1. 确保数据路径正确,并且 Spark 支持该格式。
  2. 使用适当的读取方法(如 .csv(), .parquet())指定格式。
Python 实现
class DataSourceReader:def __init__(self, spark):self.spark = sparkdef read_data(self, file_path, format="parquet"):print(f"读取 {format} 格式的数据:{file_path}")if format == "parquet":return self.spark.read.parquet(file_path)elif format == "csv":return self.spark.read.csv(file_path, header=True, inferSchema=True)# 示例
spark = SparkSession.builder.appName("DataSourceExample").getOrCreate()
reader = DataSourceReader(spark)
df = reader.read_data("/path/to/data", format="csv")

问题 13:Zookeeper 配置问题

问题描述

Zookeeper 配置不当会影响 Spark 集群的协调和容错能力。

解决方案
  1. 配置正确的 Zookeeper 地址和端口。
  2. 调整 spark.zookeeper.url 配置,确保节点间通信稳定。
Python 实现
class ZookeeperConfig:def __init__(self, spark):self.spark = sparkdef configure_zookeeper(self, zk_url="localhost:2181"):print(f"设置 Zookeeper 地址为 {zk_url}。")self.spark.conf.set("spark.zookeeper.url", zk_url)# 示例
spark = SparkSession.builder.appName("ZookeeperConfigExample").getOrCreate()
zk_configurer = ZookeeperConfig(spark)
zk_configurer.configure_zookeeper(zk_url="zookeeper1:2181")

问题 14:HDFS 数据读取失败

问题描述

Spark 读取 HDFS 数据时可能因权限或路径错误导致失败。

解决方案
  1. 检查文件路径,确保路径正确。
  2. 检查 HDFS 文件权限,确保 Spark 有读取权限。
Python 实现
class HDFSReader:def __init__(self, spark):self.spark = sparkdef read_hdfs_data(self, hdfs_path):print(f"读取 HDFS 数据:{hdfs_path}")return self.spark.read.parquet(hdfs_path)# 示例
spark = SparkSession.builder.appName("HDFSReadExample").getOrCreate()
hdfs_reader = HDFSReader(spark)
df = hdfs_reader.read_hdfs_data("hdfs://namenode/path/to/data")

问题 15:Spark 集群失去联系

问题描述

Spark 集群的节点可能因为网络故障或配置错误导致失去联系。

解决方案
  1. 检查 Spark 集群配置文件,确保所有节点的配置一致。
  2. 检查网络连接,确保节点间的通信通畅。
Python 实现
class ClusterHealthChecker:def __init__(self, spark):self.spark = sparkdef check_cluster_health(self):print("检查 Spark 集群健康状态。")status = self.spark.sparkContext.statusTracker()print(status)# 示例
spark = SparkSession.builder.appName("ClusterHealthCheck").getOrCreate()
health_checker = ClusterHealthChecker(spark)
health_checker.check_cluster_health()

这些是 Spark 中常见的 15 个问题、分析及解决方案。通过面向对象的设计,给出了解决问题的实现方式和代码示例,帮助开发者更加高效地配置、调优和排除故障。

相关文章:

Spark使用过程中的 15 个常见问题、详细解决方案

目录 问题 1:Spark 作业超时问题描述解决方案Python 实现 问题 2:内存溢出问题描述解决方案Python 实现 问题 3:Shuffle 性能问题问题描述解决方案Python 实现 问题 4:Spark 作业调度不均问题描述解决方案Python 实现 问题 5&…...

算法【最长递增子序列问题与扩展】

本文讲解最长递增子序列以及最长不下降子序列的最优解,以及一些扩展题目。本文中讲述的是最优解,时间复杂度是O(n*logn),空间复杂度O(n),好实现、理解难度不大。这个问题也可以用线段树来求解,时间和空间复杂度和本节讲…...

k8s篇之flannel网络模型详解

在 Kubernetes (K8s) 中,Flannel 是一种常用的网络插件,用于实现容器之间的网络通信。Flannel 提供了一种覆盖网络(Overlay Network)模型,使得容器可以跨多个主机进行通信。 以下是 Flannel 在 Kubernetes 中的详细工作原理和覆盖网络模型的详解: 1.Flannel 简介 Flann…...

windows 和 linux检查操作系统基本信息

windows检查操作系统基本信息 systeminfolinux检查操作系统基本信息 获取系统位数 getconf LONG_BIT查询操作系统release信息 lsb_release -a查询系统信息 cat /etc/issue查询系统名称 uname -a...

Oracle OCP认证考试考点详解082系列22

题记: 本系列主要讲解Oracle OCP认证考试考点(题目),适用于19C/21C,跟着学OCP考试必过。 105. 第105题: 题目 解析及答案: 题目翻译: 关于Oracle数据库中的事务请选择两个正确的陈述&#xf…...

线性回归 - 最小二乘法

线性回归 一 简单的线性回归应用 webrtc中的音视频同步。Sender Report数据包 NTP Timestamp(网络时间协议时间戳):这是一个64位的时间戳,记录着发送SR的NTP时间戳,用于同步不同源之间的时间。RTP Timestamp&#xff1…...

Linux - 线程基础

文章目录 1.什么是线程2.线程vs进程3.线程调度4.线程控制4.1 POSIX线程库4.2创建线程4.3线程终止4.4线程等待4.5线程分离 5、线程封装 1.什么是线程 在Linux操作系统中,线程是进程内部的一个执行流。在Linux操作系统下,执行流统称为轻量级进程&#xff0…...

网络爬虫——分布式爬虫架构

分布式爬虫在现代大数据采集中是不可或缺的一部分。随着互联网信息量的爆炸性增长,单机爬虫在性能、效率和稳定性上都面临巨大的挑战。分布式爬虫通过任务分发、多节点协作以及结果整合,成为解决大规模数据抓取任务的核心手段。 本节将从 Scrapy 框架的…...

RT_Thread内核源码分析(三)——线程

目录 1. 线程结构 2. 线程创建 2.1 静态线程创建 2.2 动态线程创建 2.3 源码分析 2.4 线程内存结构 3. 线程状态 3.1 线程状态分类 3.2 就绪状态和运行态 3.3 阻塞/挂起状态 3.3.1 阻塞工况 3.4 关闭状态 3.4.1 线程关闭接口 3.4.2 静态线程关闭 3.4.3 动态线程关…...

正排索引和倒排索引

一、简介 正排索引:一个未经处理的数据库中,一般是以文档ID作为索引,以文档内容作为记录。 倒排索引:Inverted index,指的是将单词或记录作为索引,将文档ID作为记录,这样便可以方便地通过单词或…...

丹摩 | 重返丹摩(上)

目录 一.登录平台 二. 数据管理与预处理 1.数据清洗 2.数据格式转换 3.特征工程 二.数据可视化 1.快速可视化 2.数据洞察 3.自定义视图 三.技术支持与帮助 1.技术支持 (1). 帮助文档 (2). 用户社区 2.客服支持 (1). 在线客服 (2). 反馈与建议 总结 一.登录平台…...

Frontend - 防止多次请求,避免重复请求

目录 一、避免重复执行的多种情况 (一)根据用途 (二)根据用户操作 二、具体实现 (一)“Ajax ”结合disabled (防止多次请求),避免多次点击重复请求 1. 适用场景 2. 解决办法 3. 示例 &…...

RHCE的学习(22)

第四章 流程控制之条件判断 条件判断语句是一种最简单的流程控制语句。该语句使得程序根据不同的条件来执行不同的程序分支。本节将介绍Shell程序设计中的简单的条件判断语句。 if语句语法 单分支结构 # 语法1&#xff1a; if <条件表达式> then指令 fi #语法2&#x…...

【前端知识】简单讲讲什么是微前端

微前端介绍 一、定义二、背景三、核心思想四、基本要素五、核心价值六、实现方式七、应用场景八、挑战与解决方案 什么是single-spa一、核心特点二、核心原理三、应用加载流程四、最佳实践五、优缺点六、应用场景 什么是 qiankun一、概述二、特点与优势三、核心功能四、使用场景…...

AWS IAM

一、介绍 1、简介 AWS Identity and Access Management (IAM) 是 Amazon Web Services 提供的一项服务,用于管理 AWS 资源的访问权限。通过 IAM,可以安全地控制用户、组和角色对 AWS 服务和资源的访问权限。IAM 是 AWS 安全模型的核心组成部分,确保只有经过授权的用户和应…...

丹摩|丹摩助力selenium实现大麦网抢票

丹摩&#xff5c;丹摩助力selenium实现大麦网抢票 声明&#xff1a;非广告&#xff0c;为用户体验 1.引言 在人工智能飞速发展的今天&#xff0c;丹摩智算平台&#xff08;DAMODEL&#xff09;以其卓越的AI算力服务脱颖而出&#xff0c;为开发者提供了一个简化AI开发流程的强…...

基于Qt/C++/Opencv实现的一个视频中二维码解析软件

本文详细讲解了如何利用 Qt 和 OpenCV 实现一个可从视频和图片中检测二维码的软件。代码实现了视频解码、多线程处理和界面更新等功能&#xff0c;是一个典型的跨线程图像处理项目。以下分模块对代码进行解析。 一、项目的整体结构 项目分为以下几部分&#xff1a; 主窗口 (M…...

智慧理财项目测试文档

目录 幕布思维导图链接&#xff1a;https://www.mubu.com/doc/6xk3c7DzgFs学习链接&#xff1a;https://www.bilibili.com/video/BV15J4m147vZ/?spm_id_from333.999.0.0&vd_source078d5d025b9cb472d70d8fda1a7dc5a6智慧理财项目测试文档项目介绍项目基本信息项目业务特性系…...

R | 统一栅格数据的坐标系、分辨率和行列号

各位同学&#xff0c;在做相关性等分析时&#xff0c;经常会遇到各栅格数据间的行列号不统一等问题&#xff0c;下面的代码能直接解决这类麻烦。以某个栅格数据的坐标系、分辨率和行列号为准&#xff0c;统一文件夹内所有栅格并输出到新的文件夹。 代码只需要更改输入输出和ti…...

C++学习——编译的过程

编译的过程——预处理 引言预处理包含头文件宏定义指令条件编译 编译、链接 引言 C程序编译的过程&#xff1a;预处理 -> 编译&#xff08;优化、汇编&#xff09;-> 链接 编译和链接的内容可以查阅这篇文章&#xff08;点击查看&#xff09; 预处理 编译预处理是指&a…...

UE5 学习系列(二)用户操作界面及介绍

这篇博客是 UE5 学习系列博客的第二篇&#xff0c;在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下&#xff1a; 【Note】&#xff1a;如果你已经完成安装等操作&#xff0c;可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作&#xff0c;重…...

云原生核心技术 (7/12): K8s 核心概念白话解读(上):Pod 和 Deployment 究竟是什么?

大家好&#xff0c;欢迎来到《云原生核心技术》系列的第七篇&#xff01; 在上一篇&#xff0c;我们成功地使用 Minikube 或 kind 在自己的电脑上搭建起了一个迷你但功能完备的 Kubernetes 集群。现在&#xff0c;我们就像一个拥有了一块崭新数字土地的农场主&#xff0c;是时…...

MySQL 隔离级别:脏读、幻读及不可重复读的原理与示例

一、MySQL 隔离级别 MySQL 提供了四种隔离级别,用于控制事务之间的并发访问以及数据的可见性,不同隔离级别对脏读、幻读、不可重复读这几种并发数据问题有着不同的处理方式,具体如下: 隔离级别脏读不可重复读幻读性能特点及锁机制读未提交(READ UNCOMMITTED)允许出现允许…...

Day131 | 灵神 | 回溯算法 | 子集型 子集

Day131 | 灵神 | 回溯算法 | 子集型 子集 78.子集 78. 子集 - 力扣&#xff08;LeetCode&#xff09; 思路&#xff1a; 笔者写过很多次这道题了&#xff0c;不想写题解了&#xff0c;大家看灵神讲解吧 回溯算法套路①子集型回溯【基础算法精讲 14】_哔哩哔哩_bilibili 完…...

前端导出带有合并单元格的列表

// 导出async function exportExcel(fileName "共识调整.xlsx") {// 所有数据const exportData await getAllMainData();// 表头内容let fitstTitleList [];const secondTitleList [];allColumns.value.forEach(column > {if (!column.children) {fitstTitleL…...

【算法训练营Day07】字符串part1

文章目录 反转字符串反转字符串II替换数字 反转字符串 题目链接&#xff1a;344. 反转字符串 双指针法&#xff0c;两个指针的元素直接调转即可 class Solution {public void reverseString(char[] s) {int head 0;int end s.length - 1;while(head < end) {char temp …...

【AI学习】三、AI算法中的向量

在人工智能&#xff08;AI&#xff09;算法中&#xff0c;向量&#xff08;Vector&#xff09;是一种将现实世界中的数据&#xff08;如图像、文本、音频等&#xff09;转化为计算机可处理的数值型特征表示的工具。它是连接人类认知&#xff08;如语义、视觉特征&#xff09;与…...

MySQL中【正则表达式】用法

MySQL 中正则表达式通过 REGEXP 或 RLIKE 操作符实现&#xff08;两者等价&#xff09;&#xff0c;用于在 WHERE 子句中进行复杂的字符串模式匹配。以下是核心用法和示例&#xff1a; 一、基础语法 SELECT column_name FROM table_name WHERE column_name REGEXP pattern; …...

什么?连接服务器也能可视化显示界面?:基于X11 Forwarding + CentOS + MobaXterm实战指南

文章目录 什么是X11?环境准备实战步骤1️⃣ 服务器端配置(CentOS)2️⃣ 客户端配置(MobaXterm)3️⃣ 验证X11 Forwarding4️⃣ 运行自定义GUI程序(Python示例)5️⃣ 成功效果![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/55aefaea8a9f477e86d065227851fe3d.pn…...

JVM 内存结构 详解

内存结构 运行时数据区&#xff1a; Java虚拟机在运行Java程序过程中管理的内存区域。 程序计数器&#xff1a; ​ 线程私有&#xff0c;程序控制流的指示器&#xff0c;分支、循环、跳转、异常处理、线程恢复等基础功能都依赖这个计数器完成。 ​ 每个线程都有一个程序计数…...