我有一台带有IIS 8.0的Windows Server 2012。它托管了许多用户群较少的小型网站,这些网站在任何方面都不是关键任务。对于小型网站,我的意思是应用程序代码和内存占用量非常低,但由于加载的库(如EntityFramework),应用程序的内存消耗在新启动和空闲时大约为140MB。
一般来说,这对于一个成熟的网络服务器来说并不是什么大不了的事,但我只有一个带有4GB RAM的VPS,它还可以运行其他几个应用程序(数据库,BIND,hMail等)。我正在使用它作为开发服务器来使用许多不同的技术。因此,我在服务数十个~140MB w3wp时很快耗尽了RAM。
除了在空闲时暂停,我还想减少内存消耗,同时仍然使用我想要使用的任何框架或库 - 这实际上是整个事情的目的。
长话短说:由于应用程序不仅共享相同的.NET版本,而且还有一些像EF或MVC这样的库,因此在一个app_pool中运行多个站点会更有意义吗分享图书馆?或者,无论如何,每个站点都会加载自己的副本(由于不同的应用程序域,如所讨论的here)?
奖金问题:在考虑硬件升级时,1GB内存是20美元/月,但将整个服务器放在SSD上是10美元/月。虽然我知道从页面文件中读取总是比从RAM中读取要慢得多但我正在考虑在SSD上使用大页面文件,而不是以两倍的价格购买1g的额外RAM - 再次,网站的速度不是关键,他们应该工作。这有什么意义吗?
答案 0 :(得分:15)
在Process Explorer中查看w3wp进程(托管多个站点)显示它托管了几个不同的应用程序域,这些应用程序域具有加载到内存中的相同程序集的不同实例。因此,将网站迁移到单个AppPool可能无济于事。
但还有另一种选择。在IIS 8+中,您可以跨AppPools共享通用程序集。如果多个AppPools使用某些程序集,它们只会被加载到内存中一次,然后由不同的进程进行别名化。
查看this bit from asp.net和此TechNet blog post
你必须做一些设置工作,但它似乎工作得很好。