首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

Probe:Android线上OOM问题定位组件

于是我们构建了用于快速定位线上OOM问题的组件——Probe,下图是Probe组件架构,本文主要分享Probe组件是如何对线上OOM问题进行快速定位的。 ?...void Thread::ThrowOutOfMemoryError(const char* msg) 参数 msg 携带了 OOM 时的错误信息 下面两个地方都会调用上面方法抛出OutOfMemoryError...再通过Linux的mmap调用映射到用户态虚拟内存地址空间。 第一步创建匿名共享内存时,需要打开/dev/ashmem文件,所以需要一个FD(文件描述符)。...这是在Linux中分配大块内存的常用方式。其分配的是虚拟内存,对应页的物理内存并不会立即分配,而是在用到的时候触发内核的缺页中断,然后中断处理函数再分配物理内存。 调用clone方法进行线程创建。...在/proc/pid/limits描述着Linux系统对对应进程的限制,其中Max open files就代表可创建FD的最大数目。

1.2K20

Probe:Android线上OOM问题定位组件

于是我们构建了用于快速定位线上OOM问题的组件——Probe,下图是Probe组件架构,本文主要分享Probe组件是如何对线上OOM问题进行快速定位的。 ?...void Thread::ThrowOutOfMemoryError(const char* msg) 参数 msg 携带了 OOM 时的错误信息 下面两个地方都会调用上面方法抛出OutOfMemoryError...再通过Linux的mmap调用映射到用户态虚拟内存地址空间。 第一步创建匿名共享内存时,需要打开/dev/ashmem文件,所以需要一个FD(文件描述符)。...这是在Linux中分配大块内存的常用方式。其分配的是虚拟内存,对应页的物理内存并不会立即分配,而是在用到的时候触发内核的缺页中断,然后中断处理函数再分配物理内存。 调用clone方法进行线程创建。...在/proc/pid/limits描述着Linux系统对对应进程的限制,其中Max open files就代表可创建FD的最大数目。

1.2K20

TCP的MTU Probe和MSS(2)

在上一篇《TCP的MTU Probe和MSS(1)》介绍了TCP使用MTU Probe来避免PMTU变小而导致发送失败的方法。...作为完整的MTU Probe还要有一套机制,用于及时增大MSS,从而可以发送更大的报文。 今天,就让我们看看TCP的PMTU Probe如何解决这一问题的。...接下来进入tcp_mtu_probe,其入口先进行“合法性”检查,判定哪些情况不适合做MTU探测。 ? 例如没有打开TCP MTU Probe,则这个函数直接返回。...数据包成功的发送到了对端,本端的TCP再次进入MTU探测函数tcp_mtu_probe。 ?...至此,TCP MTU Probe的原理已经分析完毕,做一个简单的总结:当PMTU变小时,MTU Probe通过丢包发现这种情况,从而不断的降低当前MSS值,达到成功发送的目的。

2.6K20

Linux Linux内核参数调优

关于调优的建议: 1、出错时,可以查看操作系统日志,可能会找到一些有用的信息 2、尽量不要“批量”修改内核参数,笔者就曾这么干过,结果“调优”后,性能反而下降,事务出错数反而增加,所以,调优的时候可以考虑逐个参数进行调优...说明:我也不是很懂,参考自网络整理了下可能需要调整的一些参数 net.core.wmem_max=124928 发送套接字缓冲区大小的最大值(以字节为单位),参考值873200 net.core.rmem_max...net.ipv4.tcp_keepalive_probes=9 net.ipv4.tcp_keepalive_intvl=75 意思是如果某个TCP连接在idle 2个小时(7200s)后,内核才发起探测(probe...如果probe 9次(每次75秒)不成功,内核才彻底放弃,认为该连接已失效,对服务器而言,显然上述值太大....net.ipv4.tcp_fin_timeout=30 默认值60,这个参数决定了它保持在FIN-WAIT-2状态的时间,参考值 30(一般来说FIN-WAIT-2的连接也极少) net.ipv4.

6.7K31

Linux内核参数调优

用法: vim /etc/sysctl.conf #修改内容 sysctl -p #生效 相关参数仅供参考,具体数值还需要根据机器性能,应用场景等实际情况来做更细微调整。...net.core.netdev_max_backlog = 400000 #该参数决定了,网络设备接收数据包的速率比内核处理这些包的速率快时,允许送到队列的数据包的最大数目。...net.core.somaxconn = 100000 #Linux kernel参数,表示socket监听的backlog(监听队列)上限 net.core.wmem_default = 11059200...net.ipv4.tcp_fin_timeout = 10 #表示如果套接字由本端要求关闭,这个参数决定了它保持在FIN-WAIT-2状态的时间。...参数值为布尔值,1表示接受,0表示不接受。 #在充当网关的linux主机上缺省值为1,在一般的linux主机上缺省值为0。 #从安全性角度出发,建议你关闭该功能。

3.9K20

Linux内核参数调优

再来看看linux内核常用的参数优化: Linux内核参数优化可以根据不同的应用场景进行调整,以提高系统性能和稳定性。...以下是一些常见的Linux内核参数优化: 文件系统缓存参数:文件系统缓存是Linux系统中的重要性能因素之一,可以通过调整以下参数进行优化: vm.dirty_background_ratio:设置脏页...网络参数:网络性能是Linux系统中的另一个关键因素,可以通过以下参数进行优化: net.core.somaxconn:设置TCP半连接队列的最大长度,建议设置为1024或更高。...内存管理参数:内存管理是Linux系统的核心,可以通过以下参数进行优化: vm.swappiness:设置内存交换的程度,建议设置为10-15。...进程管理参数:进程管理是Linux系统的另一个重要方面,可以通过以下参数进行优化: kernel.pid_max:设置系统中最大进程ID号,建议设置为65536或更高。

45221
领券