iis 用户缓存和内核缓存的区别

iis 用户缓存和内核缓存的区别,第1张

1、IIS为了提高性能,默认情况下会对静态文件js、html、gif、png等做内部缓存,这个缓存是在服务器iis进程的内存中的。IIS这么做在很大程度上可以提高静态文件的访问性能,在正常情况下只要静态文件更新了IIS也会更新缓存。但是如果更新的静态文...

程序如果要被CPU执行,就得编译成CPU可以执行的指令,一大堆的程序就变成了一堆的指令。

一个 *** 作系统它也是一堆程序组成的,可以想象CPU的指令是很多的,但是这么多的指令中,有些指令涉及到系统底层的东西,如果有些指令错用或者使用不当是非常危险的,比如清内存、设置时钟、修改用户访问权限、分配系统资源等等,可能导致系统崩溃。

CPU将这些指令进行了分类,分为 特权指令 非特权指令 ,不让所有程序都能使用所有指令,如果所有程序都能使用,那系统崩溃就会变得非常常见了。

*** 作系统的核心是内核,它是独立于普通的应用程序,负责管理系统的进程、内存、设备驱动程序、文件和网络系统,决定着系统的性能和稳定性,所以一定要保证内核的安全。

为了保护内核的安全, *** 作系统一般都限制用户进程不能直接 *** 作内核,在32位 *** 作系统总的地址空间4G(2^32 = 4GB),实现这个限制的方式就是 *** 作系统将总的地址空间分为两个部分,对于Linux *** 作系统:

你该知道你写的程序的内存布局

总之,有1G的内核空间是每个进程共享的,剩下的3G是进程自己使用的。

在内核态下,CPU可以执行指令系统的全集,也就是说内核态进程可以调用系统的一切资源,但是特权指令只能在内核态下执行,它不直接提供给用户使用,用户态下只能使用非特权指令,也就是说用户态进程只能执行简单运算,不能直接调用系统资源。

那么CPU如何知道当前是否可以使用特权指令?

Linux *** 作系统通过区分内核空间和用户空间的这种设计,将 *** 作系统代码和用户程序代码分开,这样即使在某一个应用程序出错,也不会影响到 *** 作系统,再说,Linux *** 作系统是多任务系统,其它应用程序不也还能运行。

现代 *** 作系统基本上都是分内核空间和用户空间的做法,来 保护 *** 作系统自身的安全性和稳定性,这也是区分内核空间和用户空间的本质。

你也可以继续阅读 点击 以下文章,下面是我推荐给大家的几篇文章:

1.《 竟然把通信协议讲的如此通俗?

2.《 c++如何学习?赶紧收藏这些好书

3.《 select和epoll的前世今生

4.《 彻底明白Linux硬链接和软链接

之所以要区分内核态和用户态,应该对应结构和函数本社就有特殊的应用场景。

内核中还有专门开放出来头文件给用户态去使用,比如 netfilter queue 之类的。

所以不太明白你的需求是什么。一个头文件中还要区分内核态和用户态,那么最好的方法是分开成不同的头文件。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/8071603.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-13
下一篇 2023-04-13

发表评论

登录后才能评论

评论列表(0条)

保存