关于oracle的网络配置 之前一直很乱因为其中的几个名字对应有些上头,在这里我颜色标记和对应查询的地方指明出来了,这些都是亲自实验过才说出来的。
网络原理:
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 release 5.8 (Final)
数据库版本:Oracle Database 10g Enterprise Edition Release 10.2.0.1.0
服务器1地址 主机名xcy1 ip:192.168.1.170
服务器2地址 主机名xcy2 ip:192.168.1.180
数据库1 : 实例名 orcl
数据库2:实例名 xcy
实验目标:
数据库1 通过网络链接访问数据库2
服务器1操作步骤:
[oracle@xcy1 admin]$ 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))
)
)
启动监听
[oracle@xcy1 admin]$ 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
[oracle@xcy1 admin]$
服务器2操作步骤:
[oracle@xcy2 admin]$ 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)
)
)