探究Linux 64位系统栈溢出现象 (linux 64位 栈溢出)

Linux系统一直以来都以其稳定性和安全性著称,但是这并不意味着它是完美的。其中一个严重的问题就是栈溢出。在Linux 64位系统中,栈溢出仍然是最常见的漏洞之一。本文将深入,并进一步了解如何预防和解决这些安全漏洞。

什么是栈溢出?

在计算机系统中,程序的运行需要使用栈(stack)来分配内存,栈用于保存程序执行过程中的一些临时变量和函数调用。常见的栈溢出是指当程序往栈里写入数据时,超出了栈的大小,将数据写到了已分配给其他变量的内存位置。这种情况可能会导致程序崩溃、数据损坏、攻击者利用等问题,特别是在恶意攻击下,栈溢出有可能成为黑客利用来入侵系统的手段。

在Linux 64位系统中,栈通常由高地址向低地址生长。当程序执行一个函数时,会将该函数的参数和局部变量压入栈中。栈的大小是固定的,这就意味着最多只能压入有限数量的数据。如果程序试图往栈里写入更多数据,就会导致栈溢出。

影响栈溢出的因素

在Linux 64位系统中,影响栈溢出的因素包括:

1. 缓冲区溢出:当输入的数据长度超出了变量定义时,就会导致缓冲区溢出。攻击者可以通过输入过长的串来让程序崩溃或者利用溢出漏洞入侵系统。

2. 栈保护机制的缺失:在一些软件中,缺乏栈保护机制会导致攻击者可以绕过系统的安全机制,利用栈溢出漏洞入侵系统。

3. 代码中的错误:代码中的错误可能会导致栈溢出,例如,指针过度或无效的内存访问。

防止栈溢出的方法

在Linux 64位系统中,有一些方法可以用来防止栈溢出:

1. 代码审查:通过定期审查代码可以发现和纠正代码中的错误,从而避免栈溢出。

2. 编译器选项:编译器选项可以对代码进行编译和优化,以避免栈溢出。例如,可以使用-fstack-protector选项来开启栈保护机制。

3. 栈保护工具:栈保护工具可以检测和防止栈溢出漏洞,例如,关注栈保护(SSP)、安全增强型Linux(SELinux)和内核遗留对象栈保证(KROP)等。

4. 漏洞扫描:定期扫描系统中的漏洞,及早发现和修复安全漏洞。

结论

栈溢出是Linux系统中常见的安全问题之一。通过深入了解栈溢出的原因和影响因素,以及防止栈溢出的方法,可以有效地提升系统的安全性。在Linux 64位系统中,建议要选择适合的编译器选项和栈保护工具,并定期对系统进行漏洞扫描和代码审查,以确保系统的安全性。

相关问题拓展阅读:

Linux里面JVM内存怎么设置

一、堆内存相关配置

设置历漏堆初始值

指令1:-Xms2g

指令2:-XX:InitialHeapSize=2023m

设置堆区更大值

指令1:`-Xmx2g`

指令2: -XX:MaxHeapSize=2023m

缩小堆内存的时机

-XX:MaxHeapFreeRatio=70//堆内存使用率大于70时扩张堆内存,xms=xmx时该参数无效,默认值70

扩张堆内存的时机

-XX:MinHeapFreeRatio=40//堆内存使用率小于40时缩减堆内存,xms=xmx时该参数无效,默认值40

新生代内存配置

指令1:-Xmn512m

指令2:-XX:MaxNewSize=512m

2个survivor区和Eden区大小比率

指令:-XX:SurvivorRatio=6 //S区和Eden区占新生代比率为1:6,两个S区2:6

新生代和老年代的占比

-XX:NewRatio=4 //表示新生代:老年代 = 1:4 即老年代占整个堆的4/5;默认值=2

二、方法区内存配置常用参数

初始化的Metaspace大小,

-XX:MetaspaceSize :

Metaspace更大值

-XX:MaxMetaspaceSize

三、线程栈内存配置常用参数

每个线程栈更大值

指令1:-Xss256k

指令2:-XX:ThreadStackSize=256k

注意:

栈肢扰烂设置太大,会导致线程创建减少。

栈设置小,会导致深入不够,深度的递归会导致栈溢出。

建议栈深度设置在

四、配置垃圾收集器

Serial垃圾收集器(新生代)

开启:-XX:+UseSerialGC

关闭:-XX:-UseSerialGC

//新生代使用Serial 老年代则使用SerialOld

ParNew垃圾收集器(新生代)

开启 -XX:+UseParNewGC

关闭 -XX:-UseParNewGC

//新生代使用功能ParNew 老年代则使用功能CMS

Parallel Scavenge收集器(新生代)

开启 -XX:+UseParallelOldGC

关闭 -XX:-UseParallelOldGC

//新生代使用功能Parallel Scavenge 老年代李滑将会使用Parallel Old收集器

ParallelOl垃圾收集器(老年代)

开启 -XX:+UseParallelGC

关闭 -XX:-UseParallelGC

//新生代使用功能Parallel Scavenge 老年代将会使用Parallel Old收集器

CMS垃圾收集器(老年代)

开启 -XX:+UseConcMarkSweepGC

关闭 -XX:-UseConcMarkSweepGC

G1垃圾收集器

开启 -XX:+UseG1GC

关闭 -XX:-UseG1GC

五、GC策略配置

GC并行执行线程数

-XX:ParallelGCThreads=16

新生代可容纳的更大对象

-XX:PretenureSizeThreshold=//大于此值的对象直接会分配到老年代,设置为0则没有限制。 //避免在Eden区和Survivor区发生大量的内存复制,该参数只对Serial和ParNew收集器有效,Parallel Scavenge并不认识该参数

进入老年代的GC年龄

进入老年代最小的GC年龄

-XX:InitialTenuringThreshol=7 //年轻代对象转换为老年代对象最小年龄值,默认值7,对象在坚持过一次Minor GC之后,年龄就加1,每个对象在坚持过一次Minor GC之后,年龄就增加1

进入老年代更大的GC年龄

-XX:MaxTenuringThreshold=15 //年轻代对象转换为老年代对象更大年龄值,默认值15

六、GC日志信息配置

配置GC文件路径

-Xloggc:/data/gclog/gc.log//固定路径名称生成 -Xloggc:/home/GCEASY/gc-%t.log //根据时间生成

滚动生成日志

日志文件达到一定大小后,生成另一个文件。须配置Xloggc

开启 -XX:+UseGCLogFileRotation

关闭 -XX:-UseGCLogFileRotation

-XX:NumberOfGCLogFiles=4 //滚动GC日志文件数,默认0,不滚动 -XX:GCLogFileSize=100k //GC文件滚动大小,需配置UseGCLogFileRotation,设置为0表示仅通过jcmd命令触发

jar包启动时指定对应参数,比如我的工程启动银答命令就是这样的

启动命令,打码部分为工程名

常见参数如下

1.-Xms:初始堆大小。只锋宏慧要启动,就占用的堆大小。

2.-Xmx:更大堆大小。java.lang.OutOfMemoryError:Java heap这个错误可以通过配置-Xms和-Xmx参数来设置。

3.-Xss:栈大小分配。栈是每个线程私有的区域,通常只有几百K大小,决定了函数调用的深度,而局部变量、参数都分配到栈上。

当出现大量局部变量,递归时,会发生栈空间OOM(java.lang.StackOverflowError)之类的错误。

4.XX:NewSize:设置新生代大小的绝对值。

5.-XX:NewRatio:设置年轻代和年老代的比值。比如设置为3,则新生代:老年代=1:3,新生代占总heap的1/4。

6.-XX:MaxPermSize:设置持久代大小。

java.lang.OutOfMemoryError:PermGenspace这个OOM错误需要合理调大PermSize和MaxPermSize大小。

7.-XX:SurvivorRatio:年轻代中Eden区与两个Survivor区的比值。注意,Survivor区有form和to两个。比如设置为8时,那么eden:form:to=8:1:1。

8.-XX:HeapDumpOnOutOfMemoryError:发生OOM时转储堆到文件,这是一个非常好的诊断方法。

9.-XX:HeapDumpPath:导出堆的转储文件路径。

10.-XX:OnOutOfMemoryError:OOM时,执行一个脚本,比如发送邮件报警,重启程序。后绝弊面跟着一个脚本的路径。

linux 64位 栈溢出的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于linux 64位 栈溢出,探究Linux 64位系统栈溢出现象,Linux里面JVM内存怎么设置的信息别忘了在本站进行查找喔。


数据运维技术 » 探究Linux 64位系统栈溢出现象 (linux 64位 栈溢出)