Kafka使用指南

    • Kafka简介
    • 架构设计
      • Kafka的架构设计关键概念
      • Kafka的架构设计关键机制
    • Partition介绍
      • Partition工作机制
    • 应用场景
    • ACK机制介绍
    • ACK机制原理
    • ACK机制对性能的影响
    • ACK控制粒度
    • Kafka分区数对集群性能影响
    • 调整分区优化集群性能
    • 拓展
      • Kafka数据全局有序

Kafka简介

Kafka是由Apache软件基金会开发的一个开源流处理平台,由Scala和Java编写。它是一种高吞吐量的分布式发布订阅消息系统,可以处理消费者在网站中的所有动作流数据。这些数据通常是由于吞吐量的要求而通过处理日志和日志聚合来解决。对于像Hadoop一样的日志数据和离线分析系统,但又要求实时处理的限制,这是一个可行的解决方案。Kafka的目的是通过Hadoop的并行加载机制来统一线上和离线的消息处理,也是为了通过集群来提供实时的消息。

Kafka中的消息被归类为不同的主题,每个主题有若干个分区。当有新消息时,它们会以追加的形式写入分区。由于主题可能有多个分区,因此在整个主题范围内,无法保证消息的顺序。分区可以分布在不同的服务器上,实现数据冗余和伸缩。消费者可以订阅一个或多个主题,并保存消息以进行处理。

Kafka在处理大型数据流方面表现出色,它可以存储和持续处理大型的数据流。它类似于消息中间件,但与传统的消息中间件有很大的差异。传统的消息中间件只会传递数据,而Kafka的流处理能力可以让我们高效地处理数据。

Kafka是一个强大的开源流处理平台,可以用于处理大规模的数据流,并支持实时数据处理。它在现代网络中的许多社会功能中发挥着关键作用。

在这里插入图片描述

架构设计

在这里插入图片描述

Kafka的架构设计关键概念

  1. 生产者(Producer) :负责创建消息,然后投递到Kafka集群中。生产者需要指定消息所属的主题,同时确定好发往哪个分区。
  2. 消费者(Consumer) :根据它所订阅的主题以及所属的消费组,决定从哪些分区中拉取消息。
  3. Broker :消息服务器,可水平扩展,负责分区管理、消息的持久化、故障自动转移等。一个集群由多个Broker组成,一个Broker可以容纳多个主题。
  4. 分区(Partition) :为了实现扩展性,一个非常大的主题可以分布到多个Broker上,每个Partition是一个有序的队列。
  5. 消费组(Consumer Group) :这是Kafka用来实现一个Topic消息的广播(发给所有的Consumer)和单播(发给任意一个Consumer)的手段。一个Topic可以有多个Consumer Group。
  6. Zookeeper :负责集群的元数据管理等功能,比如集群中有哪些broker节点以及Topic,每个Topic又有哪些Partition等。
  7. 主题(Topic) :Topic是Kafka中的一个核心概念,它代表了一类消息,可以被认为是消息被发送到的地方。在Kafka中,每个Topic都由多个Partition组成,Partition是不可修改的有序消息序列,也可以说是消息日志。每个Partition都有自己专属的Partition号,通常是从0开始的,用户对Partition唯一的操作就是在消息序列尾部追加写入消息。Partition上的每条消息都会被分配一个唯一的序列号,该序列号被称为位移(offset)。通常可以使用Topic来区分实际业务,Kafka中的Topic通常会被多个消费者订阅,因此出于性能考虑,kafka并不是Topic-meaaage的两极结构,而是采用了Topic-partition-message的三级结构来分散负载。
  8. 主节点(Leader) : 在Kafka中,每个Topic的Partition都有一个Leader和一个或多个Follower。Leader是处理所有读写请求的Partition,而Follower则复制Leader的数据以保持与Leader的同步。每个Partition都有一个Leader,负责处理该Partition的所有读写请求。Kafka通过选举机制来确定每个Partition的Leader。在Kafka集群中,每个Broker都会参与Leader选举过程。当一个Broker出现故障时,Kafka会自动进行Leader选举以确保数据的高可用性。选举过程中,Kafka会选择一个可用的Broker作为新的Leader,以确保集群的正常运行。需要注意的是,在Kafka中,每个Partition只能有一个Leader,但可以有多个Follower。这种设计确保了数据的一致性和可靠性,因为所有的读写请求都必须通过Leader来处理。同时,Follower可以复制Leader的数据,并在Leader出现故障时接管其角色,从而确保数据的高可用性。
  9. 从节点(Follower) : Follower Partition是Kafka中的一种特殊类型的Partition,它与Leader Partition一起构成了Kafka的分布式存储系统。在Kafka中,每个Partition都有一个Leader和若干个Follower。Leader是处理所有读写请求的Partition,而Follower则实时从Leader中同步数据,保持和Leader数据的同步。当Leader发生故障时,某个Follower会成为新的Leader。Follower Partition的主要作用是备份数据和扩展集群规模。在正常状态下,Follower Partition会从Leader Partition中同步数据,并保持与Leader Partition的数据一致性。当Leader Partition发生故障时,Follower Partition会成为新的Leader,继续为消费者提供服务。此外,当集群规模需要扩展时,可以增加Follower Partition的数量来提高集群的存储能力和吞吐量。

Kafka的架构设计关键机制

  1. 消息持久化 :Kafka支持消息持久化,消费端为拉模型来拉取数据,消费状态和订阅关系有客户端负责维护,消息消费完后,不会立即删除,会保留历史消息。
  2. 分布式机制 :Kafka的分布式机制包括生产者、消费者和代理三部分。生产者可以发送消息至Kafka集群,以供后续的消费者进行消费。消费者可以从Kafka集群中读取数据并对其进行响应的操作。代理是Kafka集群的关键组件之一,它主要负责消息的存储和转发,并通过分布式机制保障Kafka集群的故障恢复能力和高可用性。
  3. 高度可扩展的架构设计 :Kafka基于高度可扩展的架构设计,支持任意数量的生产者和消费者,可以针对不同领域的数据模型、处理技术等进行选择和组合。
  4. 消息流处理 :Kafka提供了一个流处理平台,允许应用程序充当流处理器(stream processor),从一个或者多个主题获取输入流,并生产一个输出流到一个或多个主题,能够有效的变化输入流为输出流。
  5. 连接器API :Kafka提供了连接器API,允许构建和运行可重用的生产者或者消费者,能够把kafka主题连接到现有的应用程序或数据系统。例如:一个连接到关系数据库的连接器可能会获取每个表的变化。

Kafka的架构设计涵盖了多个关键部分,这些部分协同工作,使得Kafka成为一个高效、可扩展、可靠的分布式消息系统。

Partition介绍

Kafka的Partition是一个逻辑概念,是消息在Kafka中的存储单位,也是消息被分发的单位。每个Topic被分成多个Partition,分布在不同的Broker服务器上。

Partition有几个重要的特性:

  1. Partition中的消息是有序的,同一个Partition内的消息会按照发送的顺序进行存储。
  2. Partition是Kafka中消息存储的最小单位,掌握着一个Topic的部分数据。每个Partition都是一个单独的log文件,每条记录都以追加的形式写入。
  3. Kafka集群中的每个Partition都有且只有一个Leader和零个或多个Follower。在正常状态下,Producer和Consumer只与Leader交互,所有的读写请求都必须通过Leader来处理。当Leader发生故障时,某个Follower会成为新的Leader。
  4. Kafka的负载均衡和扩展性很大程度上取决于Partition的数量和分布。为了实现负载均衡,建议将Partition的数量设置为Broker的倍数。
  5. Kafka Producer会将消息发送到指定的Topic的Partition,而Consumer则会从指定的Partition中消费消息。

Partition工作机制

Kafka的Partition是Kafka中消息存储和分发的单位,主要负责消息的存储和管理。以下是Partition在Kafka中的工作方式:

  1. 创建Partition :在创建Topic时,可以指定Partition的数量。一般来说,Partition的数量通常设为Broker节点数的整数倍,这样可以保证分区数据均匀地分配到集群中,并最大化的提升并行读写效率。
  2. 生产者写入Partition :生产者在向某个Topic发送消息时,会根据分配策略将消息发送到对应的Partition。分配策略可以是基于Partition key值进行哈希决定写入哪个Partition,也可以是采用轮询的方式均匀地写入到各个Partition。需要注意的是,如果指定了Partition key值,可能会出现热点数据问题。
  3. 消费者消费Partition :消费者订阅消费一个Topic时,会从该Topic的所有Partition中消费消息。每个Partition的消费组只能由一个消费者组中的一个消费者进行消费,因此可以说Partition是消费并行度的基本单位。从消费者的角度来看,订阅消费了一个Topic,也就订阅了该Topic的所有Partition。
  4. Partition的复制和故障转移 :Kafka的每个Partition都有一个Leader和零个或多个Follower。在正常状态下,Producer和Consumer只与Leader交互,所有的读写请求都必须通过Leader来处理。当Leader发生故障时,某个Follower会成为新的Leader。

Kafka的Partition是Kafka中实现负载均衡、扩展性和可靠性的关键组件之一。通过合理的设置和调整Partition的数量和分布,可以提高Kafka集群的性能和可靠性。

应用场景

  1. 实时数据流处理 :Kafka可以作为数据流处理的中间件,用于接收和传输大量的实时数据。它可以接收来自不同数据源的数据,并将其传输到不同的数据处理系统,如Apache Storm、Apache Flink等。通过使用Kafka,可以实现高吞吐量和低延迟的实时数据处理。
  2. 日志收集与分析 :Kafka可以用于集中式的日志收集和分析。许多应用程序和系统会生成大量的日志数据,使用Kafka可以将这些日志数据集中存储,并提供给日志分析工具进行实时或离线的分析。通过将日志数据发送到Kafka主题中,可以实现高效的日志收集和处理。
  3. 消息系统 :Kafka可以作为消息系统的一种替代方案。它具有更好的吞吐量、内置分区、副本和故障转移等特性,有利于处理大规模的消息。与传统的消息系统(如ActiveMQ或RabbitMQ)相比,Kafka在处理低延迟、高吞吐量的场景下更具优势。
  4. 网站活动追踪 :Kafka原本的使用场景之一是用户的活动追踪。网站的活动(如网页浏览、搜索或其他用户操作信息)可以发布到不同的主题中心,这些消息可实时处理、实时监测,也可加载到Hadoop或离线处理数据仓库。每个用户页面视图都会产生非常高的数据量,Kafka能够高效地处理这些数据。
  5. 指标监测 :Kafka也常用于监测数据。分布式应用程序生成的统计数据可以在Kafka中进行集中聚合,以便实时监测和分析。
  6. 日志聚合 :Kafka可以作为日志聚合的解决方案。通过将日志数据发送到Kafka主题中,可以实现高效的日志收集和处理。
  7. 事件采集 :Kafka可以用于事件采集,将各种事件数据(如用户行为事件、系统事件等)采集到Kafka主题中,以便后续处理和分析。

Kafka的应用场景非常广泛,包括但不限于实时数据处理、日志收集与分析、消息系统、网站活动追踪、指标监测、日志聚合和事件采集等。

ACK机制介绍

在Kafka中,ACK(acknowledgment)机制用于确认生产者发送的消息是否成功被Kafka服务器接收并存储。这是确保消息可靠性的重要机制。

Kafka提供了三种不同级别的消息确认机制,可以根据需求进行选择:

  1. ACK 级别 0 :生产者发送消息后,不会等待任何服务器的确认,直接认为消息发送成功。这种方式下,可能会出现消息丢失的情况。
  2. ACK 级别 1 :生产者发送消息后,会等待 leader 副本(partition 的 leader)确认消息后,认为消息发送成功。这种方式下,如果 leader 副本在确认消息前宕机,可能会导致消息丢失。
  3. ACK 级别 -1 或 all :生产者发送消息后,会等待所有的副本(包括 leader 和 follower)都确认消息后,认为消息发送成功。这种方式下,消息的可靠性最高,但是会对性能产生一定的影响。

选择合适的 ACK 级别取决于对消息可靠性和性能的要求。如果对消息的可靠性要求较高,可以选择 -1 或 all 级别,但需要考虑性能损耗。如果对消息的可靠性要求不高,可以选择 1 或 0 级别,以提高性能。

总的来说,ACK机制的优点是可以确保消息的可靠性,通过等待确认,生产者可以知道消息是否成功处理,从而保证数据的一致性。然而,ACK机制也存在一些缺点,例如延迟和服务器负载问题。需要根据具体的应用场景和需求来选择合适的ACK级别。

除了ACK级别外,Kafka还通过以下方式保证ACK机制的可靠性:

  • 数据复制 :Kafka通过将数据复制到多个副本(partition)中,确保数据的安全性和可靠性。即使某个副本出现问题,其他副本仍然可以正常工作。
  • 消息持久化 :Kafka将消息持久化到磁盘上,确保即使在服务器崩溃的情况下,消息也不会丢失。
  • 数据校验 :Kafka在存储和传输数据时使用校验和(checksum)等技术来检测数据完整性,确保数据的正确性和一致性。
  • 事务支持 :Kafka支持事务,可以在生产者发送消息时保证消息的可靠性。事务可以确保在写入数据之前进行验证和提交,避免因未提交的事务导致的数据不一致问题。
  • 参数配置 :Kafka提供了许多参数来配置ACK机制的可靠性,例如min.insync.replicas、unclean.leader.election.enable等参数。这些参数可以用来控制消息的确认机制和副本同步等行为,以确保数据的可靠性和一致性。

Kafka通过多种机制和参数配置来保证ACK机制的可靠性。在实际应用中,需要根据具体的应用场景和需求来选择合适的ACK级别和配置参数,以实现可靠的消息传递。

ACK机制原理

在Kafka中,ACK机制的原理是确认生产者发送的消息是否成功被Kafka服务器接收并存储。当生产者发送消息后,会向Kafka的代理服务器发送一个ACK(Acknowledgement)确认消息已经被发送。Kafka代理服务器在收到ACK后,会将该消息标记为已接收,然后从分区中删除。如果Kafka代理服务器在一定时间内没有收到ACK确认消息,则会将该消息重新发送给其他生产者,以确保消息的可靠性传递。

ACK机制的可靠性取决于选择的ACK级别。ACK级别为0时,生产者认为消息发送成功,无需等待服务器的确认,可能会出现消息丢失的情况。ACK级别为1时,生产者需要等待leader副本的确认,如果leader副本在确认消息前宕机,可能会导致消息丢失。ACK级别为-1或all时,生产者需要等待所有的副本(包括leader和follower)都确认消息后,才认为消息发送成功,消息的可靠性最高,但会对性能产生一定的影响。

Kafka中的ACK机制原理是生产者发送消息后向Kafka代理服务器发送ACK确认消息已经被发送,代理服务器收到ACK后将消息标记为已接收并删除。通过选择合适的ACK级别和配置参数,可以确保消息的可靠性和一致性。

ACK机制对性能的影响

首先,ACK机制影响吞吐量。ACK级别越高,吞吐量可能越低。这是因为当生产者发送消息并等待确认时,必须等待所有相关副本(包括leader和follower)都确认消息,这会增加延迟。相反,如果ACK级别较低,生产者可能不必等待所有副本的确认,从而提高了吞吐量。

其次,ACK机制影响消息的可靠性。较高的ACK级别可以提高消息的可靠性,因为消息被更多的副本确认。然而,这也可能增加复制延迟和降低吞吐量。相反,较低的ACK级别可能会导致较低的可靠性和较高的消息丢失风险。

因此,在选择ACK级别时需要权衡吞吐量和可靠性。对于需要高吞吐量的应用,可以选择较低的ACK级别;对于需要高可靠性的应用,可以选择较高的ACK级别。

此外,Kafka的ACK机制还影响集群的延迟和持久性。例如,ACK=0时,提供了最低的延迟,但持久性最弱,当服务器发生故障时很可能发生数据丢失。ACK=1时,提供了较低的延迟以及较好的持久性,但是如果leader死亡,而follower尚未复制数据,数据就会丢失。ACK=-1时,leader收到所有消息,且follower同步完数据,才发送下一条数据,这提供了最高的可靠性,但也可能增加延迟。

因此,在选择ACK策略时,需要根据应用的需求和集群的特性进行权衡。

ACK机制对Kafka集群性能的影响主要涉及以下几个方面:

  1. 延迟 :ACK机制会增加消息传递的延迟。当生产者发送消息后,必须等待确认才能继续发送下一条消息。等待确认的时间取决于网络延迟、副本数量和ACK级别等因素。如果延迟较高,可能会影响生产者的发送速率和消费者的消费速率,从而降低集群的整体性能。

  2. 吞吐量 :ACK机制会影响Kafka集群的吞吐量。吞吐量是指集群在单位时间内处理的消息数量。当ACK级别较高时,生产者必须等待更多的确认,这会降低生产者的发送速率,从而影响集群的吞吐量。此外,如果集群中的副本数量较多,也会增加确认的延迟,进一步影响吞吐量。

  3. CPU和内存使用 :ACK机制需要额外的CPU和内存资源来处理确认消息。当集群中的消息数量较多时,处理确认消息的开销也会相应增加。这可能会影响其他任务的性能,例如消费者消费消息的速度。

  4. 数据一致性 :ACK机制是确保数据一致性的重要手段。当生产者发送消息后,如果某个副本未能成功接收消息,可能会导致数据不一致。通过等待所有相关副本的确认,可以确保数据的一致性。但是,这也可能增加延迟和降低吞吐量。

  5. 可靠性 :ACK机制可以提高消息的可靠性。当生产者发送消息并收到确认时,可以认为消息已经被成功接收并存储。这可以避免消息丢失的情况,提高系统的可靠性。

需要注意的是,在选择ACK策略时需要综合考虑应用的需求和集群的特性,权衡延迟、吞吐量、CPU和内存使用、数据一致性和可靠性等因素。

ACK控制粒度

Kafka中的ACK控制粒度是指生产者在发送消息时需要等待确认的副本数量。Kafka提供了三种不同的ACK控制粒度:

  1. ACK_roj(原子性确认) :这种控制粒度要求消息被所有的副本都接收后才能发送下一条消息,可以保证原子性操作。但是这种控制粒度会增加延迟,降低吞吐量,适用于对数据一致性要求较高的场景。
  2. ACK_one(领导者确认) :这种控制粒度要求消息被领导者副本接收后就可以发送下一条消息,可以减少延迟,提高吞吐量。但是这种控制粒度不能保证数据一致性,适用于对数据一致性要求不高的场景。
  3. ACK_all(全部副本确认):这种控制粒度要求消息被所有的副本都接收后才能发送下一条消息,可以保证数据一致性。但是这种控制粒度会增加延迟,降低吞吐量,适用于对数据一致性要求较高的场景。

Kafka客户端可以根据需要选择不同的ACK控制粒度。需要注意的是,不同的ACK控制粒度会对集群的性能和可靠性产生不同的影响,因此需要根据应用的需求和集群的特性进行选择。

Kafka分区数对集群性能影响

Kafka中的分区数对集群性能有显著影响,主要表现在以下几个方面:

  1. 吞吐量 :增加分区数可以增加Kafka集群的吞吐量。每个分区可以并行处理消息,因此更多的分区意味着更高的并行度,从而提高吞吐量。但是,过多的分区数也可能导致资源竞争和开销增加,从而降低性能。

  2. 延迟 :分区数对消息传递的延迟也有影响。较少的分区数可能会导致消息在某个分区上积压,从而增加延迟。增加分区数可以分散消息负载,减少单个分区的压力,降低延迟。但是,过多的分区数也会增加消息在多个分区之间的传播延迟。

  3. 负载均衡 :分区数会影响Kafka集群的负载均衡。如果分区数过少,某些broker可能会成为瓶颈,导致负载不均衡。适当增加分区数可以平衡负载,使消息更均匀地分布在各个broker上。但是,过多的分区数也可能导致过于复杂的负载均衡策略,增加管理和维护的难度。

  4. 存储和I/O :每个分区都需要在磁盘上存储数据日志和索引文件。因此,分区数会增加存储需求和I/O操作。过多的分区数可能会导致磁盘空间不足和I/O性能下降,从而影响集群的整体性能。

  5. 资源消耗 :每个分区都需要在内存中维护缓存和其他相关数据结构。因此,随着分区数的增加,内存消耗也会相应增加。这可能会对集群的资源产生压力,降低性能。

综上所述,选择合适的分区数对于优化Kafka集群的性能至关重要。需要根据应用的需求、集群的规模和硬件资源等因素进行综合考虑和调整。

调整分区优化集群性能

要调整Kafka集群的分区数以优化性能,可以采取以下措施:

  1. 了解业务需求:首先需要了解业务需求和数据量。考虑主题的数据量、消息生产者和消费者的数量,以及消息处理的延迟等因素,以确定合适的分区数。

  2. 调整副本数:副本数是Kafka保证数据可靠性和容错性的重要手段。可以根据需要调整副本数,以提高数据可靠性和容错性。但是,过多的副本数会增加存储和网络开销,因此需要根据实际情况进行权衡。

  3. 调整批处理大小:批处理是Kafka提高消息处理效率的重要手段。可以调整批处理的大小,以适应不同的业务需求和硬件资源。较大的批处理可以减少网络传输次数,提高处理效率,但可能会增加内存消耗和延迟。

  4. 调整主题和分区策略:在设计Kafka主题和分区时,需要考虑主题的数据量、消息生产者和消费者的数量,以及消息处理的延迟等因素,以制定合适的策略。例如,可以将经常被一起消费的消息放在同一个分区,以减少跨分区的消息处理延迟。

  5. 使用SSD存储:使用SSD存储可以显著提高Kafka的性能,因为SSD存储比传统的机械硬盘更快,能够更快地读写数据。使用SSD可以减少磁盘I/O瓶颈,提高Kafka集群的整体性能。

  6. 使用网络加速器:使用网络加速器可以减少网络延迟,提高数据传输的速度和可靠性,从而提高Kafka的性能和可靠性。例如,使用InfiniBand等高速网络技术可以显著提高Kafka集群的性能。

  7. 定期清理过期数据:定期清理过期数据可以减少磁盘空间的占用,从而提高Kafka的性能和可靠性。可以根据业务需求定期清理过期数据,释放磁盘空间,提高Kafka集群的整体性能。

调整Kafka集群的分区数需要综合考虑业务需求、硬件资源、网络环境等因素,并进行测试和优化。通过合理的分区数配置,可以提高Kafka集群的性能和可靠性,满足业务需求。

拓展

Kafka数据全局有序

Kafka的数据不是全局有序的,它只能保证单个Partition内的数据有序。因为Kafka的设计中允许多个生产者并行地向同一个主题写入消息,所以无法保证全局有序性。

如果需要全局有序,可以将所有消息发送到同一个Partition,或者使用一些外部的手段进行排序。但是这样会降低并行度和吞吐量,需要根据实际需求进行权衡。

在这里插入图片描述

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

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

相关文章

同旺科技 USB TO RS-485 定制款适配器--- 拆解(二)

内附链接 1、USB TO RS-485 定制款适配器 ● 支持USB 2.0/3.0接口,并兼容USB 1.1接口; ● 支持USB总线供电; ● 支持Windows系统驱动,包含WIN10 / WIN11系统32 / 64位; ● 支持Windows RT、Linux、Mac OS X、Windo…

基于epoll实现Reactor服务器

了解epoll底层逻辑 在我们调用epoll_create的时候会创建出epoll模型,这个模型也是利用文件描述类似文件系统的方式控制该结构。 在我们调用epoll_create的时候,就会在内核管理中创建一个epoll模型,并且建管理模块地址给file结构体&#xff…

HNU-计算机网络-实验2-网络基础编程实验(Python3)

计算机网络 课程基础实验二 网络基础编程实验(Python3) 计科210X 甘晴void 202108010XXX 一、实验目的 ​ 通过本实验,学习采用Socket(套接字)设计简单的网络数据收发程序,理解应用数据包是如何通过传输层进行传送的。 二、实验…

ubuntu中显卡驱动,cuda,cudnn安装

1. 在ubuntu中安装显卡驱动 参考:https://blog.csdn.net/m0_37605642/article/details/119651996 2.在ubuntu中安装cuda 参考:https://blog.csdn.net/m0_61431544/article/details/127007300 2.1 安装cuda cuda官网: https://developer.n…

前端“量子纠缠”:multipleWindow3dScene 来了

最近前端实现的量子纠缠在网络上火了起来,作者bgstaal的推文:效果如下: 量子纠缠 那我们一起来看下什么是量子纠缠,以及前端是如何实现的。 什么是量子纠缠? 在量子力学里,当几个粒子在彼此相互作用后&…

大数据Doris(三十三):Doris高级设置

文章目录 Doris高级设置 一、增大内存

【华为数据之道学习笔记】2-建立企业级数据综合治理体系

数据作为一种新的生产要素,在企业构筑竞争优势的过程中起着重要作用,企业应将数据作为一种战略资产进行管理。数据从业务中产生,在IT系统中承载,要对数据进行有效治理,需要业务充分参与,IT系统确保遵从&…

AWS Remote Control ( Wi-Fi ) on i.MX RT1060 EVK - 2 “架构 AWS”

接续上一章节,我们把开发环境架设好之后,此章节叙述如何建立 AWS IoT 环境,请务必已经有 AWS Account,申请 AWS Account 之流程将不在此说明。 III-1. 登入AWS IoT, 在“管理”>“所有装置”>“实物”下点击“建…

IDEA切换Python虚拟环境

前言 因为之前一直使用的IDEA开发,换到VSCODE之后各种不习惯,特别是DEBUG的操作,特别难受,因此决心换回IDEA 环境配置 已有项目调整 进入Project 选择SDKs,新建Python 配置Conda以及虚拟环境 有就选择一个虚拟环境…

LeetCode-周赛-思维训练-中等难度

第一题 1798. 你能构造出连续值的最大数目 解题思路 我们先抛开原题不看,可以先完成一道简单的题目,假设现在就给你一个目标值X,问你能够构造出从【1~X】的连续整数,最小需要几个数? 贪心假设期望:我们要…

Path Finder for Mac:超越系统的文件管理利器

Path Finder for Mac是一款卓越的文件管理器,它不仅具备基本的文件浏览、打开、复制和移动等操作功能,还引入了一系列强大的特性,使得用户可以更高效地管理和处理文件。 一、强大的预览功能 Path Finder for Mac支持多种文件格式的预览&…

题目分析,高度理解一维二维数组的申请和[]是什么运算符

第0题: 动态申请二维数组并输出非负数和 和负数出现次数 思路:输入数组大小,然后申请内存并不对其初始化,提高速度,传入数据到申请的数组中,判断如果数组中有元素小于0对其进行计数,否则加上非0数最后输出答案,释放内存 第一题: 解答: 运行结果: 思路分析: 创建长度为20的…

RobotFramework编写用例,在Jenkins上如何实现用例的并发运行?

我们了解RobotFramework编写自动化测试用例的方法,了解如何将用例在Jenkins上运行。 但是,随着用例的增多,传统的pybot/robot命令运行测试用例会耗费大量的时间,这就慢慢成为了一个苦恼的问题。 那么,在Jenkins上如何…

JFrog Artifactory二进制文件管理工具部署使用

1.简介 JFrog Artifactory二进制文件管理工具,目前已经在使用的公司有很多,足见他的方便好用。 2.下载安装包 点击下载地址 这里我下载的是7.9.2版本 3. 安装 (1)在安装JFrog Artifactory之前需要安装好jdk(需…

9_企业架构队列缓存中间件分布式Redis

企业架构队列缓存中间件分布式Redis 学习目标和内容 1、能够描述Redis作用及其业务适用场景 2、能够安装配置启动Redis 3、能够使用命令行客户端简单操作Redis 4、能够实现操作基本数据类型 5、能够理解描述Redis数据持久化机制 6、能够操作安装php的Redis扩展 7、能够操作实现…

AWS 日志分析工具

当您的网络资源托管在 AWS 中时,需要定期监控您的 AWS CloudTrail 日志、Amazon S3 服务器日志和 AWS ELB 日志等云日志,以降低任何潜在的安全风险、识别严重错误并确保满足所有合规性法规。 什么是 Amazon S3 Amazon Simple Storage Service&#xff…

苹果ios的系统app应用WebClip免签应用开源及方式原理

在移动设备上,为了方便访问我们经常使用的网站或服务,我们经常会希望将其添加到主屏幕上,以便快速启动。虽然我们可以通过使用浏览器书签实现这一目标,但添加一个图标到主屏幕上,使得它看起来与原生App无异&#xff0c…

为何开展数据清洗、特征工程和数据可视化、数据挖掘与建模?

1.2为何开展数据清洗、特征工程和数据可视化、数据挖掘与建模 视频为《Python数据科学应用从入门到精通》张甜 杨维忠 清华大学出版社一书的随书赠送视频讲解1.2节内容。本书已正式出版上市,当当、京东、淘宝等平台热销中,搜索书名即可。内容涵盖数据科学…

一个最新国内可用的免费GPT4,Midjourney绘画网站+使用教程

一、前言 ChatGPT GPT4.0,Midjourney绘画,相信对大家应该不感到陌生吧?简单来说,GPT-4技术比之前的GPT-3.5相对来说更加智能,会根据用户的要求生成多种内容甚至也可以和用户进行创作交流。 然而,GPT-4对普…

MAC 系统在vs code中,如何实现自动换行

目录 问题描述: 问题解决: 问题描述: 在vscode中,有些时候,一行内容过多,如果不能自动换行,就需要拖动页面,才能看到完整的内容。如下图两行所示: 问题解决&#xff1a…