Linux操作系统内核参数

                                          作者:尹正杰

版权声明:原创作品,谢绝转载!否则将追究法律责任。

一./proc目录

/proc目录:
  
  内核把自己内部状态信息及统计信息,以及可配置参数通过proc伪文件系统加以输出。换句话说,该目录实际上是一个虚拟目录,该目录里面的数据实际上都映射到内存中的,该目录数据均来自于内存。 参数:
  只读:输出信息
  可写:可接受用户指定“新值”来实现对内核某功能或特性的配置 /proc/sys:
  ()sysctl命令用于查看或设定此目录中诸多参数
      sysctl -w path.to.parameter=VALUE
      sysctl -w kernel.hostname=mail.yinzhengjie.org.cn
  ()echo命令通过重定向方式也可以修改大多数参数的值
      echo "VALUE" > /proc/sys/path/to/parameter
      echo “websrv” > /proc/sys/kernel/hostname
sysctl命令:
  默认配置文件:/etc/sysctl.conf(保存着"/proc/sys"目录下所有的内核参数)
  (1)设置某参数
      sysctl -w parameter=VALUE
  (2)通过读取配置文件设置参数
      sysctl -p [/path/to/conf_file]
  (3)查看所有生效参数
      sysctl -a

1>."/proc/sys"的内核参数和"/etc/sysctl.conf"一一对应

[root@yinzhengjie ~]# egrep -v "^#|^$" /etc/sysctl.conf
net.ipv4.ip_forward =                     #定义路由转发为关闭状态
net.ipv4.conf.default.rp_filter =
net.ipv4.conf.default.accept_source_route =
kernel.sysrq =
kernel.core_uses_pid =
net.ipv4.tcp_syncookies =
kernel.msgmnb =
kernel.msgmax =
kernel.shmmax =                  #定义程序可以使用的最大共享内存数,单位为字节
kernel.shmall =
[root@yinzhengjie ~]#
[root@yinzhengjie ~]# cat /proc/sys/net/ipv4/ip_forward [root@yinzhengjie ~]#
[root@yinzhengjie ~]# echo > /proc/sys/net/ipv4/ip_forward    #临时开启路由转发功能
[root@yinzhengjie ~]#
[root@yinzhengjie ~]# cat /proc/sys/net/ipv4/ip_forward [root@yinzhengjie ~]#
[root@yinzhengjie ~]# echo /// | bc    #我们算出来kernel.shmmax其实就是64G [root@yinzhengjie ~]#
[root@yinzhengjie ~]# cat /proc/sys/kernel/shmmax          #发现该数字和上面配置文件写的大小一模一样,因此这台服务器最大能共享的内存为64G,生产环境中我们的服务器可能是256G内存大小,因此默认的64G依旧还是太小了,尤其是使用Oracle数据库时应该将其改为256G [root@yinzhengjie ~]#

2>.修改"vm.drop_caches"(清空缓冲区)参数

[root@yinzhengjie ~]# free -h
total used free shared buffers cached
Mem: .7G 844M .9G 3.9M 68M 423M
-/+ buffers/cache: 352M .4G
Swap: .9G 0B .9G
[root@yinzhengjie ~]#
[root@yinzhengjie ~]# dd if=/dev/zero of=bigfile bs=1M count=
+ records in
+ records out
bytes (1.1 GB) copied, 5.60672 s, MB/s
[root@yinzhengjie ~]#
[root@yinzhengjie ~]# free -h
total used free shared buffers cached
Mem: .7G .9G .9G 3.9M 68M 1.4G
-/+ buffers/cache: 381M .4G
Swap: .9G 0B .9G
[root@yinzhengjie ~]#
[root@yinzhengjie ~]# cat /proc/sys/vm/drop_caches [root@yinzhengjie ~]#
[root@yinzhengjie ~]# echo > /proc/sys/vm/drop_caches       #立即释放缓冲区的数据
[root@yinzhengjie ~]#
[root@yinzhengjie ~]# cat /proc/sys/vm/drop_caches [root@yinzhengjie ~]#
[root@yinzhengjie ~]# free -h
total used free shared buffers cached
Mem: .7G 407M .3G 3.9M 488K 57M
-/+ buffers/cache: 348M .4G
Swap: .9G 0B .9G
[root@yinzhengjie ~]#

3>.修改"net.ipv4.icmp_echo_ignore_all"(禁ping)参数

[root@yinzhengjie ~]# cat /proc/sys/net/ipv4/icmp_echo_ignore_all 

[root@yinzhengjie ~]#
[root@yinzhengjie ~]# echo > /proc/sys/net/ipv4/icmp_echo_ignore_all
[root@yinzhengjie ~]#
[root@yinzhengjie ~]# cat /proc/sys/net/ipv4/icmp_echo_ignore_all [root@yinzhengjie ~]#

4>.总结

  以上的修改均为临时修改的方法,会立即生效,但缺点就是重启操作系统后又会恢复到默认模式。

  因此,为了持久化保存文件内容到磁盘上,我们推荐将修改写入"/etc/sysctl.conf",可以通过system命令修改也可以手动写入。

二./sys目录

/sys目录:
  sysfs:
    为用户使用的伪文件系统,输出内核识别出的各硬件设备的相关属性信息,也有内核对硬件特性的设定信息;有些参数是可以修改的,用于调整硬件工作特性
  
  udev通过此路径下输出的信息动态为各设备创建所需要设备文件,udev是运行用户空间程序   专用工具:udevadmin, hotplug

  udev为设备创建设备文件时,会读取其事先定义好的规则文件,一般在/etc/udev/rules.d及/usr/lib/udev/rules.d目录下   该目录主要是管理硬件的,但是我们运维对它有所了解即可,因为硬件信息一半都交由操作系统来管理。

三.大数据集群内核参数优化案例

博主推荐阅读:
  https://www.cnblogs.com/yinzhengjie/p/10367447.html

Linux操作系统内核参数的更多相关文章

  1. 专家解读Linux操作系统内核中的GCC特性

    专家解读Linux操作系统内核中的GCC特性   Linux内核使用GNU Compiler Collection (GCC)套件的几个特殊功能.这些功能包括提供快捷方式和简化以及向编译器提供优化提示 ...

  2. Linux操作系统内核编译之NTFS文件系统模块支持案例

    Linux操作系统内核编译之NTFS文件系统模块支持案例 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.内核编译概述 单内核体系设计.但充分借鉴了微内核设计体系的优点,为内核引 ...

  3. DBA不可不知的操作系统内核参数

    背景 操作系统为了适应更多的硬件环境,许多初始的设置值,宽容度都很高. 如果不经调整,这些值可能无法适应HPC,或者硬件稍好些的环境. 无法发挥更好的硬件性能,甚至可能影响某些应用软件的使用,特别是数 ...

  4. 【Linux基础】Unix与Linux操作系统介绍

    一.Unix和Linux操作系统概述 1.Unix是什么 UNIX是一个计算机操作系统,一个用来协调.管理和控制计算机硬件和软件资源的控制程序. 2.Unix特点 (1)多用户:在同一时刻可以有多个用 ...

  5. Linux云计算-01_介绍以及Linux操作系统安装

    1 学习目的 兴趣爱好 技能提升 找到满意的工作 2 什么是云计算 云计算(cloud computing)是分布式计算的一种,指的是通过网络"云"将巨大的数据计算处理程序分解成无 ...

  6. Linux查看版本当前操作系统内核信息

    1. # uname -a (Linux查看版本当前操作系统内核信息) 输出 Linux xxx --generic #~-Ubuntu SMP Wed Jul :: UTC x86_64 x86_6 ...

  7. Linux系统内核参数优化

    Linux服务器内核参数优化 cat >> /etc/sysctl.conf << EOF # kernel optimization net.ipv4.tcp_fin_tim ...

  8. 操作系统内核Hack:(四)内核雏形

    操作系统内核Hack:(四)内核雏形 在本系列的前一篇文章<操作系统内核Hack:(三)BootLoader制作>中,我们制作出了一个两阶段引导BootLoader,并进入了一个内核的空壳 ...

  9. 操作系统内核Hack:(三)引导程序制作

    操作系统内核Hack:(三)引导程序制作 关于本文涉及到的完整源码请参考MiniOS的v1_bootloader分支. 1.制作方法 现在我们已经了解了关于BootLoader的一切知识,让我们开始动 ...

随机推荐

  1. idea输出文件夹没有jsp页面

    目录 idea输出文件夹没有jsp页面 问题描述 解决办法 idea输出文件夹没有jsp页面 问题描述 开始创建没有使用web的模板, 自己创建tomcat等配置, 后来启动发现没有index.jsp ...

  2. Spring Security教程(五)

    在之前的几篇security教程中,资源和所对应的权限都是在xml中进行配置的,也就在http标签中配置intercept-url,试想要是配置的对象不多,那还好,但是平常实际开发中都往往是非常多的资 ...

  3. Prometheus 介绍

    我们知道zabbix在监控界占有不可撼动的地位,功能强大.但是对容器监控显得力不从心.为解决监控容器的问题,引入了prometheus技术.prometheus号称是下一代监控.接下来的文章打算围绕p ...

  4. k8s 相关的命令

    查看node信息 kubectl describe node k8s-node- 查看dashboard token kubectl describe pod kubernetes-dashboard ...

  5. Maven 教程(20)— 使用maven-assembly-plugin插件来定制化打包

    原文地址:https://blog.csdn.net/liupeifeng3514/article/details/79777976 简单的说,maven-assembly-plugin 就是用来帮助 ...

  6. python 关于celery的定时任务队列的基本使用(celery+redis)【采用配置文件设置】

    工程结构沿用https://www.cnblogs.com/apple2016/p/11422388.html,只需修改celeryconfig.py文件即可: 1.更新celeyconfig.py文 ...

  7. AKKA Actor创建

    Actor 类定义 Actor 类需要继承AbstractActor类 实现createReceive方法,绑定各类actor收到不同类型消息对应处理不同业务逻辑 默认提供了ReceiveBuilde ...

  8. Visual Studio 调试 —— 附加到进程

    第一步:通过管理员方式打开想要附加到进程的项目. 第二步:在 “附加到进程” 对话框中的 “可用进程” 列表中,找到要附加到的程序.我的以 MyProgressTest 为例.选择调试 / 附加到进程 ...

  9. json对象与string相互转换教程

    一.说明 1.1 背景说明 json对象与string相互转换,这东西想写了很多次,但总觉得网上教程比较成熟,所以之前每次都放弃了.但今天又被string转json对象折腾了半天,实在受不了,所以还是 ...

  10. [转帖]ORACLE 12C连接时报ORA28040和ORA01017的错误

    ORACLE 12C连接时报ORA28040和ORA01017的错误 http://blog.itpub.net/12679300/viewspace-2150667/ 我一直在的处理方式是让更新or ...