IIS上无法启动C#编写的WebService服务

问题概述

  本单位使用C#开发的C/S三层架构(中间一层为WebService)管理程序,放假期间有用户反映客户端程序启动时报错,错误信息为“由于目标计算机积极拒绝,无法连接”。

问题查找及解决过程

  1)首先先在我自己的电脑上运行客户端程序,看是否报相同的错误。运行客户端后发现与在用户计算机上报的错误相同;
  2)检测电脑与WebService服务器是否是通的,就是在命令行上ping服务器地址。运行结果是我的电脑是可以ping通 WebService服务器的;
  3)检查电脑是否可以访问WebService地址,方式是将客户端启动时使用的WebService地址复制到IE浏览器上,检查是否能够正常访问。检查结果是访问异常;
  4)登录WebService服务器,发现客户端程序使用的WebServic服务停止了。于是在IIS上启动相应的服务,这时IIS报错,错误消息为"另一个程序在使用此文件,进程无法访问"。开始的时候以为是WebService物理文件夹的权限不够(之前碰到过类似的问题,更新WebService的文件后,文件的访问权限减少了,导致WebService无法访问),检查文件夹权限后发现权限是给够了;
  5)将IIS中抛出的错误信息在百度上检索,发现很多碰到类似问题的原因解释是WebService使用的端口被占用了,导致WebService无法启动,于是在WebService服务器的命令行中输入netstat -ano名称,查找是哪个进程使用了与WebService服务相同的端口,最终发现了PID为XXX的某进程(简称TEMP程序)占用了端口,通过查看该进程的介绍,发现结束该进程不会造成影响,为了让用户尽快使用程序,直接将该进程结束掉。此时再在IIS中启动WebService服务,该服务顺利启动,客户端程序也可以正常运行了。

问题分析

  本单位使用的客户端程序之前一直运行正常,用户也没有反馈问题。通过与服务器运维同事沟通,发现他们在放假以后重启了WebService服务器(安装了补丁、程序等原因)。由于WebService服务器上装了TEMP程序,并且它的启动顺序比WebService的启动顺序早,因此TEMP程序占用了WebService的端口,导致后者无法启动。
  问题解决方式主要是两种,修改WebService的端口或者修改TEMP程序使用的端口。具体用哪种方式要看哪种比较省事。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值