linux大内存拷贝优化,Linux 下基础设施及系统网络优化

基础设施优化

CPU 优化

多级缓存

充分利用 cache 是 CPU 调优的重要手段,由于是底层优化作用范围广。

性能分析利器——Perf 参数学习

提升 cache 命中率

缓存命中: CPU 要取的数据再一级缓存内,直接读取,称为 cache 命中率

使用 Perf 查看 Data[i][j] 和 Data[j][i] 性能对比。

对于一个二维数组,是先遍历后排序还是先排序后遍历性能更好。

提升多核 cache 命中率

若发生 CPU 切换,则之前 L1 和 L2 cache 会发生切换(L1 和 L2 每个CPU单独拥有, L3 多个 CPU 公用),优化会失效。

绑定到 CPU 比不绑定 CPU 性能更加。

小结:

数据 cache 命中率提升

命令 cache 命中率提升

CPU 绑定

内存优化

应用程序分配内存过程

业务代码-->应用层内存池-->C 库内存池--> 操作系统内存分配

linux 默认 C 库内存池 Ptmalloc2

cat /proc/${PID}/maps 查看内存分配

堆内存最小分配132k

堆内存最好尽早释放

Tcmalloc C 库内存池适合小内存分配,中大内存分配不如 Ptmalloc2

界限:0-256k 小 256k-1M 中 1M 以上 大

Tcmalloc: 多线程、256k 以下

Ptmalloc2: 通用性好,大内存

堆和栈内存

栈速度快,缺点:容量和声明周期

磁盘优化

磁盘常常是瓶颈所在

优化技术

零拷贝(缓存 IO 技术)

网卡支持 SG-DMA 还可以更快。

缺陷:大文件传输 PageCache 技术的缺陷。

直接 IO + 异步 IO

大文件传输可以使用此方法。

系统网络优化

TCP 握手优化

SYN 请求优化

服务端优化

SYN 半队列溢出

netstat -s 可以查看由队列满引起的连接失败次数

设置 syncookie ,可以在队列满后继续建立连接, 参数含义如下:

0:关闭

1:队列满开启

2:无条件开启

accept 队列溢出

linux 默认丢弃新连接,设置 tcp_abort_on_overflow 参数,可以发送 RST 给客户端。 参数含义如下:

0:丢弃

1:发 RST 给客户端

绕过三次握手发送数据

Goole 统计,三次握手在 http 请求时间中占了 10% ~ 30%。

TFO 实现过程:

正常三次握手

SYN 携带数据

设置系统参数 tcp_fastopen 来使用 TFO, 需要客户端和服务器同时支持。

TCP 挥手优化

Close 函数

Shutdown 函数

tcp_orphan_retries: 控制主动方重传 FIN 的次数,默认值为 0,表示 8 次

FIN_WAIT_1

tcp_max_orphans

tcp_fin_timeout

被动方参数优化

netstat 发现大量 close_wait

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

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

相关文章

Vue或React多页应用脚手架

https://github.com/zhujiasheng/vue-multipage https://github.com/MeCKodo/vue-multipage 转载于:https://www.cnblogs.com/zhujiasheng/p/6112335.html

磁盘管理来安装linux,Linux_在CentOS系统中安装quota来管理磁盘配额,在网络管理的工作中,由于硬 - phpStudy...

在CentOS系统中安装quota来管理磁盘配额在网络管理的工作中,由于硬盘的资源是有限的,常常需要为多用户的服务器设定用户的linux磁盘配额。这个功能对公用的多用户服务器(免费的或者收费的)来说,更是非常必要的。Quota就是在RedHatlinux下实现…

arcgis api 3.x for js 入门开发系列六地图分屏对比(附源码下载)

前言 关于本篇功能实现用到的 api 涉及类看不懂的,请参照 esri 官网的 arcgis api 3.x for js:esri 官网 api,里面详细的介绍 arcgis api 3.x 各个类的介绍,还有就是在线例子:esri 官网在线例子,这个也是学…

linux中进程pts 1和pts 3,termial创建时ptmx与pts的关系

我们打开一个terminal,那么将会在devpts文件系统/dev/pts下创建一个对应的pts字符文件,该pts字符文件节点直接由/dev/ptmx节点的驱动函数ptmx_open()调用devpts_pty_new(tty->link)[tty对应ptmx,tty->link对应/dev/pts/xxx,那么tty->link->link又对应回ptmx同样ptm…

linux系统无root权限lua库安装,liunx系统中安装lua以及torch

一直在用pytorch,最近在做项目的时候,遇到了torch的开源代码,所以又开始不得不接触torch以及他所依赖的环境lua。 liunx下lua环境的配置代码如下: curl -R -O http://www.lua.org/ftp/lua-5.3.5.tar.gz tar zxf lua-5.3.5.tar.gz cd lua-5.3…

js数组去重的四种方式

// 删除重复的 function only(arr){for(var i0;i<arr.length;i){for(var j i1;j<arr.length;j){if(arr[i]arr[j]){arr.splice(j,1);j--;}}}return arr; } console.log(only([6]));//[6] console.log(only([1,9,8,8,0,6,0,6]));//[1, 9, 8, 0, 6]// 往新数组中插入不重复…

linux的usermod命令参数,linux usermod命令参数及用法详解

linuxusermod命令参数及用法详解,linux修改用户账号信息命令,usermod可用来修改用户帐号的各项设定。接下来是小编为大家收集的linux usermod命令参数及用法详解&#xff0c;欢迎大家阅读&#xff1a;linux usermod命令参数及用法详解命令&#xff1a;usermod功能说明&#xff…

SVN版本管理trunk及branch相关merge操作

先说说什么是branch。按照Subversion的说法&#xff0c;一个branch是某个development line&#xff08;通常是主线也即trunk&#xff09;的一个拷贝&#xff0c;见下图&#xff1a; branch存在的意义在于&#xff0c;在不干扰trunk的情况下&#xff0c;和trunk并行开发&#xf…

linux没有interface文件,Linux下interface文件修改

我们来通过一些例子&#xff0c;来记录interfaces文件的书写。详情可参照man interfaces。设置常用ethernet参数auto loiface lo inet loopback# The primary network interfaceauto eth0iface eth0 inet staticaddress192.168.0.42network192.168.0.0netmask255.255.255.0broa…

线程之间通信 等待(wait)和通知(notify)

线程通信概念&#xff1a; 线程是操作系统中独立的个体&#xff0c;但这些个体如果不经过特殊的处理就不能成为一个整体&#xff0c;线程之间的通信就成为整体的必用方式之一。当线程存在通信指挥&#xff0c;系统间的交互性会更强大&#xff0c;在提高CPU利用率的同时还会对线…

女生适合linux运维吗,女生适不适合做Linux运维工程师进入IT行业?

很多人对于女生做Linux运维工程师进入IT还有都存在质疑。因为大多数人认为女生不适合IT行业&#xff0c;IT is a men’sworld&#xff0c;女生学IT是件匪夷所思的事情。在传统的思维当中&#xff0c;女生只适合从事像教师、会计、公务员等稳定的职业。然而&#xff0c;这一莫名…

PHP函数积累

PHP函数积累 simplexml_load_string 将Xml转化为对象&#xff1b;返回对象1 <?php2 $string <<<XML3 <?xml version1.0?> 4 <document>5 <title>Forty What?</title>6 <from>Joe</from>7 <to>Jane</to>8 <…

红帽linux6的版本号,RedHat CentOS发行版本号及内核版本号对照表

Redhat 9.0———————————————2.4.20-8RHEL 3 Update 8————————————2.4.21-47RHEL 4 ————————————————2.6.9-5RHEL 4 Update 1————————————2.6.9-11RHEL 4 Update 2————————————2.6.9-22RHEL 4 Update 3———…

WPF强制更新

&#xff0c;更新的时候选择最小版本号,就是强制更新 转载于:https://www.cnblogs.com/damsoft/p/6119509.html

鸟哥的linux私房菜简答题答案,《鸟哥的Linux私房菜》7章 Linux文件与目录管理 习题答案...

自己整理了一下&#xff0c;分享给大家&#xff0c;这些习题确实是非常经典的&#xff01;1.什么是绝对路径与相对路径&#xff1f;绝对路径是相对于/目录的路径的&#xff0c;比如/home/user&#xff1b;相对路径是相对于当前工作目录的&#xff0c;比如你的系统上有个/home/u…

昨天的新的解决方法

aint(input("k:")) sumj0 sum1 for i in range(1,a1):sumsum*isumjsumjsum print(str(sumj)) 比昨天少一行…… 趁烧水的时间来写的。 明天拉链 今天要出去买东西 。 但是外面飘小雨~ 早安世界&#xff01;转载于:https://www.cnblogs.com/juemz/p/6120490.html

c语言程序设计 第三版 哈工大,c语言程序设计 哈工大 苏小红 第三章习题

这是学习课程时自己在VC上操作运行的第二章P24 T2#includevoid main(){printf("These values are:\n");float x2.5,y2.5,z2.5;printf("x%f\n",x);printf("y%f\n",y);printf("z%f\n",z);}例3.1#include main(){int x 153, b0, b1, b2,…

a的n次方的最后三位数c语言,求13的n次方(12n≤130000000000)的最后三位数,用c++编程...

#includeintmain(){longlonginti,x,y,last;/*变量last保存求X的Y次方过程中的部分乘积的后三位*///输入while(scanf("%lld,%lld",&x,&y)2){last1;x%1000;//因为一个三位数的n次方的最后三位数只和这个数的最后三位数有关y%100;//因为可以发现这个是一个轮回&…

使用Pycharm的一些错误

当在你的某个文件夹中打开xxx.py的时候&#xff08;引用numpy的py文件&#xff09; import numpy as np然后Run的时候提示module numpy has no attribute array为什么会这样呢?因为你在那个文件夹里有numpy的模块好像&#xff0c;比如struct.py或者struct.pyc或者诸如此类的文…

c语言自定义一个函数求商和余数,c – 如何在一个步骤中获得商和余数?

div会这样做见reference和示例&#xff1a;/* div example */#include #include int main (){div_t divresult;divresult div (38,5);printf ("38 div 5 > %d, remainder %d.\n", divresult.quot, divresult.rem);return 0;}输出&#xff1a;38 div 5 > 7, re…