- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在一篇论文中看到了对末级缓存的介绍。介绍中说末级缓存有很多片。每个切片就像一个传统的集合关联缓存。通过set index和slice id找到对应的cache set(如下图所示)。
我想检查我的服务器有多少个切片。以及每个分片的信息(有多少个cache set,每个cache set有多少cacheline)。我在google上搜索的方法是查看文件夹/sys/devices/system/cpu/cpu0/cache/index3
下的缓存信息。
但是查了一下,发现这个文件夹下的介绍和l1、l2没什么区别。该文件夹下的文件有
coherency_line_size level physical_line_partition shared_cpu_list size uevent
id number_of_sets power shared_cpu_map type ways_of_associativity
如何查看服务器上有多少个切片?此处显示的 number_of_sets
是否为切片缓存集?
我正在使用服务器。版本是:Linux version 4.15.0-122-generic (buildd@lcy01-amd64-010) (gcc version 5.4.0 20160609 (Ubuntu 5.4.0-6ubuntu1~16.04.12)) #124~16.04。 1-Ubuntu SMP。
最佳答案
以下处理器集合使用服务器非核心微架构:
在这些处理器上,L3 缓存片的数量可以通过以下方式获得:
第 1 步:在 Linux 终端上运行以下命令:
setpci | grep Power
这会向您显示系统中每个处理器包的 PCU 的 PCI 设备功能列表。双 Xeon E5 v4 处理器系统上的示例输出如下所示:
df:1e.0 System peripheral: Intel Corporation Xeon E7 v4/Xeon E5 v4/Xeon E3 v4/Xeon D Power Control Unit (rev 01)
df:1e.1 System peripheral: Intel Corporation Xeon E7 v4/Xeon E5 v4/Xeon E3 v4/Xeon D Power Control Unit (rev 01)
df:1e.2 System peripheral: Intel Corporation Xeon E7 v4/Xeon E5 v4/Xeon E3 v4/Xeon D Power Control Unit (rev 01)
df:1e.3 System peripheral: Intel Corporation Xeon E7 v4/Xeon E5 v4/Xeon E3 v4/Xeon D Power Control Unit (rev 01)
df:1e.4 System peripheral: Intel Corporation Xeon E7 v4/Xeon E5 v4/Xeon E3 v4/Xeon D Power Control Unit (rev 01)
df:1e.0 System peripheral: Intel Corporation Xeon E7 v4/Xeon E5 v4/Xeon E3 v4/Xeon D Power Control Unit (rev 01)
df:1e.2 System peripheral: Intel Corporation Xeon E7 v4/Xeon E5 v4/Xeon E3 v4/Xeon D Power Control Unit (rev 01)
ff:1e.0 System peripheral: Intel Corporation Xeon E7 v4/Xeon E5 v4/Xeon E3 v4/Xeon D Power Control Unit (rev 01)
ff:1e.1 System peripheral: Intel Corporation Xeon E7 v4/Xeon E5 v4/Xeon E3 v4/Xeon D Power Control Unit (rev 01)
ff:1e.2 System peripheral: Intel Corporation Xeon E7 v4/Xeon E5 v4/Xeon E3 v4/Xeon D Power Control Unit (rev 01)
ff:1e.3 System peripheral: Intel Corporation Xeon E7 v4/Xeon E5 v4/Xeon E3 v4/Xeon D Power Control Unit (rev 01)
ff:1e.4 System peripheral: Intel Corporation Xeon E7 v4/Xeon E5 v4/Xeon E3 v4/Xeon D Power Control Unit (rev 01)
ff:1e.0 System peripheral: Intel Corporation Xeon E7 v4/Xeon E5 v4/Xeon E3 v4/Xeon D Power Control Unit (rev 01)
ff:1e.2 System peripheral: Intel Corporation Xeon E7 v4/Xeon E5 v4/Xeon E3 v4/Xeon D Power Control Unit (rev 01)
总线 df
上的设备功能在一个处理器上,而总线 ff
上的设备功能在另一个套接字上。唯一需要的信息是公交车号码。以总线df
为例
第 2 步:运行以下命令:
sudo setpci -s df:1e.3 98.l
一个例子是 46000f2e
。此值的位 0-23 表示位向量,其中位值为零表示启用的 L3 缓存片,位值为零表示禁用的缓存片。您实际上不能自己禁用任何切片;只有 PCU 可以在包 C 状态转换期间执行此操作。在正常操作期间,将启用所有可用的切片。因此,设置位的数量就是切片的数量。在此示例中,位向量 000f2e
设置了 8 位,因此所选处理器上的切片数为 8。
通常,同一个共享内存系统中的所有英特尔处理器都是同类的,但如果需要,您可以为每个处理器重复上述状态。
一般来说,最多可以有 24 个切片,每个切片的大小最大为 2.5 MiB。
以下处理器集合使用服务器非核心微架构:
第 1 步:与之前相同。
第 2 步:运行以下命令:
sudo setpci -s XX:0a.3 94.l
其中 XX 是第 1 步中的总线编号。位 0-14 表示缓存切片位向量。通常,最多可以有 15 个切片,每个切片的大小最大为 2.5 MiB。
我不确定这种方法是否适用于 Sandy Bridge 处理器和 Ivy Bridge 的 Core X 系列,但检查它是否有效没有坏处。
以下处理器集合使用服务器非核心微架构:
第 1 步:与之前相同。
第 2 步:运行以下命令(感谢@JohnDMcCalpin):
sudo setpci -s XX:1e.3 9c.l
其中 XX 是第 1 步中的总线编号。位 0-27 表示缓存切片位向量。通常,最多可以有 28 个切片,每个切片的大小为 1.375 MiB。
Intel 发布的所有具有服务器非核心的处理器型号都具有由 1.375 MiB 片组成的 L3 缓存。切片数是总缓存大小除以 1.375 MiB。我不知道有任何异常(exception)。
以下处理器集合使用服务器非核心微架构:
在我看来,这些处理器上的切片大小为 1.5 MiB。
以下处理器集合使用具有分布式 L3 缓存的服务器非核心微架构:
这些处理器上的切片大小可以达到 3 MiB。
它们不使用分布式缓存架构,因此这些处理器上不存在切片的概念。
关于caching - 如何查看末级缓存中有多少个切片?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65195656/
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 8 年前。 Improve t
我卡在了一个点上,我无法进步,很抱歉这个愚蠢的问题。我为此进行了很多搜索,但我不知道我错过了什么。请帮助我。 我研究了 python 中的模块和类。现在我想使用 python 和 apt 进行一些操作
我在 Kong 有服务,我已经为该服务设置了代理缓存插件。 curl -X POST http://localhost:8001/plugins --data "name=proxy-cache"--
ASP.NET Core 提供内存缓存和响应缓存。 假设该应用程序是 ASP.NET Core WebAPI,它通过配置的响应缓存中间件将 SQL 数据库中的数据传送给用户。 在什么情况下也使用内存缓
我最近遇到了以下面试问题: You need to design a system to provide answers to factorials for between 1 and 100. Yo
我的 Javascript (JS) 代码遇到了一些麻烦,因为我有时需要在同一个函数中多次访问相同的 DOM 元素。还提供了一些推理here . 从性能的角度来看,是一次性创建一个 jQuery 对象
仅使用 Cache 终端,我使用或查看什么实用程序函数或 Global 来查找存在于 Cache 数据库中的所有 Globals 的列表? 再次仅在缓存终端中使用,我使用或查看什么实用程序功能或全局以
我的 Javascript (JS) 代码遇到了一些麻烦,因为有时我需要在同一个函数中多次访问同一个 DOM 元素。还提供了一些推理here . 从性能的角度来看,是先创建一个jQuery对象然后缓存
来自 RFC 2616 http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html#sec14.9.1 no-cache If the no-cach
大多数 CDN 服务器对经常访问的内容使用缓存。 场景:假设有人上传了一张非常热门的图片,并且来自同一位置的许多用户 (1000) 试图访问该图片。 问题:假设网络服务器收到一个请求,首先检查它的缓存
我的 Javascript (JS) 代码遇到了一些麻烦,因为有时我需要在同一个函数中多次访问同一个 DOM 元素。还提供了一些推理here . 从性能的角度来看,是先创建一个jQuery对象然后缓存
如果我将服务器响应设置为:Cache-Control: private,no-cache,max-age=900 ? 如果标题是这样的,会发生什么:Cache-Control: public,no-c
我有一个类需要在缓存中存储数据。最初我在 ASP.NET 应用程序中使用它,所以我使用了 System.Web.Caching.Cache。 现在我需要在 Windows 服务中使用它。现在,据我了解
我遇到了和这个人一样的问题:X-Drupal-Cache for Drupal 7 website always hits MISS ,并且找不到出路。 我正在运行 Drupal 7 - 新闻流 和
我已将 Laravel 设置为使用 Redis 作为缓存。当我使用 Cache::('my_var', 'my_val'); 然后通过 CLI 检查 Redis 以查看 key 是否已创建时,我可以验
我在 Windows Azure 云上有一个应用程序,并且正在使用 Windows Azure 共置缓存。 有时,当我发布网站/web服务时,调用DataCacheFactory.GetCache方法
我正在阅读 documentation for Apollo server-side caching ,但看不到任何关于缓存通常如何加密的内容。 我需要的是一个以响应中包含的对象 ID 为键的缓存,而
Hibernate\Grails 中最好的缓存策略是什么?是否缓存所有实体和查询以及如何找到最佳解决方案? 这是我的 hibernate 配置。 hibernate { cache.use_sec
我收到错误 'Nuget.Proxy Cache' 的类型初始化器抛出异常 尝试连接到 Nuget 官方包源时。我在公司网络后面,但是我怀疑问题是连接性。 有任何想法吗? 最佳答案 我有同样的问题。我
我是一名优秀的程序员,十分优秀!