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. Flask 中的模板语言 Jinja2 及 render_template 的深度用法

    是时候开始写个前端了,Flask中默认的模板语言是Jinja2 现在我们来一步一步的学习一下 Jinja2 捎带手把 render_template 中留下的疑问解决一下 首先我们要在后端定义几个字符 ...

  2. jQuery(JavaScript代码库)——dialog对话框

    配置对话框: $("#add-user-modal").dialog({ autoOpen : false, //这个属性为true的时候dialog被调用的时候自动打开dialo ...

  3. Mikrotik: Setup SSTP Server for Windows 10 Client

    原文: http://www.dr0u.com/mikrotik-setup-sstp-server-for-windows-10-client/ Basic how-to on SSTP for a ...

  4. highcharts实现组织机构的点击选中和取消选中事件

    代码   Highcharts.chart('container', { chart: { height: 600, inverted: true }, title: { text: 'Highsof ...

  5. Typescript 学习 - 类

    class class 并不是一种新的数据结构,只是在函数原型基础上的语法糖 class People { hand: number; constructor(hand: number) { this ...

  6. Prometheus安装部署说明

    本文主要介绍了如何二进制安装Prometheus.使用 Node Exporter 采集主机信息并使用Grafana来进行图形化的展示. 1. 安装Prometheus Server Promethe ...

  7. python安装 hanlp +使用 坑坑坑。。。填填填。。。

    刚开始用都不知道要怎么安装,包括什么文件.百度了下发现正常安装就可以用,不用下多余的东西,但是但是但是但是但是但是但是但是 用pycharm安装不行,pip安装不行,也是见鬼了. 解决方法: 1.手动 ...

  8. 哈夫曼树的构建(C语言)

    哈夫曼树的构建(C语言) 算法思路: 主要包括两部分算法,一个是在数组中找到权值最小.且无父结点两个结点位置,因为只有无父结点才能继续组成树: ​ 另一个就是根据这两个结点来修改相关结点值. 结构定义 ...

  9. TCP和UDP的差异

    TCP建立连接 如果有人问TCP如何建立连接?大部分的回答都是三次握手成功,就建立连接了. 那么握手的目的是什么呢? 1)告知对方自己的序号 2)初始化资源 例如以下握手案例,握手两次由客户端主动发起 ...

  10. Linux学习笔记之Btrfs 文件系统

    0x00 btrfs文件系统简介 btrfs文件系统:技术预览版(Centos7)Btrfs(B-tree.Butter FS.Better FS),GPL授权,Orale2007提出是想用来取代Ex ...