• php搭建与网页服务器故障排查


    一、对于php页面完全无法访问的情况

     

    1、确认是php的问题还是iis等服务器的问题

     

    判断方法,在目录下放一个静态文件,通过浏览器判断这个静态文件可否访问。若可以访问,即为php问题。

     

    如果是IIS的问题,常见的有两种情况,一个判断的利器是telnet

     

    linuxtelnet其实更加好用,因为默认是打开回显的。而windows,则需要用 set localecho,否则看不到输入的文字

     

    1.1 防火墙禁止80端口

     

    进入telnet后,输入指令,open 域名 80

     

    如:open www.baidu.com 80

     

    如果能连接上,会出现一个黑色屏幕,等待输入

     

    提示所谓的无法打开到主机的连接,在端口80失败,则表示这个端口不可达。可能的原因有:DNS服务器没有这个域名(用nslookup查),远程主机没有开启或禁止连接(用ping等命令查),以及这里说的,防火墙没有打开80端口。

    计算机生成了可选文字: iC犷0公oft Telnet>Set10CaleCho 地回显启用 crosoftTelnet>open讨讨讨。baidu。coo555 在连接,,.b。idu.。。。…无法打开到主机的连接。在端口555:连接失败 crosoftTelnet>opennot一exists日 在连接not一exist一无法打开到主机的连接。在端口的:连接失败 crosoftTelnet>open讨讨讨。baidu。coos日 正在连接。,。.baidu.。。。…

     

    1.2 服务器上目标目录的权限设置不正确

     

    这种情况下,一般会提示要求登录的对话框,不至于显示不出来页面

     

    1.3 其他问题

     

    假设要访问的主机是www.baidu.com ,那么,用如下命令查:

    > telnet www.baidu.com 80

    会出来一个黑屏幕,这个时候速度要快,因为服务器可能不会等你输入,他期待的是一个迅速的输入。(可以先在记事本里头打好,然后粘贴进去),直接telnet可能没有localecho,可能需要盲打

     

    指令例子,括号内的字符不要输入:

     

    GET / HTTP/1.1 (回车)

    Host: www.baidu.com (回车)

    (回车)

     

    注意,在host行后有两个回车。

     

    这个是用telnet模拟浏览器对目标主机的请求。如图:

    计算机生成了可选文字: Telnetw认八剐.baidU.C0m TTP/1。12日日OK ate:Thu,2日SepZ日12日4:58:26GNT eruer:BUS/1。日 ontent一Length:93551一 ontent一T夕pe:text/htnl;cha护set=gbk ache一Cont护01:priuate xpi护es:Thu,2日SepZ日12日4:58:26GHT et一Cookie:BnIDUID=日8自PE6F33E,自E04DD65F4?3B6日B日152B:FG=1;expires=Thu,2日一Sep一4 04:58:26CHT;path=/;donain=。baidu。con 3P:CP="OT1DSPCORIU自OURIHDCOH onnection:Keep一自liue <兮doct,pehtnl><htnl><head>(st,ie>htoi{ove,fio,一,:auto 》bod夕(font:12pxa犷ial;text一align:cente护;backg护ound:林fff》bod夕,p,forn,ul,11(nargin :0;padding:O;list一st夕le:none}bod夕,for。,林f。{position:relative)td(text一align:left》 ing(border:日}a(color:林日日c}a:actiue(colo护:林f6日}林u{color:林,9,;padding:4pxl日pxspx 日;text一align:护ight}林ua<ma护gin:日SPx}林u。护eg(。argin:日}林。{"idth:68日Px;na护gin:日a uto;}林nua,林nub,。btn,林Ik(font一size:14px}林f。{Padding一left:9日Px;text一align:left}i nput(borde护:日;padding:日)林nu(height:19px;font一siZe:16px;。argin:日日4Px;text一align :left;text一indent:117px;}。s_ipt一“护("idth:418px;heig卜t:3日Px;disPla夕:inline一block; nargin一护ight:Spx;background:u护1<httP://51。bdstatic。co。/r/衬“衬/ing/i一1。0。0.png>no 一犷epeat一3日4px日;borde护:lpxsolid林b6b6b6;l,orde护一color:林,a,a,a林cdcdcd林cdcdcd林 ,aga,a;uertical一align:top}。s_iPt<"idth:4日SPx;height:22px;font:16px/22pxarial;na rgin:spx日日?px;background:林fff;outline:none;一衬ebklt一appea护ance:none}。s一btn{衬id 旧口口口口口口口

     

    注意,回复头的内容拥有非常丰富的信息,如200表示请求成功。500表示内部服务器错误等,具体信息可以看看相关文档。

     

    1.4 一点点背景知识

     

    以上的步骤涉及到浏览器发起请求的过程,介绍下或许会有帮助:

     

    1 你在浏览器的地址栏输入域名,并按下回车。

     

    2、浏览器请求DNS服务器将域名转换为IP地址——注意,这一步还和你的网页服务器(IIS或者APACHE)没有任何关系。

     

    3、浏览器向你的网页服务器请求连接——相当于我们telnet 80端口。当然, 如果你指定了端口号,他就会连接你指定的端口。但是默认端口是80,这个是rfc规定的http的端口,https端口是443,这个过程更加复杂,有密钥交换和加解密的过程,因此没办法用这种方法做trouble shooting,建议在这个阶段先搞定http的再说。

     

    4、建立了一条连接,服务器等待浏览器发请求头,浏览器发请求头。请求头以一个空行结束。

     

    5、请求头格式如下:

     

    方法【空格】请求路径(不包含域名,如/a.html或者/)【空格】协议

    HOST:请求的域名

    例如:

    GET /index.php HTTP/1.1 (回车)

    Host: www.baidu.com (回车)

    (回车)

     

    请求头可能有其他信息,例如,提交的信息,不过对于我们而言,这个就够了。

     

    方法,常用的就是getpost,一般请求网页用get,提交信息用post

     

    6、服务器处理并返回数据,包括头和网页体。

    HTTP/1.1 200 OK

    这行开头,包括了协议,以及错误代码(或成功代码),错误代码解释。

    对于浏览器而言,可能会有不少信息有用,但对于我们而言,知道代码和错误代码解释就很有必要了。

    信息体里头,可能会有很多别的东西,例如对这个信息的详细解释等。php的错误报告开启的时候,也会在这里头报告相关问题。

     

    2、确认php扩展加载。

     

    2.1isapi扩展

     

    对于isapi扩展,在主目录的配置下:

    计算机生成了可选文字: 旅管系实践教学中心属性 目口‘ 目录安全性}二TF头 网站1性能}工s、工筛选器 此资源的内容来自: ‘琳计算机上的草蒸曹{ 广另一台计算机上的共享迄〕 广重定向到姗工电) 主目录 自定义错误 }文档 本地路径迄): 万脚本资源访问辽) 反读取逗) 厂写入逻) 厂目录浏览迄) 应用程序设置 应用程序名电): 开始位置: 执行权限健〕: 应用程序池电): 厂记录访问逐) 厂索引资源辽〕 劝友管系实践教学中心> }纯脚本 }nef记t灿pr。。i 厂丽歪一刁取消}应用因}帮助!

    找到php

    计算机生成了可选文字: 映射}选项!调试 口缓存工s好工扩展屯) 应用程序扩展送)- 扩展名!可执行文件路径 动作。 鲜攀举… 通配符应用程序映射队行顺序)逻): …一盟 上移电〕}下移。,} 叮丽奢刁取消}帮助}

    若没有,添加之。

     

    2.2对于fastcgi方法

     

    另一种加载方法是fastcgi,这种方法需要判断是fastcgi引擎问题还是php问题,判断方法是跳过fastcgi,直接用cgi方式加载php.exe

     

    二、php页面部分能访问的情况

     

    简单的判断是不是这种情况的方法是,新建一个php文件,输入如下内容:

     

    <?php phpinfo(); ?>

     

    注意大小写和空格必须正确。正常情况下回输出一个phpinfo页面,如下图所示:

    计算机生成了可选文字: PHPVersion5.2.17 System BUildDat6 Configure COmmand S6FVerAPI VirtualDirectory Support ConfigurationFIIe (php.ini)Path LOad6d COnfigurationFile SC日nthisdirfor additional.inifiles additiona!.inifil6s parsed PHPAPI PHPEXtension Z.ndEXtension DebugBuild ThreadSafety ZendMemory WindowsNTCCSUPHP5.2build3790 jan6201117:26:08 cscript/nologoconfigure.js’一enable一snapshot一build"’一enable一debug一pack' 一with一snapshot一template二d:\php一sdk\snap_5_2\Vc6\X86\template”一with- php一build=d:\php一sdk\snap_5_2\Vc6\x86\php_build"”一with一pdo一oci=D:\php- sdk\oracle\instantclientlo\sdKshared’一with一ocis二D:\php一sdk\oracle \instantclient10\sdKshared"”一without一pi3web" ISAPI enabled H入功月NDOWS E:\ProgramFiles\PHP\php.ini (none) (none) 20041225 20060613 220060519 nO enabled enabled

    该页面非常有用。

     

    1、判断php文件加载正确性

     

    确认Loaded Configuration File里头加载的是不是你想要他加载的php.ini文件。有可能修改该文件错误。

     

    2、判断mysql等扩展是否加载

     

    很多时候可能会有这种情况,就是页面白屏,但是明显的,页面加载了一半。例如,tittle部分已经显示出来了,包括supersitediscuz等站点很可能出现这种情况。

     

    判断方法很简单,页面上搜索mysql,要是没有如下内容就是没有加载

     

    计算机生成了可选文字: mysql My狡LSupport enab!6d ActiVePersist6ntLinkS 0 ArtiVeLinkS 0 C!i6ntAPIVeFSIOn 5.0.51日 Dir6rtiVe LOCalVa!U6 MasterValU6 mysql.allO代persistent On On mysql.connerteetimeout 60 60 mysql.default--host 170叼lu尸 n口Value mysql.defaUlt_paSSwQrd 170叼lU已 刀O曰lU已 mysql.defaUlt_port 刀O叼lU已 刀口叼lue mysql.default--socket 刀O叼lU己 刀O留lU己 mysql.defaUlt_USer 刀O叼lU已 刀O叼lu已 mysql.max--links Unlimited Unlimited mysql.max--Persistent Unlimited Unlimited mysql.trace_mode O什 O什

     

    2.1、判断为什么没有加载

     

    主要的两种可能性:extension_dir没有配置对和没有取消注释

     

    2.2、第一种可能性

     

    extension_dir没有配置对,注意要配置到ext目录下,例如:

    extension_dir="E:\PHP\EXT"

     

    记得确认该目录是不是存在

     

    2.3、第二种可能性

     

    extension没有取消注释。看有没有这一句以及这一句前头有没有#,若有,去掉。

    [PHP_MYSQL]

    extension=php_mysql.dll

     

    2.4、其他

     

    网上的说法要拷贝两个和mysql有关的文件到windows下,不过实际配置过程中似乎与这个无关,但以上都没有解决的情况下,可以试试。

     

     

    3trouble shooting方法

     

    开启display_errorsdisplay_startup_errors,在页面上会有一些错误显示出来,例如,mysql_connect未定义等。通过这些错误提示,能针对性的找到错误的来源。

     
  • 相关阅读:
    javascript闭包
    Anaconda快速加载opencv
    Opencv3.0python: 编译报错color.cpp:7456: error: (215) scn == 3 || scn == 4 的解决方案
    Vivado 调用自定义IP核
    Xilinx与modelsim的仿真联调
    Altera三速以太网IP核使用(上篇)之快速仿真
    opencv+python视频实时质心显示
    FPGA千兆网UDP协议实现
    MySql添加数据语句
    聚合函数 及执行机理
  • 原文地址:https://www.cnblogs.com/slayercat/p/2695080.html
Copyright © 2020-2023  润新知