Shell脚本实现把进程负载均衡到多核CPU中

 更新时间:2014年06月21日 10:38:49   投稿:junjie  
这篇文章主要介绍了Shell脚本实现把进程负载均衡到多核CPU中,可以把进程指定运行在某个CPU中,需要的朋友可以参考下

有时候,由于架构设计或其他业务本身特点原因,导致有些应用使用CPU很不均衡,所以业务处理集中在一个CPU上,而其它CPU闲得在睡觉。这里有个简单的优化方案实现将各个线程绑定到到多个CPU,从而实现性能的提高。

虽然CPU是一个不错的思路,但是不是杀手锏,其性能能提高多少依赖于各个线程的性能分布是否均匀;所以最好的办法是优化你的程序架构。

在这里分享一个Shell脚本(脚本名为bindcpu2p.sh),通过该脚本可将该进程均匀负载到各个CPU上。

复制代码 代码如下:
#!/bin/sh
pids=`/sbin/pidof $1`
cpunum=`cat /proc/cpuinfo | grep processor | wc -l`
 
cpuidx=0
for pid in $pids
do
    /usr/bin/taskset -cp ${cpuidx} ${pid}
    cpuidx=$(($cpuidx+1))
    cpuidx=$(($cpuidx%$cpunum))
    echo $cpuidx
done

使用方法 $> ./bindcpu2p.sh progressname

注:请兄弟们检视下代码,能帮忙调试下就最好不过了。

相关文章

  • Linux 解压缩文件到指定目录

    Linux 解压缩文件到指定目录

    tar是Linux中常用的打包、压缩、加压缩工具,tar的参数很多,这里仅仅列举常用的压缩与解压缩参数,本文重点讲解Linux 解压缩文件到指定目录,需要的朋友可以参考下
    2023-02-02
  • Linux Shell 脚本编程入门教程

    Linux Shell 脚本编程入门教程

    Linux的Shell种类众多,常见的有:Bourne Shell(/usr/bin/sh或/bin/sh)、Bourne Again Shell(/bin/bash)、C Shell(/usr/bin/csh)、K Shell(/usr/bin/ksh)、Shell for Root(/sbin/sh),Shell是用户与Linux操作系统沟通的桥梁,对本文感兴趣的朋友一起看看吧
    2015-11-11
  • 关于shell的几个不为人知却十分有用的命令分享

    关于shell的几个不为人知却十分有用的命令分享

    这篇文章主要介绍了关于shell的几个不为人知却十分有用的命令,需要的朋友可以参考下
    2016-03-03
  • linux命令行批量创建目录详解

    linux命令行批量创建目录详解

    这篇文章主要介绍了linux命令行批量创建目录详解的相关资料,需要的朋友可以参考下
    2017-04-04
  • Linux命令每天必学之 useradd/adduser 新增用户

    Linux命令每天必学之 useradd/adduser 新增用户

    Linux下useradd或adduser命令用来建立用户帐号和创建用户的起始目录,使用权限是超级用户。接下来通过本文给大家介绍每天必学Linux命令之 useradd/adduser 新增用户的相关知识,需要的朋友参考下吧
    2018-10-10
  • Shell中的while循环几种使用实例详解

    Shell中的while循环几种使用实例详解

    今天小编就为大家分享一篇关于Shell中的while循环几种使用实例详解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-03-03
  • 查看linux中某个端口(port)是否被占用的方法

    查看linux中某个端口(port)是否被占用的方法

    下面小编就为大家带来一篇查看linux中某个端口(port)是否被占用的方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • shell正则表达式、grep命令和sed命令举例详解

    shell正则表达式、grep命令和sed命令举例详解

    正则表达式就是用于描述这些规则的工具,换句话说正则表达式就是记录文本规则的代码,这篇文章主要给大家介绍了关于shell正则表达式、grep命令和sed命令的相关资料,需要的朋友可以参考下
    2024-02-02
  • crontab执行失败的原因及一些解决办法

    crontab执行失败的原因及一些解决办法

    crontab 是Linux和Unix-like系统中用于设置周期性被执行的任务的工具,cron 是一个守护进程,可以定期检查 crontab 文件,并执行其中定义的命令,本文给大家介绍了crontab执行失败的原因及一些解决办法,需要的朋友可以参考下
    2024-04-04
  • shell脚本批量将文件复制到指定的文件夹下

    shell脚本批量将文件复制到指定的文件夹下

    本文主要介绍了shell脚本批量将文件复制到指定的文件夹下,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-08-08

最新评论