首页 > 服务器 > Linux服务器 > 正文

解决Linux下Oracle Tomcat 8080端口冲突

2020-05-06 19:53:34
字体:
来源:转载
供稿:网友

在启动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 t

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

--------------------------------------------------------------------------------

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.

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表