日期:2014-05-17  浏览次数:20831 次

请教一个关于Oracle配置的问题。
我在本地安装了Oracle客户端程序,以及PL/SQL

现在需要通过PL/SQL打开内网环境中另一台测试机的数据库。

同样的地址,同样的帐号密码,同事通过配置就OK了,我这里却一直不行。不知道是何原因。
我的配置过程是
1 打开Oracle提供的Net Manager

2 创建一个服务名,按照步骤将主机地址那些都敲进去了,在第五步测试是否能连接通时遇到问题,连接不通。该帐号在同事机子是可以连通的。然后我就不管了。继续下一步

3 创建监听,新建一个监听,在监听位置那里添加了一个地址,主机就写了测试机的IP地址,端口是默认的1521
然后点击保存,没有任何提示。在关闭掉当前窗口时,提示我网络配置被修改了,问我是保存还是丢弃或者取消。
我在这里点击了保存还是没有任何效果,点击丢弃窗口就关掉了。

第2和第3步骤都是遇到了问题,求高人给些解决办法,谢谢!

------解决方案--------------------
下面是原来的帖子回复,拿过来看对lz是否有帮助撒!!!


远程连接ORACLE服务
远程服务端配置
1. 数据库配置
因为要为外界客户端提供数据服务,所以一定要将 [数据库操作模式] 配置为 "共享服务模式". 如果将操作模式配置成"专用服务器模式",导至远程客户端无法正常连接.
如果不能确定数据库的操作模式,可以打开ORACLE "Database Configuration Assistant" 工具的 "在数据库中配置数据库选项" 进行配置.
如果新建数据库一定不要忘了将 [数据库操作模式] 配置为 "共享服务模式".

2. 数据库服务
确定数据库服务已经启动.
方法: 命令行 下键入 "services.msc"
在 WINDOWS服务 窗口中找到您的数据库服务(一般都以 OracleService数据库实例名 的形式命名),查看是否为"已启动"状态,否则请启动该服务.

3. 监听程序
确定数据库已经附加到监听程序中,并且监听程序已启用.
方法: 命令行 下键入 "lsnrctl"
在 lsnrctl控制台 窗口中键入 "services 监听程序名"

如果出现 "摘要信息" 则说明监听程序已启动

如果出现 "无监听器" 字样,说明监听程序未被启动
在 lsnrctl控制台 窗口中键入 "start 监听程序名" 以启动监听程序
也可在 命令行 下键入 "services.msc"
在 WINDOWS服务 窗口中找到您的监听程序服务(一般都以 OracleOraHome92TNSListener监听程序名 的形式命名,默认的监听程序服务名为 "OracleOraHome92TNSListener"),查看是否为"已启动"状态,否则请启动该服务.

4. 网络状态
确定监听程序所使用的端口已被列入防火墙允许的行列.

本地客户端配置
1. 测试连接
方法: 命令行 下键入 "tnsping 服务端IP地址"
如果出现 "OK(XX毫秒)" 字样,说明可以与服务端建立连接.否则请检查服务端配置.

2. 添加服务名
方法: 打开ORACLE "Database Configuration Assistant" 工具 -> "本地NET服务名配置" -> "添加" -> 选择ORACLE数据库或服务(依个人服务端设置进行相应选择,我的是8i或更高版本..) -> 输入服务名(建库时输入的全局数据库名) -> TCP -> 主机名中输入服务端IP地址,端口输入服务端监听程序所监听的端口 -> 是,进行测试 -> 首次测试可能会失败,因为默认的用户名口令不一定和服务端的匹配,点击 更改登录 输入有效用户名和口令确定后如出现"测试成功",说明连接成功,点击下一步 -> 输入本地服务名 -> 直到完成.
------解决方案--------------------
其实楼主只不过是做了一个事情...就是在你本机的

%oracle安装目录%\product\10.2.0\db_1\NETWORK\ADMIN\tnsnames.ora

文件上面增加了一个对测试库机器的监听而已.

同样的,把中间一段从你同学的机器上copy过来,然后

1、确保网络是通过的,ping 测试库机器是可以ping通
2、确保监听是配置没有问题的,tnsping 监听 是可以ping通的
------解决方案--------------------
本机不用装listener

命令窗口执行

sqlplus uname/password@测试机ip:测试机端口号/servicename

例如

sqlplus dex/xiaojun@192.168.100.10:1521/prod


看是否能够登录

同理登录plsql也用这种方式

如果你的同事能够登录,而你的却不能,这表示网络有问题。
------解决方案--------------------
你安装的如果只是客户端的话,应该按照#2楼的就可以解决,万一不行的话,重装一下oracle的客户端吧。
------解决方案--------------------
主要是你的第二步没成功,第三步不影响你的连接,你是作为客户端不需要监听的, 
你可以先试试 TNSPING “你配置的连接字段串” 或是把你测试时报的错贴出来,,再请教大虾们一看便知