首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

创建多少线程是合适

面试中经常有人被问到线程池的数据设置多少合适呢,今天我们就看一下这个问题,首先我们需要知道两个问题 为什么使用多线程 多线程使用的场景 为什么使用多线程 使用多线程是主要目的就是提高性能,而性能的指标有很多...io和cpu互相配合使用,操作系统提供给我们的方案就是多线程 举个例子,此时的cpu计算和io操作的耗时就是1:1,而我们只有一个线程,在执行CPU计算的时候io设备闲置,而使用io操作的时候cpu闲置...创建多少个线程合适呢 创建线程的多少,是要区分场景的,一般是cpu密集性和io密集性,这两种场景的是不同的计算方式 对于CPU密集型计算,多线程本质上就是提升多核cpu的利用率,所以一个4核的cpu,...每一个核创建一个线程,理论上创建4个线程就可以了,再多的线程只会增加线程切换的成本,所以对于CPU密集型计算场景,理论上线程的数据数量=CPU核数是最合适的,但是一般都会设置cpu核数+1,那是因为当线程偶发内存也失效或其他原因导致阻塞...O耗时/CPU耗时,当线程A执行IO操作的时候,R个线程去执行各自的CPU计算,CPU的利用率就会达到100% 不过上面的公式是在单核下面,如果是多核cpu,可以使用下面公式 最佳线程数 =CPU 核数

71610
您找到你想要的搜索结果了吗?
是的
没有找到

Java中创建多少线程才是合适的?

所以,从度量的角度,提升性能主要是降低延迟,提升吞吐量。 多线程的应用场景 在并发编程领域,提升性能本质上就是提升硬件的利用率,就是提升I/O利用率和CPU利用率。...比如,如果CPU和I/O操作的耗时是1:1(这里假设CPU和I/O执行效率是一致的),如果只有一个线程,执行CPU计算的时候I/O设备是空闲的,执行I/O操作的时候CPU是空闲的,所以CPU和I/O利用率都是...创建多少个线程合适呢?...O密集型计算相对的是CPU密集型计算,CPU密集型计算大部分情况下都是纯CPU计算。...对于CPU密集型计算,多线程是为了提高多核CPU的利用率,理论上线程数=CPU核心数是最合适的,不过实际设置过程中会设置成CPU核心数+1,这样是为了在线程在某些原因造成阻塞时,而外的线程可以顶上,保障了

3.1K10

【38期】JAVA中线程池设置多少合适

真实程序中的线程数 那么在实际的程序中,或者说一些 Java 的业务系统中,线程数(线程池大小)规划多少合适呢?...结论 没有固定答案,先设定预期,比如我期望的 CPU 利用率在多少,负载在多少,GC 频率多少之类的指标后,再通过测试不断的调整到一个合理的线程数比如一个普通的,SpringBoot 为基础的业务系统,...流程一般是这样: 分析当前主机上,有没有其他进程干扰 分析当前 JVM 进程上,有没有其他运行中或可能运行的线程 设定目标 目标 CPU 利用率 - 我最高能容忍我的 CPU 飙到多少?...没有标准答案,一定要结合场景,带着目标,通过测试去找到一个最合适的线程数。...可能还有同学可能会有疑问:“我们系统也没啥压力,不需要那么合适的线程数,只是一个简单的异步场景,不影响系统其他功能就可以” 很正常,很多的内部业务系统,并不需要啥性能,稳定好用符合需求就可以了。

1.3K20

软中断会吃掉你多少CPU

2、你的服务器上被软中断吃掉了多少CPU时间? 如果你和我一样好奇上面的问题的答案,那请跟我来!...1 软中断的诞生 CPU正常情况下都是专心处理用户的进程的,当外部的硬件或软件有消息想要通知CPU,就会通过中断请求(interrupt request,IRQ)的方式来进行。...所以现代的Linux又发明了软件中断,配合硬中断来处理网络IO。硬中断你可以理解只是个收包的,把包收取回来放到“家里”就完事,很快就能完成,这样不耽误CPU响应其它外部高优先级的中断。...让我们将他们进行一个简单的对比: 1)和系统调用开销对比 《深入理解Linux内核-第五章》开头的一句话,很形象地把中断和系统调用两个不相关的概念联系了起来,巧妙地找到了这二者之间的相似处。...大家感兴趣的,可以继续阅读《深入理解Linux内核》的-第五章。 根据前文的实验结果,进程上下文切换开销是3us-5us。

1.3K20

如何选用合适Linux版本

本文将分析Linux操作系统的版本选择,重点突出Kali Linux版本对信息安全的优势,并分析CentOS停止更新的危害。...一、Linux版本选择的考虑因素 在选择Linux版本时,我们需要考虑以下因素: 安全性:选择一个安全的Linux版本是至关重要的,因为安全漏洞可能导致系统被攻击。...兼容性:Linux版本的兼容性是指系统能否与其他软件和硬件兼容。 二、Kali Linux对信息安全的优势 Kali Linux是一个基于Debian的Linux发行版,专门用于信息安全领域。...三、CentOS停止更新的危害 CentOS是一个基于Red Hat Enterprise Linux(RHEL)的Linux发行版,它是一款广泛使用的企业级Linux发行版。...输入设备:Kali Linux需要一个键盘和鼠标。 网络:Kali Linux需要一个可用的网络连接,以便下载和更新软件包。 用户权限:Kali Linux需要管理员权限才能安装和运行软件包。

33210

EOS开发DApp需要多少内存CPU带宽?

要开发一个基于EOS区块链的DAPP需要多少内存、CPU或带宽资源?这是很多即将开始EOS项目的开发者关注的一个重要问题。...CPU计量你在过去3天里的对计算资源的平均利用情况,单位为毫秒。每当你发送一个动作或交易,也会暂时消耗一些CPU资源。...3、EOS资源的分配模型 在EOS区块链中,网络带宽和CPU资源是采用抵押方式获取的。...分配给你多少带宽和CPU,取决于你抵押的EOS代币在过去3天里EOS区块链系统抵押合约持有的代币总量中占多大的比例。发送交易所消耗的网络带宽资源和CPU资源,会随时间流逝自动再释放给你。...通常一个交易需要消耗200字节的带宽和1ms的CPU

2K20

linux系统怎么内存使用率_cpu使用率0

04/08/2019 _x86_64_ (1 CPU) 10:54:35 AM LINUX RESTART 11:00:02 AM CPU %user...free:可用有多少。 Shared:多个进程共享的内存总额。 Buff/cache:磁盘缓存的大小。 第三行是交换分区SWAP的,也就是我们通常所说的虚拟内存。...所以我们linux,只要不用swap的交换空间,就不用担心自己的内存太少.如果常常swap用很多,可能你就要考虑加物理内存了.这也是linux内存是否够用的标准....如果是应用服务器的话,一般只第二行,+buffers/cache,即对应用程序来说free的内存太少了,也是该考虑优化程序或加内存了。...5、硬盘则决定你的电脑可以装下多少东西,内存则决定你的电脑开机后一次最多可以运行多少程序(如手机运行内存)。 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。

21.9K50

(转)数据库连接池数量设置为多少合适

一、前言 基本上来说,大部分项目都需要跟数据库做交互,那么,数据库连接池的大小设置成多大合适呢?...这个网站的数据库连接池应该设置成多大合适呢? 其实这个问法本身就是有问题的,我们需要反过来问,正确问法应该是: “这个网站的数据库连接池应该设置成多小合适呢?”...一核 CPU同一时刻只能执行一个线程,然后操作系统切换上下文,CPU 核心快速调度,执行另一个线程的代码,不停反复,给我们造成了所有进程同时运行假象。...大小设置成多少合适呢? 这要取决于磁盘,如果你使用的是 SSD 固态硬盘,它不需要寻址,也不需要旋转碟片。打住打住!!!...还有,你应该模拟预期的访问量,并通过下面的公式先设置一个偏合理的值,然后在实际的测试中,通过微调,来寻找最合适的连接数大小。

11.7K62

CPU缓存缓存的套路

三、何时更新缓存 在 CPU 中引入缓存中间层后,虽然可以解决和内存速度不一致的问题,但是同时也面临着一个问题:当 CPU 更新了其缓存中的数据之后,要什么时候去写入到内存中呢?...上面说的在适当的时候写入内存,如果是单核 CPU 的话,可以在缓存要被新进入的数据取代时,才更新内存,但是在多核 CPU 的情况下就比较复杂了,由于 CPU 的运算速度超越了 1 级缓存的数据 I\O...能力,CPU 厂商又引入了多级的缓存结构,比如常见的 L1、L2、L3 三级缓存结构,L1 和 L2 为 CPU 核心独有,L3 为 CPU 共享缓存。...第二种是当一个核心修改了缓存的数据之后,就把其它同样复制了该数据的 CPU 核心失效掉这些数据,等到合适的时机再更新,通常是下一次读取该缓存的时候发现已经无效,才从内存中加载最新的值。...下面看看基于缓存一致性协议是如何进行读取和写入操作的, 假设现在有一个双核的 CPU,为了描述方便,简化一下只其逻辑结构: ?

61040

从猫蛇之战内核戏CPU

在网上搜一下,可以看到很多猫蛇战斗的照片,看来猫蛇之战是很多人都喜欢的“精彩节目”。 ? (照片来自搜索引擎) 再来一张更清晰一些的。 ?...很多同行都知道,今天的CPU是运行在所谓的保护模式中,软件访问的内存空间都是虚拟空间。而且这个虚拟空间中的内容是分三六九等的,是分平民区和富人区的,是分道路和深坑的。...ProbeForRead () 而Linux内核中的两个函数为: root@gedu-VirtualBox:/home/gedu/labs/linux-source...继续深挖,在目前的Linux内核实现中,是维护一个计数器:pagefault_disabled。 ?...(https://elixir.bootlin.com/linux/v5.0-rc8/source/include/linux/uaccess.h) 在处理页错误的do_page_fault函数中

81520

Linux查询CPU信息

1.基本概念 物理CPU数 主板上实际插入的CPU数量,可以数不重复的physical id 有几个(physical id) CPU核数 单块CPU上面能处理数据的芯片组的数量,如双核、四核等...(CPU cores) 逻辑CPU数 一般情况下,逻辑CPU数=物理CPU个数每颗核数,如果不相等的话,则表示服务器的CPU支持超线程技术(简单来说,它可使处理器中的1颗内核如2颗内核那样在操作系统中发挥作用...这样一来,操作系统可使用的执行资源扩大了一倍,大幅提高了系统的整体性能,此时逻辑CPU=物理CPU个数每颗核数*2) 它们之间的关系 总核数 = 物理CPU个数 * 每颗物理CPU的核数 总逻辑...CPU数 = 物理CPU个数 * 每颗物理CPU的核数 * 超线程数 2.查看物理CPU的个数 $ cat /proc/cpuinfo |grep "physical id"|sort |uniq|wc...-l 2 3.查看逻辑CPU个数 $ cat /proc/cpuinfo |grep "processor"|wc -l 24 4.查看CPU核数 $ cat /proc/cpuinfo |grep

11.5K10
领券