【Oracle11g】06_网络配置
1.Oracle11g在windows上访问的两种方式
1.1 通过网络访问
通过tcp/ip协议访问数据库的话,需要启动2个服务:
- OracleServiceORCL
- OracleOraDb11g_home1TNSListener
访问命令为:sqlplus scott/tiger@orcl
1.2 本地直接访问
如果是直接访问本地的话,那么只需要启动1个服务即可
- OracleServiceORCL
访问命令为:sqlplus scott/tiger
2.客户端访问服务器
Oracle11g中进行网络配置的主要文件有三个,位于$ORACLE_HOME\NETWORK\ADMIN
下的sqlnet.ora、listener.ora、tnsnames.ora文件。
1)tnsnames.ora文件
客户端的网络服务名配置信息包括服务器地址、监听端口号和数据库SID等,与服务器的监听器建立连接。配置信息保存在名为tnsnames.ora的文件中。
2)listener.ora文件
服务器端监听器配置信息包括监听协议、地址及其他相关信息。配置信息保存在名为listener.ora的文件中。在安装服务器软件时自动配置一个监听器。
2.1 监听相关内容
- 启动监听:
lsnrctl start
- 停止监听:
lsnrctl stop
- 查看监听:
lsnrctl start
1)监听的配置也可以通过netca来完成。
2)也可以直接修改$ORACLE_HOME\NETWORK\ADMIN\listener.ora文件
2.1.1 listener.ora的作用
以下是对listener.ora文件内容的详细解释
上图中1表示:在oracle对外部过程调用的时候进行的监听,此处的外部过程指的是Oracle无法实现的功能,通过c、c++、java等高级语言编写的函数。
上图中2表示:在本地计算机上通过1521端口对tcpip进行监听
2.2 sqlnet.ora的作用
2.2.1 SQLNET.AUTHENTICATION_SERVICES参数
1)当用户登录到操作系统后,如果进而允许此用户登录数据库系统,则需要在sqlnet.ora中设置SQLNET.AUTHENTICATION_SERVICES= (NTS);
2)如果设置为SQLNET.AUTHENTICATION_SERVICES= (NONE),则不允许登录到数据库系统中。
上述参数我们也可以在netca中进行配置,以下是具体的配置步骤:
首先在cmd命令窗口中打开netca
选择【命名方法配置】,点击下一步,在下图就可以看到与sqlnet.ora中的两个参数对应的中文描述
配置完成后,则会在sqlnet.ora文件中生效
2.2.2 NAMES.DIRECTORY_PATH参数
例如:不想让客户端通过
简单连接
连接到服务端,删除EZCONNECT
即可。
2.3 tnsnames.ora的作用
1)简单连接:类似conn scott/scott@a84p1l1x02meo8p:1521/orcl的连接方式,不需要客户端进行任何配置。
2)本地命名:类似conn scott/scott@orcl的连接方式,需要客户端配置一个本地命名解析文件,为$ORACLE_HOME\NETWORK\ADMIN\tnsnames.ora文件,可以使用netca配置。
以下是tnsnames.ora文件的部分内容:
该文件一般是在客户端定义,表示:我将以tcp/ip协议通过1521端口连接到100.100.0.106服务器上的orcl数据库。我在客户端mydb作为连接字符串,此处的mydb为服务名
测试服务是否能连接上:tnsping mydb
3.动态注册和静态注册
3.1 动态注册
在listener.ora中,如果有类似
LISTENER =
(DESCRIPTION_LIST =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))
(ADDRESS = (PROTOCOL = TCP)(HOST = a84p1l1x02meo8p)(PORT = 1521))
)
)
就是动态注册。动态注册的一个特点就是不需要LISTENER.ORA文件。默
认情况PMON 向LSNRCTL 注册TCP/IP协议,PORT 为1521。
以下是一个小实验:验证动态注册
我们先停止监听lsnrctl stop
,然后删除listener.ora文件,接着启动监听lsnrctl start
,通过lsnrctl status
查看状态,第一次查看状态如下:
此时的监听还没启动,过30s后再次查看
但是依旧没有生成listener.ora文件
3.2 静态注册
注册就是将数据库作为一个服务注册到监听程序,在数据
库服务器启动过程中,数据库服务器会向监听程序注册相应的
服务 。
在listener.ora中,如果有类似
SID_LIST_LISTENER =
(SID_LIST =
(SID_DESC =
(GLOBAL_DBNAME = Orcl)
(ORACLE_HOME = D:\app\Administrator\product\11.1.0\db_1)
(SID_NAME = ORCL)
)
)
,就是静态注册
以下是静态注册的步骤,使用Net Manager进行注册
打开后如下如:
点击【添加地址】后出现下图
接着选择数据库服务,则出现下图:
点击【添加数据库】
填写完相应的信息后,直接关闭窗口,提示保存,保存即可
此时,在对应的路径下生成了listener.ora文件了
停止监听,启动后查看状态,如下:
状态为UNKNOWN表示是通过静态注册的服务名。
3.3 小结
使用lsnrctl status查看某个服务是静态注册、还是动态注册;如果是UNKNOWN,表示静态注册;如果是READY,表示动态注册。
READY的服务是由PMON进程动态的注册到监听器,因此PMON进程所在的数据库一定处于打开状态,所以说这些服务名所对应的实例已经准备好(READY)接受用户的连接请求。
UNKNOWN的服务是通过编辑listener.ora而静态注册的服务名,监听器并不知道该服务名对应的实例是否打开了,所以用UNKNOWN表示。
动态注册、静态注册可以根据需要进行转换。
声明:书写博客不易,转载请注明出处,请支持原创,侵权将追究法律责任
个性签名:人的一切的痛苦,本质上都是对自己无能的愤怒
如果觉得这篇文章对你有小小的帮助的话,记得在右下角点个“推荐”哦,博主在此感谢!