同事在Oracle 10g上创建一个实例,快结束时弹出一个错误,提示监听失败之类。查看服务,并无生成监听服务。于是删除重来,一连试了好几次,都是如此。
这真是令人心烦意乱。提示里面有说到端口1521,难道此端口被占用了?用netstat -aon命令看了下,并没有。而且创建实例过程中,并没有什么地方可以设置端口的。
后来试了下Net manager,手动创建了一个监听。看系统服务,发现已有listener;然后修改 tnsnames.ora 文件,创建一个连接串,连接,成功。
其实呢,我修改的那个tnsnames.ora 文件,是oracle 10g client下面的。同事先装了客户端,后来才装数据库。估计是二者有点冲突。那应对办法就是
1、创建实例
2、手动创建监听
3、修改客户端处的 tnsnames.ora
那是否一定要修改客户端的 tnsnames.ora 呢?是否客户端的优先级比数据库要高?估计不是,这个可以在操作系统的环境变量里设置的:
设置PATH。
- 1
- 2
- 1
- 2
排在前面的应该优先级高。
至于什么oracle_home之类,好像没啥卵用。也不清楚它们究竟有啥卵用。在网上抄了些,先记下来: