解决linux下oracle tomcat 8080端口冲突问题

在启动tomcat的时候提示8080端口被占用,后来经过查找发现如下结论:将oracle与tomcat、jboss等其它占用8080端口的服务器安装在一台机器上,会出现8080端口被占用的错误

一、首先检查8080端口的使用情况
[root@olivenan root]# lsof -i :8080 -n
COMMAND  PID   USER   FD   TYPE DEVICE SIZE NODE NAME
tnslsnr 1031 oracle   12u  IPv4   2013       TCP *:webcache (LISTEN)
[root@olivenan root]# lsof -i tcp:8080 -n
COMMAND  PID   USER   FD   TYPE DEVICE SIZE NODE NAME
tnslsnr 1031 oracle   12u  IPv4   2013       TCP *:webcache (LISTEN)
发现8080端口被oracle使用,注意lsof命令参数的使用。
[root@olivenan root]# lsof -i udp:8080 -n
[root@olivenan root]# lsof -i|grep 8080
[root@olivenan root]# netstat -tln|grep 8080
tcp        0      0 0.0.0.0:8080            0.0.0.0:*               LISTEN      
[root@olivenan root]#

二、查找解决方法
解决方法一、
将*.dispatchers='(PROTOCOL=TCP) (SERVICE=orclXDB)'
修改为#*.dispatchers='(PROTOCOL=TCP) (SERVICE=orclXDB)'
[oracle@olivenan dbs]$ sqlplus "/as sysdba"
SQL*Plus: Release 9.2.0.4.0 - Production on Fri Jul 6 10:37:32 2007
Copyright (c) 1982, 2002, Oracle Corporation.  All rights reserved.

Connected to:
Oracle9i Enterprise Edition Release 9.2.0.4.0 - Production
With the Partitioning, OLAP and Oracle Data Mining options
JServer Release 9.2.0.4.0 - Production
SQL> shutdown immediate
Database closed.
Database dismounted.
ORACLE instance shut down.
SQL> create spfile from pfile;
File created.
SQL> startup
ORACLE instance started.
Total System Global Area  236000356 bytes
Fixed Size                   451684 bytes
Variable Size             201326592 bytes
Database Buffers           33554432 bytes
Redo Buffers                 667648 bytes
Database mounted.
Database opened.
SQL> exit
[root@olivenan root]# lsof -i :8080 -n
[root@olivenan root]
结果端口8080停止被占用

三、解决方法二
将xmlDB的端口转换为其它端口,此例转换为8082
SQL> call dbms_xdb.cfg_update(updateXML(dbms_xdb.cfg_get(), '/xdbconfig/sysconfig/protocolconfig/httpconfig/http-port/text
()', 8082));
Call completed.
SQL> exec dbms_xdb.cfg_refresh;
PL/SQL procedure successfully completed.
将ftp端口由2100转换为2111
SQL> call dbms_xdb.cfg_update(updateXML(dbms_xdb.cfg_get(),  '/xdbconfig/sysconfig/protocolconfig/ftpconfig/ftp-port/text
()',2111));
Call completed.
SQL> commit;
Commit complete.
SQL> exec dbms_xdb.cfg_refresh;
PL/SQL procedure successfully completed.
SQL>
SQL> select dbms_xdb.cfg_get from dual;
CFG_GET
--------------------------------------------------------------------------------
<xdbconfig xmlns="http://xmlns.oracle.com/xdb/xdbconfig.xsd" xmlns:xsi="http://w
SQL>
检查转换结果,发现8080,2100端口停止使用,而8082、2111端口开始使用。
[root@olivenan root]# lsof -i :8080 -n
[root@olivenan root]# lsof -i :8082 -n
COMMAND  PID   USER   FD   TYPE DEVICE SIZE NODE NAME
tnslsnr 1031 oracle   12u  IPv4  18456       TCP *:8082 (LISTEN)
[root@olivenan bin]# lsof -i :2100 -n
[root@olivenan root]# lsof -i :2111 -n
COMMAND  PID   USER   FD   TYPE DEVICE SIZE NODE NAME
tnslsnr 1031 oracle   13u  IPv4  18462       TCP *:2111 (LISTEN)
[root@olivenan root]#

四、lsof命令的使用
lsof -i TCP:port -n
lsof -i UDP:port -n
lsof -i :port -n
# lsof -i tcp:8080 -n

注:上面是解决和XDB冲突的,我发现大部分人问的是和OSE(oracle servlet engine)冲突的,现象是访问8080端口时,看到的是一个倔强的小飞猪,呵呵。

下面是解决方法:
我的oracle是装在D盘,大家可以根据自己情况找  
D:oracleora90jisinstall>sess_sh -u sys/change_on_install -role SYSDBA -s jdbc:oracle:oci8:@oradb(这里填你的服务名,我的是oradb)
--Session Shell--
--type "help" at the command line for help message
$ @serverendp.ssh admin 4321 4322 -register
$ exit
就能把原来的8080换成4321,把9090换成4322
搞定。