博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【Big Data 每日一题20180823】Linux 中 ulimit 作用
阅读量:4216 次
发布时间:2019-05-26

本文共 1365 字,大约阅读时间需要 4 分钟。

作用

Linux对于每个用户,系统限制其最大进程数。为提高性能,可以根据设备资源情况,设置各linux 用户的最大进程数。

ulimit主要是用来限制进程对资源的使用情况的,它支持各种类型的限制,常用的有:

  • 内核文件的大小限制
  • 进程数据块的大小限制
  • Shell进程创建文件大小限制
  • 可加锁内存大小限制
  • 常驻内存集的大小限制
  • 打开文件句柄数限制
  • 分配堆栈的最大大小限制
  • CPU占用时间限制用户最大可用的进程数限制
  • Shell进程所能使用的最大虚拟内存限制

 

可以用ulimit -a 来显示当前的各种用户进程限制。

下面我把某linux用户的最大进程数设为10000个:

     ulimit -u 10240

     对于需要做许多 socket 连接并使它们处于打开状态的 Java 应用程序而言,

     最好通过使用 ulimit -n xx 修改每个进程可打开的文件数,缺省值是 1024。

     ulimit -n 4096 将每个进程可以打开的文件数目加大到4096,缺省为1024

     其他建议设置成无限制(unlimited)的一些重要设置是:

     数据段长度:ulimit -d unlimited

     最大内存大小:ulimit -m unlimited

     堆栈大小:ulimit -s unlimited

     CPU 时间:ulimit -t unlimited

     虚拟内存:ulimit -v unlimited

     暂时地,适用于通过 ulimit 命令登录 shell 会话期间。

     永久地,通过将一个相应的 ulimit 语句添加到由登录 shell 读取的文件中, 即特定于 shell 的用户资源文件,如:

1)、解除 Linux 系统的最大进程数和最大文件打开数限制:

        vi /etc/security/limits.conf

        # 添加如下的行

        * soft noproc 11000

        * hard noproc 11000

        * soft nofile 4100

        * hard nofile 4100

       说明:* 代表针对所有用户,noproc 是代表最大进程数,nofile 是代表最大文件打开数

2)、让 SSH 接受 Login 程式的登入,方便在 ssh 客户端查看 ulimit -a 资源限制:

        a、vi /etc/ssh/sshd_config

             把 UserLogin 的值改为 yes,并把 # 注释去掉

        b、重启 sshd 服务:

              /etc/init.d/sshd restart

3)、修改所有 linux 用户的环境变量文件:

    vi /etc/profile

    ulimit -u 10000

    ulimit -n 4096

    ulimit -d unlimited

    ulimit -m unlimited

    ulimit -s unlimited

    ulimit -t unlimited

    ulimit -v unlimited

 保存后运行#source /etc/profile 使其生效

/**************************************

有时候在程序里面需要打开多个文件,进行分析,系统一般默认数量是1024,(用ulimit -a可以看到)对于正常使用是够了,但是对于程序来讲,就太少了。

修改2个文件。

转载地址:http://cyvmi.baihongyu.com/

你可能感兴趣的文章
如何用JMeter对MySQL数据库进行压测?
查看>>
Linux 性能瓶颈阈值分析
查看>>
Windows gnuplot 画图教程
查看>>
为何再次强调JDK的安装?
查看>>
集群间多台机器SSH免密码登录(两种方法实现)
查看>>
JMeter中引入外部的JAR包给bean shell 使用(提供三种方法)
查看>>
Linux下JMeter脚本如何运行?
查看>>
JMeter的堆大小如何设置?
查看>>
性能分析、调优的概念及手段
查看>>
如何完成一个严谨的权限管理系统
查看>>
Java 代码中如何获取JVM相关的信息?
查看>>
Eclipse Memory Analyzee Java内存分析工具安装教程和使用
查看>>
如何判断JVM是运行在Client模式还是Server模式?
查看>>
关于JVM 的GC收集器
查看>>
JVM 中的内存如何分配及相应的命令设置
查看>>
如何利用tcpdump来确定外部设备是否连接到服务器?
查看>>
Linux 中ps 和 top命令详解
查看>>
Linux中如何防止一个Shell脚本被重复执行?
查看>>
Linux 中使用env查看当前环境
查看>>
Linux 中执行Shell 脚本的方式(三种方法)
查看>>