webservice 接口报404错误问题小结

Posted 甩手掌柜文刀

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了webservice 接口报404错误问题小结相关的知识,希望对你有一定的参考价值。

1 背景介绍

生产环境有两台应用服务器(RAC),EBS版本是12.1.3,服务器操作系统版本linux

节点一:10.192.80.87

节点二:10.192.80.88

20180512(周六) 凌晨停应用和数据库服务器,然后更换网络设备(交换机),凌晨四点重启数据库和应用服务器

2 问题描述:

1)EBS系统对接的外围系统的webservice接口无法正常访问,以HR凭证接口为例,报错信息如下:

[18-5-14 20:11:21:408 CST] 000427cd SystemErr     R AxisFault
 faultCode: {http://xml.apache.org/axis/}HTTP
 faultSubcode: 
 faultString: (404)Not Found
 faultActor: 
 faultNode: 
 faultDetail: 
	{}:return code:  404
<!DOCTYPE html PUBLIC "-//IETF//DTD HTML 2.0//EN">
<HTML><HEAD>
<TITLE>404 Not Found</TITLE>
</HEAD><BODY>
<H1>Not Found</H1>
The requested URL /webservices/SOAProvider/plsql/cux_hr_inter_pkg/ was not found on this server.<P>
</BODY></HTML>

	{http://xml.apache.org/axis/}HttpErrorCode:404

2)直接访问EBS提供的webservice接口URL:http://ebs.cic.inter:8000/webservices/SOAProvider/plsql/cux_hr_inter_pkg/,发现

奇怪的现象,有时候报错有时候不报错,通过网线连接公司内网报错,通过wifi上网测试不报错

报错信息:No WebService Provider is registered at this URL 

正常显示:

由于应用服务器是双节点的,访问ebs.cic.inter后通过F5(负载均衡) 实现随机访问某个节点,所以将上面的webservice接口URL中的域名改成IP,重试

发现访问节点一:http://10.192.80.87:8000/webservices/SOAProvider/plsql/cux_hr_inter_pkg/,正常;

访问节点二:http://10.192.80.88:8000/webservices/SOAProvider/plsql/cux_hr_inter_pkg/,报错;

3)adadmin用户登录EBS,发现报错信息:

服务供应商访问权限不可用。您可能无法查看完整的服务信息。有关详情,请查看服务供应商日志

备注:这个问题一般是webserver没有成功生成WSDL或者生成了但是没有部署成功

4)重新生成WSDL并部署

由于是多节点环境,Oracle推荐使用后台脚本生成和部署WS。这是因为在多节点环境,如果通过UI生成一个Service,我们可能不知道到底是哪个节点的服务生成了,

我们需要每个节点进行检查才知道。因此采用后台针对每一个节点生成和部署WS。

具体参考文档:“Oracle实践之EBS Integrated SOA Gateway实施指南_modify by renjun.doc”的  “5.3   ISG多节点Web Service生成和部署

a 生成WS

$ cd $FND_TOP/bin

$ soagenerate.sh irepname=CUX_HR_INTER_PKG logfile=/tmp/cux_ws_gen.log

查看/tmp/cux_ws_gen.log的日志如下:

########################

Please see Service Provider logs for more details
ServiceGenerator invoked at : Tue May 15 11:32:01 CST 2018

Using following properties :-

INST_TOP = /ebsapp/inst/apps/EBS2_ebsapp2
OAFM oc4j.properties = /ebsapp/inst/apps/EBS2_ebsapp2/ora/10.1.3/j2ee/oafm/config/oc4j.properties
EXTERNAL_URL = http://ebs.cic.inter:8000
JTFDBCFILE = /ebsapp/inst/apps/EBS2_ebsapp2/appl/fnd/12.0.0/secure/EBS.dbc
SOA_SERVER_TEMP_DIRECTORY_LOCATION = /ebsapp/inst/apps/EBS2_ebsapp2/soa/
SOA_SERVER_URL = http://ebsapp2.cic.inter:8000
SOA_ENABLE_STANDALONE_LOGGING = true
SOA_CREATE_DB_CONN_CONTEXT = true


irepName is : CUX_HR_INTER_PKG
ClassId = 4412
Generating service with classId = 4412
WSDL Location = /ebsapp/inst/apps/EBS2_ebsapp2/soa//PLSQL/4412/CUX_HR_INTER_PKG_soap.wsdl

Service Generated.
ServiceGenerator executed successfully.Please clear the middle tier cache for the changes to reflect on the IREP UI correctly
ServiceGenerator ends at : Tue May 15 11:33:54 CST 2018

在$INST_TOP/soa/PLSQL/4412/下成功生成相关文件

$ cd $INST_TOP/soa/PLSQL/4412

$ ll

total 52
-rw-r----- 1 ebsapp ebsapp 1245 May 15 12:49 AppsContextHeader.wsdl
-rw-r----- 1 ebsapp ebsapp 13138 May 15 12:49 APPS_ISG_PROCESS_HR_INTER_CUX_HR_INTER_PKG-24PROCESS_HR_I.xsd
-rw-r----- 1 ebsapp ebsapp 3007 May 15 12:49 CUX_HR_INTER_PKG_soap_http.wsdl
-rw-r----- 1 ebsapp ebsapp 3240 May 15 12:49 CUX_HR_INTER_PKG_soap.wsdl
-rw-r----- 1 ebsapp ebsapp 614 May 15 12:49 CUX_HR_INTER_PKG.wsdl
-rw-r----- 1 ebsapp ebsapp 277 May 15 12:49 ISG_PROCESS_HR_INTER_drop.sql
-rw-r----- 1 ebsapp ebsapp 11486 May 15 12:49 ISG_PROCESS_HR_INTER.sql
-rw-r----- 1 ebsapp ebsapp 2916 May 15 12:49 PROCESS_HR_INTER.wsdl

b  部署WS

$ cd $FND_TOP/bin

$ soadeploy.sh irepname=CUX_HR_INTER_PKG logfile=/tmp/cuxsoadeploy.log

查看部署WS的日志 /tmp/cuxsoadeploy.log ,如下:

########################

Please see Service Provider logs for more details
ServiceDeployer invoked at : Tue May 15 10:35:10 CST 2018

Using following properties :-

INST_TOP = /ebsapp/inst/apps/EBS2_ebsapp2
OAFM oc4j.properties = /ebsapp/inst/apps/EBS2_ebsapp2/ora/10.1.3/j2ee/oafm/config/oc4j.properties
EXTERNAL_URL = http://ebs.cic.inter:8000
JTFDBCFILE = /ebsapp/inst/apps/EBS2_ebsapp2/appl/fnd/12.0.0/secure/EBS.dbc
SOA_SERVER_TEMP_DIRECTORY_LOCATION = /ebsapp/inst/apps/EBS2_ebsapp2/soa/
SOA_SERVER_URL = http://ebsapp2.cic.inter:8000
SOA_CREATE_DB_CONN_CONTEXT = true


irepName is : CUX_HR_INTER_PKG
Policy = USERNAME_TOKEN
Deploying Service for IRepName CUX_HR_INTER_PKG
ClassId = 4412
Error in Service Deployment.
SystemError: Error while sending message to server. http://ebsapp2.cic.inter:8000/webservices/SOAProvider/EbizAuth?DeployService=4412&soa_ticket=NL4TxBfZdo-bW-_0WFWF6Q..&authtype=USERNAME_TOKEN&
oracle.apps.fnd.soa.util.SOAException: SystemError: Error while sending message to server. http://ebsapp2.cic.inter:8000/webservices/SOAProvider/EbizAuth?DeployService=4412&soa_ticket=NL4TxBfZdo-bW-_0WFWF6Q..&authtype=USERNAME_TOKEN&
at oracle.apps.fnd.soa.provider.util.ServerAccess.sendMessageToServer(ServerAccess.java:92)
at oracle.apps.fnd.soa.ui.ProviderAccess.deployService(ProviderAccess.java:129)
at oracle.apps.fnd.soa.provider.ServiceDeployer.deploySOAService(ServiceDeployer.java:84)
at oracle.apps.fnd.soa.provider.ServiceDeployer.deploySingleService(ServiceDeployer.java:112)
at oracle.apps.fnd.soa.provider.ServiceDeployer.main(ServiceDeployer.java:488)

由部署日志可以看出部署失败。

 3 原因分析

节点一一切正常,节点二SOA访问有问题,webservice接口的ws无法部署。

1)假设一:可能之前重启应用服务器节点二的时候,重启存在问题,导致SOA服务没有起成功;

      建议解决方法:重启应用服务器

2)假设二:可能跟缓存有关, oafm和oacore 这部分缓存估计是写在磁盘文件里的,重启不会清理,而是直接读取以前缓存的数据 ,所以需要手工清理掉,再去读取最新的配置,

                   可能是ip地址变动或者网络配置变动导致的,一般不会出现。

      建议处理方法:清理高速缓存,然后重启应用服务器

 

 4 实际解决方法

这边是下午先清了高速缓存,然后晚上将节点二服务器重启,能够成功访问节点二:http://10.192.80.88:8000/webservices/SOAProvider/plsql/cux_hr_inter_pkg/,问题解决,但是不确定跟下午清高速缓存是否有关。问题的具体原因后面遇到再继续补充。

以上是关于webservice 接口报404错误问题小结的主要内容,如果未能解决你的问题,请参考以下文章

用webservice的客户端访问webservice服务端时,报以下异常,找了好久没发现问题,各位大虾来看看吧。。

nodejs调用webservice接口返回500是啥原因

Linux上部署REST接口的应用报404

C# mvc 同样的程序包发布,iis多台webservice可以访问,一台webservice出现问题

从 ajax 调用 webservice asmx 返回 404 错误

axis2 调用 webService 报超时错误 org.apache.axis2.AxisFault: Connection reset