- 2025-01-06以C++为低延迟的解决方案总结
前言某天在知乎上看到的问题https://www.zhihu.com/question/23185359/answer/137034841,《以C++为核心语言的高频交易系统是如何做到低延迟的》,感觉问题和答案都非常好,所以想在此归纳和总结一下优秀的答案作为今后的参考要点总结为了解决这个问题,可以结合我之前记录的C++
- 2024-12-22NUMA的取舍与优化设置
NUMA的取舍与优化设置 在os层numa关闭时,打开bios层的numa会影响性能,QPS会下降15-30%; 在bios层面numa关闭时,无论os层面的numa是否打开,都不会影响性能。 安装numactl: #yuminstallnumactl-y #numastat 等同于
- 2024-11-28支持超线程的numa架构
支持超线程的numa架构物理硬件视角,将多个CPU封装在一起,这个封装被称为插槽Socket;Core是socket上独立的硬件单元;通过intel的超线程HT技术进一步提升CPU的处理能力,OS看到的逻辑上的核Processor的数量。每个硬件线程都可以按逻辑cpu寻址,因此这个处理器看上去有八块cpu。
- 2024-11-28Burp抓PC端WX小程序数据包
Burp抓PC端WX小程序数据包两种方式,一种为设置系统代理Burp直接抓,一种为使用Proxifire转发数据包至Burp再抓。Way1系统安装Burp证书,安装步骤同上。设置系统代理为Burp,默认127.0.0.1:8080随便打开一个WX小程序,Burp直接抓即可。以某车之家小程序举例WX小程序抓
- 2024-09-15P2657 [SCOI2009] windy 数 题解
枚举、预处理,len-1位,len位但小于第一个数的这些都不讲了,看这篇题解windy讲一下贴近最高位的处理。因为最高位如果取了,后面位数只能取到最高位,而不是9,而后面的数也是同理,所以我们的内部$\j\$循环枚举范围要把\(num_i\)单独拿出来判,单独拿出来的原因是好判break一些,因为已
- 2024-07-22Linux--进程绑定NUMA节点或CPU核心
对于CPU和NUMA架构的介绍本文不再做叙述,感兴趣的可自行查看:Linux--CPU简述,Linux--内存管理浅谈。 1、进程绑定NUMA节点或cpu核心的意义NUMA架构将内存和cpu分散在不同的NUMA节点上,每个节点都有自己的本地内存和cpu处理器,将进程绑定到特定的NUMA节点或cpu上,可以让进程直接
- 2024-07-17Linux服务器配置信息查看
lscpu ---查看CPU架构相关信息 Architecture:系统的CPU架构。CPUop-mode(s):CPU的操作模式,比如32位和64位。ByteOrder:字节序,通常是小端(LittleEndian)。CPU(s):系统中总的CPU核心数。On-lineCPU(s)list:在线的CPU核心列表。Th
- 2024-06-24'MMDetection3D'+'waymo-open-dataset-tf-2-6-0'+'pytorc2.3.1+cu121'安装
安装pytorc2.3.1+cu121步骤1.创建并激活一个conda环境condacreate-nmmdpython=3.8-ycondaactivatemmd步骤2.基于PyTorch官方说明安装PyTorch,例如:pip3installtorchtorchvisiontorchaudio--index-urlhttps://download.pytorch.org/whl/cu121步骤3.验
- 2024-06-20多处理系统结构
目录统一内存访问(UMA)多处理器系统结构优点缺点应用场景UMA结构的架构示例解决方案和改进非统一内存访问(NUMA)多处理系统结构概述NUMA的优点NUMA的缺点NUMA系统的工作原理NUMA优化策略结论 现代计算机系统越来越多地采用多处理器结构,这带来了性
- 2024-06-12给出五种典型的访存模型,并分别简要描述其特点。
均匀存储访问模型(UMA):物理存储器被所有处理器均匀共享;所有处理器访问任何存储字取相同的时间;每台处理器可带私有高速缓存;外围设备也可以一定形式共享。非均匀存储访问模型(NUMA):被共享的存储器在物理上是分布在所有的处理器中的,其所有本地存储器的集合就组成了全局地址空间;处理
- 2024-06-09简单工厂模式( Simple Factory Pattern )
简单工厂模式(SimpleFactoryPattern),在工厂类中对象决定创建出哪一种产品类的实例。这些产品类都实现了相同的接口,或者继承了相同的父类。结构图Factory(工厂角色):它是核心,负责实现创建所有实例的内部逻辑。在工厂类中,提供了一个静态方法,可以直接被外界直接调用,以创建具体产品
- 2024-06-01NUMA架构的个人理解
numa架构是并行处理器环境的产物。之前通过卷cpu频率的方式无法满足更高计算性能的情况下,cpu向着多socket多core多socket的方式发展,这种架构设计下,总线发生争用,不再适合并行的需求,于是,出现了这种新的架构设计,每个socket独占一部分内存空间,这样就出现了针对某个socket的本地内存和
- 2024-05-23linux关闭numa
以下内容在Centos8操作系统演示1、编辑/etc/default/grub2、在GRUB_CMDLINE_LINUX里添加numa=off3、输入命令grub2-mkconfig-o/boot/grub2/grub.cfg用更改的文件重新生成/boot/grub2/grub.cfg重启生效4、重启后查看cat/proc/cmdline再次确认
- 2024-05-08使用libvirt配置pci bus的numa亲和性
前面的一篇文章在qemu中绑定pcibus到numanode-半山随笔-博客园(cnblogs.com)中记录了如何使用qemu命令行来设置pcibus与numa的亲和性。本篇来记录如何使用libvirt来做同样的事。libvirt相较于qemu是一个更高层的工具,在提供便捷性的同时也损失了一点灵活性。就拿设置pcib
- 2024-05-07使用libvirt绑定numa node
初学libvirt,感觉还挺方便的。它能够像daemon一样运行一个稳定的VM,相比直接用qemu命令行是方便多了。这里记录一下我如何绑定numanode。不知道能不能直接在创建虚拟机的时候绑定numa,我是在xml中设置的。安装libvirt,略去。在host上创建一个网桥,libvirt以它上网,我这里命名为virbr0
- 2024-04-29openGauss NUMA-aware分配和亲和性
NUMA-aware分配和亲和性非统一内存访问(NUMA)是一种计算机内存设计,用于多重处理,其中内存访问时间取决于内存相对于处理器的位置。处理器可以利用NUMA的优势,优先访问本地内存(速度更快),而不是访问非本地内存(这意味着它不会访问另一个处理器的本地内存或处理器之间共享的内存)。MOT内存
- 2024-04-29在qemu中绑定pci bus到numa node
在多numanode的物理机中,pcibus常常是连接到其中一个numa上。如此,不同的numa节点访问该pcibus下的设备的访问速度是不同的。基于此常常要将访问该设备的负载绑定到对应的numanode上可以提供性能。对于qemu虚拟机也可以模拟pcibus与numa之间的亲和性。在x86机器中,只有pxb和pxb
- 2024-04-29openGauss NUMA-aware分配和亲和性
NUMA-aware分配和亲和性非统一内存访问(NUMA)是一种计算机内存设计,用于多重处理,其中内存访问时间取决于内存相对于处理器的位置。处理器可以利用NUMA的优势,优先访问本地内存(速度更快),而不是访问非本地内存(这意味着它不会访问另一个处理器的本地内存或处理器之间共享的内存)。MOT内存
- 2024-04-23Linux命令之查找CPU资源利用情况(lscpu和top详解)
1.lscpu命令:获取CPU架构完整详细信息,例如架构信息,CPU模式,CPU频率,CPU核心数、线程数、缓存大小。在终端输入“lscpu”: 参数详解:【Architecture:x86_64】:架构信息,表示系统的CPU架构为x86_64,表示64位架构;【CPU op-mode(s):32-bit,64-bit】:CPU的运行模式,表示支持32位和64位
- 2024-04-08P1449 后缀表达式
P1449后缀表达式题目所谓后缀表达式是指这样的一个表达式:式中不再引用括号,运算符号放在两个运算对象之后,所有计算按运算符号出现的顺序,严格地由左而右新进行(不用考虑运算符的优先级)。本题中运算符仅包含$\texttt{+-*/}$。保证对于$\texttt{/}$运算除数不为0。特别地,其中$
- 2024-03-30openGauss 鲲鹏NUMA架构优化
鲲鹏NUMA架构优化可获得性本特性自openGauss1.0.0版本开始引入。特性简介鲲鹏NUMA架构优化,主要面向鲲鹏处理器架构特点、ARMv8指令集等,进行相应的系统优化,涉及到操作系统、软件架构、锁并发、日志、原子操作、Cache访问等一系列的多层次优化,从而大幅提升了openGauss数据库在