发表于 2018-9-12 10:06:09

ORACLE网络配置介绍

  关于oracle的网络配置 之前一直很乱因为其中的几个名字对应有些上头,在这里我颜色标记和对应查询的地方指明出来了,这些都是亲自实验过才说出来的。
  网络原理:
http://blog.itpub.net/attachment/201404/20/29479238_1397996874sWlF.jpg
  1 客户端通过配置好的ip、端口、服务名 连接 监听程序。
  2 监听程序通过sid名去连接数据实例。
  3 数据库实例创建一个服务器进程,然后把服务器进程的地址告诉监听。
  4监听在把服务器地址告诉客户端。
  5 客户端拿着这个地址直接去连接数据库实例,客户端会把用户名和密码给服务器进程,服务器进程验证通过后,正式建立链接,以后的客户端和数据库实例连接都不经过监听了。
  注意:
  客户端和数据库实例一旦连接以后,及时监听程序挂了以后,也没任何影响。
  我通常把监听程序理解为 红娘,就是把客户端和数据库实例牵红线的,一点双方同意,他就退出不妨碍他们办事了。
  配置方式:
  服务端: 配置监听
  cd $ORACLE_HOME/network/admin/listener.ora
  -------------------------------------------------------------------
  #监听位置
  LISTENER =
  (DESCRIPTION =                                    对应本机地址|主机名
  (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.170)(PORT = 1522))
  )
  #数据库服务
  SID_LIST_LISTENER =
  (SID_LIST =
  (SID_DESC =
  (GLOBAL_DBNAME =asmdb)   --> show parameter db_unique_name
  (ORACLE_HOME = /u01/app/oracle/product/10.2.0/db_1)
  (SID_NAME = asmdb)               -->echo $ORACLE_SID
  )
  )
  客户端:只需要配置服务命名
  cd $ORACLE_HOME/network/admin/tnsnames.ora
  -------------------------------------------
  170 =
  (DESCRIPTION =
  (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.170)(PORT = 1522))
  (CONNECT_DATA =
  (SERVER = DEDICATED)
  (SERVICE_NAME = asmdb)       -->lsnrctl status --> Service "asmdb" | show parameter service_names
  )
  )
  实例操作验证真理:
  实验环境介绍:

  服务器系统版本:CentOS>
  数据库版本:Oracle Database 10g Enterprise Edition>  服务器1地址主机名xcy1   ip:192.168.1.170
  服务器2地址主机名xcy2   ip:192.168.1.180
  数据库1 : 实例名 orcl
  数据库2:实例名xcy
  实验目标:
  数据库1 通过网络链接访问数据库2
  服务器1操作步骤:
  $ vim /u01/app/oracle/product/10.2.0/db_1/network/admin/listener.ora
  SID_LIST_LISTENER =
  (SID_LIST =
  (SID_DESC =
  (SID_NAME = PLSExtProc)
  (ORACLE_HOME = /u01/app/oracle/product/10.2.0/db_1)
  (PROGRAM = extproc)
  )
  SID_LIST_LISTENER =
  (SID_LIST =
  (SID_DESC =
  (GLOBAL_DBNAME = orcl)
  (ORACLE_HOME = /u01/app/oracle/product/10.2.0/db_1)
  (SID_NAME = orcl)
  )
  )
  LISTENER =
  (DESCRIPTION_LIST =
  (DESCRIPTION =
  (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1))
  (ADDRESS = (PROTOCOL = TCP)(HOST =192.168.1.180)(PORT = 1521))
  )
  )
  启动监听
  $ lsnrctl start
  LSNRCTL for Linux: Version 10.2.0.1.0 - Production on 21-APR-2014 04:53:59
  Copyright (c) 1991, 2005, Oracle.All rights reserved.
  Starting /u01/app/oracle/product/10.2.0/db_1/bin/tnslsnr: please wait...
  TNSLSNR for Linux: Version 10.2.0.1.0 - Production
  System parameter file is /u01/app/oracle/product/10.2.0/db_1/network/admin/listener.ora
  Log messages written to /u01/app/oracle/product/10.2.0/db_1/network/log/listener.log
  Listening on: (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(KEY=EXTPROC1)))
  Listening on: (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=192.168.1.180)(PORT=1521)))
  Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=IPC)(KEY=EXTPROC1)))
  STATUS of the LISTENER
  ------------------------
  Alias                     LISTENER
  Version                   TNSLSNR for Linux: Version 10.2.0.1.0 - Production
  Start Date                21-APR-2014 04:53:59
  Uptime                  0 days 0 hr. 0 min. 3 sec
  Trace Level               off
  Security                  ON: Local OS Authentication
  SNMP                      OFF
  Listener Parameter File   /u01/app/oracle/product/10.2.0/db_1/network/admin/listener.ora
  Listener Log File         /u01/app/oracle/product/10.2.0/db_1/network/log/listener.log
  Listening Endpoints Summary...
  (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(KEY=EXTPROC1)))
  (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=192.168.1.190)(PORT=1521)))
  Services Summary...
  Service "xcy" has 1 instance(s).
  Instance "xcy", status UNKNOWN, has 1 handler(s) for this service...      ---这表明服务器已经启用生效,服务进程在。
  The command completed successfully
  $
  服务器2操作步骤:
  $ vim /u01/app/oracle/product/10.2.0/db_1/network/admin/tnsnames.ora
  # tnsnames.ora Network Configuration File: /u01/app/oracle/product/10.2.0/db_1/network/admin/tnsnames.ora
  # Generated by Oracle configuration tools.
  XCY =
  (DESCRIPTION =
  (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.180)(PORT = 1521))
  (CONNECT_DATA =
  (SERVER = DEDICATED)
  (SERVICE_NAME = xcy)
  )
  )
  EXTPROC_CONNECTION_DATA =
  (DESCRIPTION =
  (ADDRESS_LIST =
  (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1))
  )
  (CONNECT_DATA =
  (SID = PLSExtProc)
  (PRESENTATION = RO)
  )
  )
  $ sqlplus scott/tiger@xcy

  SQL*Plus:>  Copyright (c) 1982, 2005, Oracle.All rights reserved.
  Connected to:

  Oracle Database 10g Enterprise Edition>  With the Partitioning, OLAP and Data Mining options
  SQL>
  也可以进行直连方式:
  $ sqlplus scott/tiger@192.168.1.180:1521/xcy

  SQL*Plus:>  Copyright (c) 1982, 2005, Oracle.All rights reserved.
  Connected to:

  Oracle Database 10g Enterprise Edition>  With the Partitioning, OLAP and Data Mining options
  SQL>
  如果链接不上的情况出现,我在这里提供一下简单的排错思路:
  sqlplus scott/tiger@xcy
  1 在服务器端 查看监听程序是否启动 命令: lsnrctl status
  2 在服务器端配置tnsnames.ora 然后进行链接 命令:sqlplus scott/tiger@xcy 如果不可链接那么说明服务器端配置有问题,反之客户端的问题。
  3 在客户端进行 监听文件是否可以读取正常,命令:tnsping 【实例名】比如: tnsping xcy   如果显示OK (20 msec) 则表明正常,如果不能平通请仔细检查tnsnames.ora文件。
  好了 先简单描述这些吧,因为我也是在学习当中,所以有很多地方不是很全面。
  在上述描述中如果有不正确的地方,麻烦多多指出来。我会改正的。说了这么多希望能对和我一样刚入门的同学一些帮助,少走一些弯路。

页: [1]
查看完整版本: ORACLE网络配置介绍