TCMalloc优化Nginx、MySQL、Redis内存管理
与标准的glibc库的malloc相比,TCMalloc在内存的分配效率和速度要高,可以在高并发的情况下很好的控制内存的使用,提高服务器的性能,降低负载。
安装libunwind库:
如果系统是64位的需要先安装libunwind库,32位系统则不需要安装。
libunwind库为基于64位CPU和操作系统的程序提供了基本的堆栈辗转开解功能,其中包括用于输出堆栈跟踪的API用于以编程方式辗转开解堆栈的API以及支持C++异常处理机制的API。
tar
xf libunwind-1.1.
tar
.gz
cd
libunwind-1.1
CFLAGS=-fPIC .
/configure
make
CFLAGS=-fPIC
make
CFLAGS=-fPIC
install
gperftools的安装:
1
2
|
tar xzf gperftools-2.1. tar .gz
cd gperftools-2.1
|
可以加入参数只编译tcmalloc(./configure –enable-minimal、–disable-cpu-profiler、–disable-heap-profiler、–disable-heap-checker、–disable-debugalloc),64位操作系统不安装libunwind也不会报错,注意生成的库文件是libtcmalloc_minimal.*
64位操作系统,如下
1
|
. /configure
|
32位系统,不需要安装libunwind,但是一定要添加–enable-frame-pointers参数,如下
1
|
. /configure -- enable -frame-pointers
|
1
|
make && make install
|
编译安装后,输入以下命令:
1
2
|
echo '/usr/local/lib' > /etc/ld .so.conf.d /local .conf
ldconfig |
使用TCMalloc优化Nginx
为了使nginx支持google-perftools,需要在安装过程中添加”–with-google_perftools_module”选项重新编译nginx。安装如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
tar xf nginx-1.4.7. tar .gz
cd nginx-1.4.7
. /configure \
> --user=nginx \ > --group=nginx \ > --prefix= /usr/local/nginx \
> --with-pcre=.. /pcre-8 .33 \
> --with-zlib=.. /zlib-1 .2.8 \
> --with-openssl=.. /openssl-1 .0.0l \
> --with-http_stub_status_module \ > --error-log-path= /var/log/nginx/error .log \
> --http-log-path= /var/log/nginx/access .log \
> --pid-path= /var/run/nginx/nginx .pid \
> --lock-path= /var/lock/nginx .lock \
> --with-http_gzip_static_module \ > --http-proxy-temp-path= /var/tmp/nginx/proxy/ \
> --http-fastcgi-temp-path= /var/tmp/nginx/fcgi/ \
> --http-uwsgi-temp-path= /var/tmp/nginx/uwsgi \
> --http-scgi-temp-path= /var/tmp/nginx/scgi \
> --with-google_perftools_module make && make install
|
为添加线程目录:
1
2
3
4
5
|
mkdir /tmp/tcmalloc
chown -R www.www /tmp/tcmalloc
chmod 0777 /tmp/tcmalloc vi /usr/local/nginx/conf/nginx .conf #pid下一行添加
google_perftools_profiles /tmp/tcmalloc ;
|
重启nginx服务
1
|
/etc/init .d /nginx restart
|
验证tcmalloc是否在Nginx中生效
1
2
|
yum -y install lsof
lsof -n | grep tcmalloc
|
每个线程(work_processes的值)会有一行记录。每个线程文件后面的数字值就是启动的nginx的pid值。
使用TCMalloc优化MySQL
MySQL 5.1静态编译方法,./configure预编译时假设下面参数
1
|
--with-mysqld-ldflags=-ltcmalloc |
MySQL 5.5静态编译方法,cmake预编译时加上下面参数
1
|
-DCMAKE_EXE_LINKER_FLAGS= "-ltcmalloc" -DWITH_SAFEMALLOC=OFF
|
采用动态加载
1
2
|
sed -i 's@executing mysqld_safe@executing mysqld_safe\nexport LD_PRELOAD=/usr/local/lib/libtcmalloc.so@' /usr/local/mysql/bin/mysqld_safe
service mysqld restart |
验证加载tcmalloc在MySQL中是否生效,如下:
1
|
lsof -n | grep tcmalloc
|
使用TCMalloc优化redis
注意:redis-2.4以上自带jemalloc,你不需要加任何参数,通过zmalloc.c源码中我们可以看到,Redis在编译时,会先判断是否使用tcmalloc,如果是,会用tcmalloc对应的函数替换掉标准的libc中的函数实现。其次会判断jemalloc是否使得,最后如果都没有使用才会用标准的libc中的内存管理函数。所以用tcmalloc优化请谨慎使用,这两着分配器碎片率相差不大,建议用自带jemalloc
1
|
make USE_TCMALLOC= yes FORCE_LIBC_MALLOC= yes /bin/cp src/{redis-benchmark,redis-check-aof,redis-check-dump,redis-cli,redis-sentinel,redis-server} /usr/local/redis/bin
|
相关推荐
jemalloc的优化不仅限于MySQL和Nginx,它可以用于任何依赖于高效内存管理的软件,提高系统的整体性能。然而,值得注意的是,虽然jemalloc通常能带来性能提升,但在特定的工作负载或硬件配置下,可能并不总是最优选择...
内容概要:本文详细介绍了COMSOL与MATLAB联合仿真的具体实现方法及其应用。首先讲解了如何通过LiveLink进行基本操作,如加载模型、设置参数并运行仿真。接着探讨了利用MATLAB的强大功能扩展COMSOL的功能,包括参数扫描、优化算法、批量处理等高级操作。随后,文章深入讨论了基于MATLAB App Designer设计友好的GUI界面的方法,使用户能够更加便捷地控制和展示仿真结果。此外,文中还分享了许多实用的调试技巧,如实时监控参数、异常处理以及内存管理等,确保仿真过程顺利进行。最后,强调了联合仿真在提高科研工作效率方面的巨大潜力。 适合人群:对数值模拟和科学计算感兴趣的科研工作者、工程师和技术爱好者,尤其是那些希望将COMSOL与MATLAB结合起来以增强仿真能力的人群。 使用场景及目标:适用于需要高效执行复杂仿真任务的研究项目,旨在帮助用户掌握COMSOL与MATLAB联合使用的最佳实践,从而显著减少仿真时间并获得更精确的结果。 其他说明:文章不仅提供了详细的代码示例,还分享了很多实践经验,有助于读者快速上手并解决实际问题。同时提醒读者关注不同版本间的兼容性和性能优化问题。
等速万向节周期寿命试验台垂直运动模块及PLC控制设计 毕业设计说明书.doc
钢筋混凝土肋梁楼盖设计课程设计说明书.doc
特征 基于mpv,在macOS上提供最佳解码能力 设计时考虑了macOS(10.15+)的现代版本 视频和音乐所需的所有功能:字幕、播放列表、章节……以及更多! Force Touch、画中画和高级Touch Bar支持 可定制的用户界面,包括多种配色方案和屏幕控制器(OSC)布局定位 专为音频文件设计的独立音乐模式 视频缩略图 在线字幕搜索与智能本地字幕匹配 无限播放历史记录 方便的交互式视频/音频过滤器设置 完全可定制的键盘、鼠标、触控板和手势控制 面向高级用户的mpv配置文件和脚本系统 提供命令行工具和浏览器扩展
内容概要:本文详细介绍了如何利用Bagging集成学习方法进行时间序列预测,并提供了完整的Matlab代码实现。首先解释了Bagging的基本原理,强调了在时间序列预测中保持序列连续性和防止信息泄露的重要性。然后展示了如何通过滑动窗口法生成样本矩阵,并使用ARIMA与XGBoost的混合模型作为基模型,实现了Bagging集成。文中还讨论了预测阶段的聚合策略,如指数衰减加权,以及并行加速技巧。此外,作者分享了一些实践经验,如避免使用复杂的深度学习模型作为基模型,以及如何处理异常值和特征工程的具体方法。 适合人群:具有一定编程基础和技术背景的研究人员、数据科学家和工程师,特别是对时间序列预测感兴趣的读者。 使用场景及目标:适用于需要提高时间序列预测精度的实际应用场景,如电力负荷预测、销售预测等。目标是通过集成学习方法减少预测误差,提高模型稳定性。 其他说明:文中提供的代码可以直接运行,同时附带了许多实用技巧和注意事项,帮助读者更好地理解和应用Bagging集成模型。
苯 正丁醇化工原理课程设计说明书.pdf
4.0吨商用车膜片弹簧离合器设计说明书.doc
常村煤矿22采区2203综采放顶煤工作面开采设计说明书.docx
内容概要:本文介绍了一种创新的方法,利用多目标黏菌优化算法(MOSMA)来优化支持向量机(SVM)的参数C和gamma,从而提高回归预测的效果。首先详细解释了MOSMA的工作原理,包括黏菌权重更新、快速非支配排序以及自适应参数调整等关键技术点。接着展示了具体的Python代码实现,涵盖数据预处理、适应度函数定义、参数更新规则等方面。实验结果显示,在风电功率预测等多个应用场景中,相较于传统的网格搜索方法,MOSMA能够更快更有效地找到最优参数组合,显著提升了预测性能。 适合人群:从事机器学习研究或应用开发的技术人员,尤其是关注SVM参数优化及回归预测领域的从业者。 使用场景及目标:适用于需要进行高效参数寻优的回归预测任务,如风电功率预测、设备负载预测等。主要目标是通过改进SVM参数配置,获得更高的预测精度和更好的泛化能力。 其他说明:文中提供了完整的代码示例和详细的实施步骤指导,帮助读者快速理解和应用这一先进的优化技术。此外,还讨论了一些常见的注意事项和技术细节,如数据标准化、参数范围设定、并行化改造等。
项目管理知识体系.ppt
内容概要:本文详细介绍了如何利用Python进行盾构机姿态计算和隧道中线设计计算的自动化。首先,针对盾构机刀盘中心坐标的计算,提出了基于前后参考点距离的方法,并加入了异常值检测机制。其次,对于隧道中线的设计,采用三次样条曲线拟合,解决了控制点间距过大导致的“甩尾”现象。此外,文章还讨论了高程计算中的竖曲线处理方法,以及如何通过Pandas和Matplotlib实现自动报表生成和偏差分析。最后,强调了将工程经验转化为算法的重要性,旨在提高工作效率并减少人为错误。 适用人群:从事地铁隧道建设的技术人员、测量员、程序员及相关领域的研究人员。 使用场景及目标:适用于需要频繁进行盾构机姿态和隧道中线计算的工程项目,目标是提升计算效率和准确性,减轻工作人员负担,确保施工进度不受影响。 其他说明:文中提供了多个具体的Python代码片段,涵盖了从数据读取、处理到可视化的完整流程,为读者提供了一个完整的解决方案。同时,作者分享了许多实际应用中的经验和教训,帮助读者更好地理解和应用这些算法。
计算机二级Word精选二十套(标红)
项目管理体系样本.doc
蓝桥杯
SmartDNS 是一个运行在本地的 DNS 服务器,它接受来自本地客户端的 DNS 查询请求,然后从多个上游 DNS 服务器获取 DNS 查询结果,并将访问速度最快的结果返回给客户端,以此提高网络访问速度。 SmartDNS 同时支持指定特定域名 IP 地址,并高性匹配,可达到过滤广告的效果; 支持DOT,DOH,DOQ,DOH3,更好的保护隐私。 与 DNSmasq 的 all-servers 不同,SmartDNS 返回的是访问速度最快的解析结果。 支持树莓派、OpenWrt、华硕路由器原生固件和 Windows 系统等。
内容概要:本文详细介绍了基于S7-200 PLC和组态王软件构建喷泉控制系统的全过程。首先明确了系统的IO分配,包括启动按钮、停止按钮以及喷泉水泵的连接方式。接着展示了梯形图程序的设计,涵盖了基本的启停控制逻辑、定时循环和模式切换机制。随后提供了详细的接线图原理图,解释了输入输出部分的具体接线方法。最后讲述了组态王的画面设计,包括创建工程、定义变量和绘制监控界面等步骤。此外还分享了一些调试过程中遇到的问题及解决方案。 适合人群:对自动化控制感兴趣的初学者和技术人员,尤其是那些希望深入了解PLC编程和人机界面设计的人群。 使用场景及目标:适用于小型喷泉项目的实际控制系统开发,旨在帮助读者掌握PLC编程技巧、熟悉组态软件的应用,并能够独立完成类似的自动化控制系统设计。 其他说明:文中不仅包含了理论知识讲解,还附带了许多实践经验分享,如硬件配置建议、常见错误规避措施等,有助于提高实际操作能力。
内容概要:本文详细介绍了DSP28335在线升级的关键技术和实践经验。首先,文章讲解了最小系统的构建以及MemCopy函数的作用,强调了Flash操作API的使用方法,包括初始化、扇区解锁与锁定、擦除和写入等步骤。接着,讨论了参数存储管理和CMD文件的编写要点,提出了双备份升级方案和增量升级的方法。同时,阐述了上位机通信协议的设计,包括帧结构、校验方式和数据传输的具体实现。此外,还探讨了常见的升级策略,如跳转式升级、镜像式升级和差分升级,并提供了详细的代码示例。最后,强调了异常处理的重要性,特别是针对断电情况的解决方案,如硬件看门狗和状态标记的使用。 适合人群:具有一定嵌入式开发基础的技术人员,尤其是熟悉DSP架构和C/C++编程的工程师。 使用场景及目标:适用于需要进行DSP28335在线升级的项目,帮助开发者避免常见错误,提高升级的成功率和可靠性。 其他说明:文中提供了大量实际操作中的注意事项和技巧,有助于读者更好地理解和应用相关技术。
CDMA2000网络优化的研究毕业设计说明书.doc
毕业设计说明书基于移动平台的外卖小助手设计与实现.doc