php maxInstances,win2008服务器IIS+fastCGI完美设置教程

帮用户配置服务器,装的WIN2008系统,在WIN2008的IIS7上用FASTCGI调使用PHP-CGI.EXE,默认只有4个进程,这样对于大流量的网站为说进程数不足带来的进程排队现象十分严重,处理方案如下

32位系统 http://www.iis.net/Downloads/files/AdminPack/TP2/AdminPack_x86.msi

64位系统 http://www.iis.net/Downloads/files/AdminPack/TP2/AdminPack_amd64.msi

下载如下工具,安装后,如下图

82314209c2b2d82f349c6b101a25910e.png

cde1ccd38b97cf4ca3e0f0d78277f444.png

增加

PHP_FCGI_MAX_REQUESTS = 10000

增加后,不使用重启IIS,就能在进程管理器看到效果。

393597337461a8a1dd52ee212014c92d.png

似乎并没有达到设定的值,不过浏览网站显著感觉到性能的提醒。

196a6195876b77bc93adad5414045b43.png

内存占使用~~ 其实微软的系统有一个不好处在于,服务器的内存占使用,要尽量让服务去用,而并不像用户端用一样,留足够多的内存给使用户的应使用程序。

我在这里要提示大家注意的是以下两个参数值得设置:

InstanceMaxRequests:fastcgi进程(php-fcgi.exe)能解决的最大请求数,超过了就要回收,默认是200

PHP_FCGI_MAX_REQUESTS:php自身控制的最大请求数,默认是500

既然要使用fastcgi去运行cgi,那一定是不想php自身去限制最大请求数!!

所以,肯定要保证InstanceMaxRequests小于 或者 等于 PHP_FCGI_MAX_REQUESTS,这样php自身永远没有机会去回收进程。

可以看micorsoft说的:

Make sure that FastCGI always recycles Php-cgi.exe processes before native PHP recycling starts. The configuration property instanceMaxRequests controls the FastCGI process-recycling behavior. This property specifies how many requests FastCGI will process before recycling. PHP also has a similar process-recycling functionality that is controlled by the environment variable PHP_FCGI_MAX_REQUESTS. By setting instanceMaxRequests to a value that is smaller than or equal to PHP_FCGI_MAX_REQUESTS, you can make sure that the native PHP process-recycling logic will never start.

建议

512M 内存的改maxInstances=50

1G 内存的改maxInstances=80

2G 内存的改maxInstances=140

再修改

InstanceMaxRequests=

把这个值改小

建议

512M 内存的改InstanceMaxRequests=200

1G 内存的改InstanceMaxRequests=300

2G 内存的改InstanceMaxRequests=500

改完, 重启IIS。

instanceMaxRequests PHP_FCGI_MAX_REQUESTS 这两个参数决定了一个php-cgi进程被创立出来之后,最多接受的PHP请求数,在lighttpd中默认配置是10000。也就是说这个php-cgi进程每接受10000次PHP请求后会终止,释放所有内存,并重新被管理进程启动。假如把它降低,比方改成100,那么php-cgi重启的周期会大大缩短,偶然的高内存操作造成的问题影响时间也会缩短。

maxInstances 这个参数指定可以启动的最大实例数目,即php-cgi.exe进程的数目。假如把它降低,比方改成100,那么在任务管理器的进程中最多只有php-cgi.exe进程,php-cgi.exe所占使用的总内存将大大减少。

我现在使用的服务器为windows 2003操作系统,4G内存,一个php-cgi.exe程序占使用7-25M内存,我把maxInstances值调为300,减少了php-cgi.exe进程的总数量,占使用内存也减小了,反应速度比以前快了不少,至少调整到多少,可根据您的站点访问量来决定。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
感谢您的提问。以下是Linux Oracle 19c的安装教程详细步骤: 1. 确认系统配置 在安装Oracle 19c之前,请确认系统配置是否满足Oracle的最低硬件要求。建议硬件要求为至少4个CPU和16GB内存。 还应确保系统有足够的磁盘空间来存储Oracle软件以及数据库文件。对于单实例,Oracle建议至少具有64GB的空间。 2. 下载Oracle 19c软件并解压 从Oracle官网下载Oracle 19c软件,并将其解压缩到您希望安装Oracle的文件夹中。 您需要登录到Oracle官网才能下载软件。 3. 安装依赖软件包 在开始安装Oracle 19c之前,您需要在系统上安装一些必需的软件包和库文件。 使用以下命令安装软件包: sudo yum install oracle-database-preinstall-19c 4. 创建Oracle用户和组 使用以下命令创建Oracle用户和组: sudo groupadd oinstall sudo groupadd dba sudo useradd -g oinstall -G dba oracle 5. 配置Oracle用户环境变量 使用以下命令编辑oracle用户的bash profile: sudo vi /home/oracle/.bash_profile 添加以下行: export ORACLE_BASE=/u01/app/oracle export ORACLE_HOME=/u01/app/oracle/product/19.0.0/dbhome_1 export ORACLE_SID=orcl export PATH=$PATH:$ORACLE_HOME/bin 注意,这些路径取决于您将Oracle软件解压缩到何处。 6. 运行Oracle安装程序 使用以下命令运行Oracle安装程序: sudo ./runInstaller 将进入Oracle 19c的安装向导。请按照向导的指示进行安装。 7. 创建数据库实例 安装Oracle后,您需要创建一个数据库实例。使用以下命令以sysdba用户身份登录到数据库: sudo su - oracle sqlplus / as sysdba 在数据库实例中执行以下命令以创建数据库: CREATE DATABASE orcl MAXINSTANCES 4 MAXLOGHISTORY 1 MAXLOGFILES 16 MAXLOGMEMBERS 3 MAXDATAFILES 100 DATAFILE '/u01/app/oracle/oradata/orcl/system01.dbf' SIZE 1G SYSAUX DATAFILE '/u01/app/oracle/oradata/orcl/sysaux01.dbf' SIZE 500M DEFAULT TEMPORARY TABLESPACE temp TEMPFILE '/u01/app/oracle/oradata/orcl/temp01.dbf' SIZE 500M DEFAULT TABLESPACE users DATAFILE '/u01/app/oracle/oradata/orcl/users01.dbf' SIZE 500M; 以上是Oracle 19c的安装教程详细步骤,希望对您有所帮助。如果您有其他问题,请随时联系我。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值