前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Linux的一些知识

Linux的一些知识

作者头像
sparkle123
发布2021-03-07 10:41:47
4980
发布2021-03-07 10:41:47
举报
文章被收录于专栏:大数据-Hadoop、Spark

Linux OS版本

yum install -y redhat-lsb

代码语言:javascript
复制
[root@bigdata001 xxx]# lsb_release -a
LSB Version:    :core-4.1-amd64:core-4.1-noarch:cxx-4.1-amd64:cxx-4.1-noarch:desktop-4.1-amd64:desktop-4.1-noarch:languages-4.1-amd64:languages-4.1-noarch:printing-4.1-amd64:printing-4.1-noarch
Distributor ID: CentOS
Description:    CentOS Linux release 7.7.1908 (Core)
Release:    7.7.1908
Codename:   Core

vi文件保存退出命令":wq"和":x"的区别

:wq 强制性写入文件并退出。即使文件没有被修改也强制写入,并更新文件的修改时间。

:x 写入文件并退出。仅当文件被修改时才写入,并更新文件修改时间,否则不会更新文件修改时间。

ulimit -a 查看用户能打开的最大进程数

代码语言:javascript
复制
[root@bigdata001 bd_manager]# ulimit -a
core file size          (blocks, -c) 0
data seg size           (kbytes, -d) unlimited
scheduling priority             (-e) 0
file size               (blocks, -f) unlimited
pending signals                 (-i) 513726
max locked memory       (kbytes, -l) unlimited
max memory size         (kbytes, -m) unlimited
open files                      (-n) 1048576
pipe size            (512 bytes, -p) 8
POSIX message queues     (bytes, -q) 819200
real-time priority              (-r) 0
stack size              (kbytes, -s) 8192
cpu time               (seconds, -t) unlimited
max user processes              (-u) 65536
virtual memory          (kbytes, -v) unlimited
file locks                      (-x) unlimited

max user processes (-u) 65536 当前用户(root)最多能创建65536个进程

Linux Thread

线程资源限制由以下几个系统参数共同决定:

/proc/sys/kernel/threads-max,有直接关系,每个进程中最多创建的的线程数目 /proc/sys/kernel/pid_max,有直接关系,系统中最多分配的pid(进程)数量 /proc/sys/vm/max_map_count,限制一个进程可以拥有的虚拟内存区域(VMA)的数量数量越大,能够创建的线程数目越多

代码语言:javascript
复制
[bd@bigdata001 ~]$ cat /proc/sys/kernel/threads-max 
1027453
[bd@bigdata001 ~]$ cat /proc/sys/kernel/pid_max 
32768
[bd@bigdata001 ~]$ cat /proc/sys/vm/max_map_count 
262144

查看某个进程状态

代码语言:javascript
复制
//得到进程号
ps -ef | grep nodemanager
//根据进程号获取指定进程当前的限制状况
cat /proc/pidxxx/limits

sysctl命令

用于运行时配置或显示内核参数,这些参数位于/proc/sys目录下 比如,永久修改

代码语言:javascript
复制
sysctl -w kernel.pid_max=4194303
sysctl -w kernel.threads-max=2061206
sysctl -w vm.max_map_count=4194303

unable to create new native thread

当发现unable to create new native thread后,应该先找到报错的进程号,然后执行cat /proc/$pid/limits,查看Max processes参数,而不是直接就去执行ulimit -u查看max user processes

因为:

修改max user processes(用户创建最大线程数)立即生效,是对操作系统而言的。

对于修改后系统直接创建的进程这个修改是有效的;

对于在修改时是运行状态的进程(称作A),这个修改是无效的;

修改后,A再创建子进程B,那么这个修改对B也是无效的,B的Max processes继承自A而不是操作系统。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Linux OS版本
  • vi文件保存退出命令":wq"和":x"的区别
  • ulimit -a 查看用户能打开的最大进程数
  • Linux Thread
  • 查看某个进程状态
  • sysctl命令
  • unable to create new native thread
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档