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. Java代理(静态代理、JDK动态代理、CGLIB动态代理)

    Java中代理有静态代理和动态代理.静态代理的代理关系在编译时就确定了,而动态代理的代理关系是在运行期确定的.静态代理实现简单,适合于代理类较少且确定的情况,而动态代理则给我们提供了更大的灵活性. J ...

  2. React 获取真实Dom v8.6.2版本

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  3. 请教网友:#pragma pack(push) #pragma pack(pop)无效

    //try 一 try #pragma back(push) #pragma pack(2) struct E { char a; short b; double c; float d; char e ...

  4. 转 史上最详细的Hadoop环境搭建

    GitChat 作者:鸣宇淳 原文:史上最详细的Hadoop环境搭建 关注公众号:GitChat 技术杂谈,一本正经的讲技术 [不要错过文末活动哦] 前言 Hadoop在大数据技术体系中的地位至关重要 ...

  5. JSON Template

    public java.lang.String toString() {#if ( $members.size() > 0 ) #set ( $i = 0 )return "{\&qu ...

  6. Linux中文件权限查看和修改

    权限定义 linux文件权限分为:r读权限(4).w写权限(2).x执行权限(1) linux权限对象分为:拥有者.组用户.其他用户 权限修改: chown user:group /usr/local ...

  7. odoo 币别符号显示机制 Monetary

    //-------------------------------------------------------------------basic_fields.js init: function ...

  8. 用eclipse开发需要准备什么?

    1.到eclipse的官网上,https://www.eclipse.org/  下载好eclipse,安装好eclipse,修改eclipse.ini文件,把内存改大点,避免出现内存溢出的情况. [ ...

  9. 把jar包安装到本地Maven仓库

    使用的场景 自己写的工具类想安装到本地 从Maven仓库中下载不下来的jar 使用的步骤       首先要保证自己的Maven配置全局环境变量,如果没有配置过maven全局变量,可以按照下面的步骤配 ...

  10. 【LeetCode】搜索旋转排序数组【两次二分】

    假设按照升序排序的数组在预先未知的某个点上进行了旋转. ( 例如,数组 [0,1,2,4,5,6,7] 可能变为 [4,5,6,7,0,1,2] ). 搜索一个给定的目标值,如果数组中存在这个目标值, ...