精华内容
下载资源
问答
  • 九、Oracle网络配置

    千次阅读 2018-06-18 01:01:55
    Oracle网络配置 一、tnsnames.ora文件详解 1、tnsnames.ora文件简介 tnsnames.ora:位于客户端,用于配置客户端连接服务端数据库连接信息。客户端服务配置信息包括:服务器地址、服务名称(数据库实例...

                                                            Oracle网络配置

    一、tnsnames.ora文件详解

    1、tnsnames.ora文件简介

    tnsnames.ora:位于客户端,用于配置客户端连接服务端数据库连接信息。客户端服务配置信息包括:服务器地址、服务名称(数据库实例)、端口号。

    2、查看数据库监听状态

    进入oracle但不登录:sqlplus/nolog
    查看监听状态:lsnrctl status
    启动监听:lsnrctl  start
    停止监听:lsnrctl  stop
    

    这里写图片描述

    3、使用可视化工具netca修改tnsnames.ora文件配置数据库客户端连接服务端

    使用netca来生成这个文件(使用管理员身份运行):
    这里写图片描述

    这里写图片描述
    这里写图片描述
    这里写图片描述
    这里写图片描述
    这里写图片描述

    这里写图片描述

    listener.ora:位于服务器端,用于时时监听客户端请求。
    监听器位于服务器端,主要信息包括监听协议(TCP/IP协议)、地址。

    查看生成的文件:F:\OracleServerAndClinet\Server\app\yang\product\11.2.0\dbhome_1\NETWORK\ADMIN
    这里写图片描述

    测试是否能ping通:cmd下
    tnsping orclLocal
    

    4、直接修改tnsnames.ora文件配置数据库客户端连接服务端

    # tnsnames.ora Network Configuration File: F:\OracleServerAndClinet\Server\app\yang\product\11.2.0\dbhome_1\network\admin\tnsnames.ora
    # Generated by Oracle configuration tools.
    
    4.9 =
      (DESCRIPTION =
        (ADDRESS_LIST =
          (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.4.9)(PORT = 1521))
        )
        (CONNECT_DATA =
          (SERVICE_NAME = orcl)
        )
      )
    

    二、listener.ora文件详解

    1、通过修改listener.ora文件配置监听

    LISTENER =
     (ADDRESS_LIST=
       (ADDRESS=(PROTOCOL=tcp)(HOST=localhost)(PORT=1521))
       (ADDRESS=(PROTOCOL=ipc)(KEY=PNPKEY)))
    
    服务端监听的客户端:(ADDRESS=(PROTOCOL=tcp)(HOST=localhost)(PORT=1521))
    服务端对调用外部PL/SQL片段的监听:(ADDRESS=(PROTOCOL=tcp)(HOST=localhost)(PORT=1521))
    

    2、通过可视化工具netca修改listener.ora文件配置监听

    这里写图片描述

    这里写图片描述
    一直往下就可以。

    三、sqlnet.ora文件详解

    1、直接修改sqlnet.ora

    sqlnet.ora:配置连接数据库的方式

    OS认证:oracle对操作系统登录用户身份的识别
    SQLNET.AUTHENTICATION_SERVICES=(NTS)
    则说明可以使用OS认证(oracle systerm certification)就只要conn / as sysdba 就可以登陆
    但如果注释掉或SQLNET.AUTHENTICATION_SERVICES=(none)
    必须要使用conn scott/scott@localhost:1521/orcl才能登陆
    
    1、在windows下,SQLNET.AUTHENTICATION_SERVICES必须设置为NTS或者 ALL才能使用OS认证;不设置或者设置为其他任何值都不能使用OS认证。
    2、在linux下,在SQLNET.AUTHENTICATION_SERVICES的值设置为ALL,或者不设置的情况下,OS验证才能成功;设置为 其他任何值都不能使用OS认证。 
    
    NAMES.DIRECTORY_PATH= (TNSNAMES,ezconnect)
    ezconnect简单连接 :
         conn scott/scott@orcl 可以直接连接
    TNSNAMES 本地命名连接:
         类似conn scott/scott@orcl的连接方式,需要客户端配置一个本地命名解析文件,
         为$ORACLE_HOME\NETWORK\ADMIN\tnsnames.ora文件,可以使用netca配置。
         
    

    NAMES.DIRECTORY_PATH=(TNSNAMES,ezconnect)图形界面配置:
    使用下图配置可以直接在sqlnet.ora文件中加上NAMES.DIRECTORY_PATH=(TNSNAMES,ezconnect)这句,就可以不用修改sqlnet.ora文件了。

    2、通过可视化工具netca配置sqlnet.ora

    这里写图片描述

    展开全文
  • oracle网络配置

    2011-04-12 10:39:10
    oracle网络配置 三个配置文件 listener.ora、sqlnet.ora、tnsnames.ora ,都是放在$ORACLE_HOME\network\admin目录下。 1. sqlnet.ora-----作用类似于linux或者其他unix的nsswitch.conf文件,通过这个文件来决定...
    oracle网络配置
    三个配置文件 listener.ora、sqlnet.ora、tnsnames.ora ,都是放在$ORACLE_HOME\network\admin目录下。

    1. sqlnet.ora-----作用类似于linux或者其他unix的nsswitch.conf文件,通过这个文件来决定怎么样找一个连接中出现的连接字符串。
    例如我们客户端输入
    sqlplus sys/oracle@orcl
    假如我的sqlnet.ora是下面这个样子
    SQLNET.AUTHENTICATION_SERVICES= (NTS)
    NAMES.DIRECTORY_PATH= (TNSNAMES,HOSTNAME)
    那么,客户端就会首先在tnsnames.ora文件中找orcl的记录.如果没有相应的记录则尝试把orcl当作一个主机名,通过网络的途径去解析它的 ip地址然后去连接这个ip上GLOBAL_DBNAME=orcl这个实例,当然我这里orcl并不是一个主机名
    如果我是这个样子
    NAMES.DIRECTORY_PATH= (TNSNAMES)
    那么客户端就只会从tnsnames.ora查找orcl的记录,括号中还有其他选项,如LDAP等并不常用。
    2. Tnsnames.ora------这个文件类似于unix 的hosts文件,提供的tnsname到主机名或者ip的对应,只有当sqlnet.ora中类似
    NAMES.DIRECTORY_PATH= (TNSNAMES) 这样,也就是客户端解析连接字符串的顺序中有TNSNAMES是,才会尝试使用这个文件。
    PROTOCOL:客户端与服务器端通讯的协议,一般为TCP,该内容一般不用改。
    HOST:数据库侦听所在的机器的机器名或IP地址,数据库侦听一般与数据库在同一个机器上,所以当我说数据库侦听所在的机器一般也是指数据库所在的机器。在UNIX或WINDOWS下,可以通过在数据库侦听所在的机器的命令提示符下使用hostname命令得到机器名,或通过ipconfig(for WINDOWS) or ifconfig(for UNIX)命令得到IP地址。需要注意的是,不管用机器名或IP地址,在客户端一定要用ping命令ping通数据库侦听所在的机器的机器名,否则需要在 hosts文件中加入数据库侦听所在的机器的机器名的解析。
    PORT:数据库侦听正在侦听的端口,可以察看服务器端的listener.ora文件或在数据库侦听所在的机器的命令提示符下通过lnsrctl status [listener name]命令察看。此处Port的值一定要与数据库侦听正在侦听的端口一样。
    SERVICE_NAME:在服务器端,用system用户登陆后,sqlplus> show parameter service_name命令察看。
    ORCL 对应的本机,SALES对应的另外一个IP地址,里边还定义了使用主用服务器还是共享服务器模式进行连接

    #你所要连接的时候输入得TNSNAME
    ORCL =
    (DESCRIPTION =
    (ADDRESS_LIST =
    #下面是这个TNSNAME对应的主机,端口,协议
    (ADDRESS = (PROTOCOL = TCP)(HOST = 127.0.0.1)(PORT = 1521))
    )
    (CONNECT_DATA =
    #使用专用服务器模式去连接需要跟服务器的模式匹配,如果没有就根据服务器的模式自动调节
    (SERVER = DEDICATED)
    #对应service_name,SQLPLUS>;show parameter service_name; 进行查看
    (SERVICE_NAME = orcl)
    )
    )
    #下面这个类似
    SALES =
    (DESCRIPTION =
    (ADDRESS_LIST =
    (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.188.219)(PORT = 1521))
    )
    (CONNECT_DATA =
    (SERVER = DEDICATED)
    (SERVICE_NAME = sales)
    )
    )
    注意:如果数据库服务器用MTS,客户端程序需要用database link时最好明确指明客户端用dedicated直连方式,不然会遇到很多跟分布式环境有关的ORACLE BUG。一般情况下数据库服务器用直接的连接会好一些,除非你的实时数据库连接数接近1000。

    3. listener.ora------listener监听器进程的配置文件
    关于listener进程就不多说了,接受远程对数据库的接入申请并转交给oracle的服务器进程。所以如果不是使用的远程的连接,listener进程就不是必需的,同样的如果关闭listener进程并不会影响已经存在的数据库连接。
    Listener.ora文件的例子
    #listener.ora Network Configuration File: #E:\oracle\product\10.1.0\Db_2\NETWORK\ADMIN\listener.ora
    # Generated by Oracle configuration tools.
    #下面定义LISTENER进程为哪个实例提供服务 这里是ORCL,并且它对应的ORACLE_HOME和GLOBAL_DBNAME 其中GLOBAL_DBNAME不是必需的除非
    #使用HOSTNAME做数据库连接

    SID_LIST_LISTENER =
    (SID_LIST =
    (SID_DESC =
    (GLOBAL_DBNAME = boway)
    (ORACLE_HOME = E:\oracle\product\10.1.0\Db_2)
    (SID_NAME = ORCL)
    )
    )
    #监听器的名字,一台数据库可以有不止一个监听器
    #再向下面是监听器监听的协议,ip,端口等,这里使用的tcp1521端口,并且使#用的是主机名
    LISTENER =
    (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = boway)(PORT = 1521))
    )
    上面的例子是一个最简单的例子,但也是最普遍的。一个listener进程为一个instance(SID)提供服务。
    监听器的操作命令
    $ORACLE_HOME/bin/lsnrctl start,其他诸如stop,status等。具体敲完一个lsnrctl后看帮助。

    上面说到的三个文件都可以通过图形的配置工具来完成配置
    $ORACLE_HOME/netca 向导形式的
    $ORACLE_HOME/netmgr
    本人比较习惯netmgr,
    profile 配置的是sqlnet.ora也就是名称解析的方式
    service name 配置的是tnsnames.ora文件
    listeners配置的是listener.ora文件,即监听器进程
    具体的配置可以尝试一下然后来看一下配置文件。

    这样一来总体结构就有了,是
    当你输入sqlplus sys/oracle@orcl的时候
    1. 查询sqlnet.ora看看名称的解析方式,发现是TNSNAME
    2. 则查询tnsnames.ora文件,从里边找orcl的记录,并且找到主机名,端口和service_name
    3. 如果listener进程没有问题的话,建立与listener进程的连接。
    4. 根据不同的服务器模式如专用服务器模式或者共享服务器模式,listener采取接下去的动作。默认是专用服务器模式,没有问题的话客户端就连接上了数据库的server process。
    5. 这时候网络连接已经建立,listener进程的历史使命也就完成了。

    #---------------
    几种连接用到的命令形式
    1.sqlplus / as sysdba 这是典型的操作系统认证,不需要listener进程
    2.sqlplus sys/oracle 这种连接方式只能连接本机数据库,同样不需要listener进程
    3.sqlplus sys/oracle@orcl 这种方式需要listener进程处于可用状态。最普遍的通过网络连接。
    以上连接方式使用sys用户或者其他通过密码文件验证的用户都不需要数据库处于可用状态,操作系统认证也不需要数据库可用,普通用户因为是数据库认证,所以数据库必需处于open状态。
    init.ora中的Remote_Login_Passwordfile对身份验证的影响
    三个可选值:
    NONE:默认值,指示Oracle系统不使用密码文件,通过操作系统进行身份验证的特权用户拥有SYSORA和SYSOPER权限
    EXCLUSIVE:
    1.表示只有一个数据库实例可以使用密码文件
    2.允许将SYSORA和SYSOPER权限赋值给SYS以外的其它用户
    SHARED:
    1.表示可以有多个数据库实例可以使用密码文件
    2.不允许将SYSORA和SYSOPER权限赋值给SYS以外的其它用户
    所以,如果要以操作系统身份登录,Remote_Login_Passwordfile应该设置为NONE
    当登录用户不是ORA_DBA组和ORA_OPER组成员时,登录数据库需要在Oracle中创建当前操作系统用户相同的用户名,如果当前用户是域用 户,则名称为:domainname\yourname,如果是本地计算机用户,则名称为:computername\yourname
    创建方法:
    create "domainname\yourname" identified externally;
    操作系统,修改HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\HOME0下面添加AUTH_PREFIX_DOMAIN,值设为FALSE,在创建Oracle用户时可以忽略 掉域名
    这种方式下,init.ora中有一个参数将影响数据库如何匹配一个windows用户和Oracle用户os_authent_prefix = ""
    缺省为空,Oracle8i以前,无该参数,而使用OPS$作为用户名前缀.(Oracle用户名最大长度限制为30个字符)

    关于域名(主机名)解析
    /etc/hosts (UNIX)
    或者windows\hosts(WIN98) winnt\system32\drivers\etc\hosts (WIN2000)
    客户端需要写入数据库服务器IP地址和主机名的对应关系。

    127.0.0.1 localhost
    192.168.0.35 oracledb oracledb
    192.168.0.45 tomcat tomcat
    202.84.10.193 bj_db bj_db

    有些时候我们配置好第一步后,tnsping 数据库服务器别名显示是成功的,
    但是sqlplus username/password@servicename不通,jdbc thin link 也不通的时候,
    一定不要忘了在客户端做这一步,原因可能是DNS服务器里没有设置这个服务器IP地址和主机名的对应关系。
    如果同时有私有IP和Internet上公有IP,私有IP写在前面,公有IP写在后面。
    编辑前最好留一个备份,增加一行时也最好用复制粘贴,避免编辑hosts时空格或者tab字符错误。

    UNIX下ORACLE多数据库的环境,OS客户端需要配置下面两个环境变量
    ORACLE_SID=appdb;export ORACLE_SID
    TWO_TASK=appdb;export TWO_TASK
    来指定默认的目标数据库

    #-------------
    平时排错可能会用到的
    1.lsnrctl status查看服务器端listener进程的状态
    LSNRCTL>; help
    The following operations are available
    An asterisk (*) denotes a modifier or extended command:
    start stop status
    services version reload
    save_config trace change_password
    quit exit set*
    show*
    LSNRCTL>; status
    :em11:
    2.tnsping 查看客户端sqlnet.ora和tnsname.ora文件的配置正确与否,及对应的服务器的listener进程的状态。
    C:\>tnsping orcl
    TNS Ping Utility for 32-bit Windows: Version 10.1.0.2.0 - Production on 16-8月 -
    2005 09:36:08
    Copyright (c) 1997, 2003, Oracle. All rights reserved.
    Used parameter files:
    E:\oracle\product\10.1.0\Db_2\network\admin\sqlnet.ora

    Used TNSNAMES adapter to resolve the alias
    Attempting to contact (DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)
    (HOST = 127.0.0.1)(PORT = 1521))) (CONNECT_DATA = (SERVER = DEDICATED) (SERVICE_
    NAME = orcl)))
    OK (20 msec)
    3.
    SQL>;show sga 查看instance是否已经启动
    SQL>; select open_mode from v$database; 查看数据库是打开还是mount状态。
    OPEN_MODE
    ----------
    READ WRITE


    使用hostname访问数据库而不是tnsname的例子
    使用tnsname访问数据库是默认的方式,但是也带来点问题,那就是客户端都是需要配置tnsnames.ora文件的。如果你的数据库服务器地址发生改变,就需要重新编辑客户端这个文件。通过hostname访问数据库就没有了这个麻烦。
    需要修改
    服务器端listener.ora
    #监听器的配置文件listener.ora
    #使用host naming则不再需要tnsname.ora文件做本地解析
    # listener.ora Network Configuration File: d:\oracle\product\10.1.0\db_1\NETWORK\ADMIN\listener.ora
    # Generated by Oracle configuration tools.
    SID_LIST_LISTENER =
    (SID_LIST =
    (SID_DESC =
    # (SID_NAME = PLSExtProc)
    (SID_NAME = orcl)
    (GLOBAL_DBNAME = boway)
    (ORACLE_HOME = d:\oracle\product\10.1.0\db_1)
    # (PROGRAM = extproc)
    )
    )
    LISTENER =
    (DESCRIPTION_LIST =
    (DESCRIPTION =
    (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC))
    )
    (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = boway)(PORT = 1521))
    )
    )
    客户端sqlnet.ora 如果确认不会使用TNSNAME访问的话,可以去掉TNSNAMES
    # sqlnet.ora Network Configuration File: d:\oracle\product\10.1.0\db_1\NETWORK\ADMIN\sqlnet.ora
    # Generated by Oracle configuration tools.
    SQLNET.AUTHENTICATION_SERVICES= (NTS)
    NAMES.DIRECTORY_PATH= (HOSTNAME)
    Tnsnames.ora文件不需要配置,删除也无所谓。
    下面就是网络和操作系统的配置问题了,怎么样能够解析我的主机名的问题了
    可以通过下面的方式连接
    sqlplus sys/oracle@boway
    这样的话,会连接boway这台服务器,并且listener来确定你所要连接的service_name
    常见故障解决办法:
    TNS-12154 (ORA-12154):TNS:could not resolve service name
    该错误表示用于连接的网络服务名在tnsnames.ora文件中不存在,如上面的tnsnames.ora中的网络服务名只有test,假如用户在连接时用sqlplus system/manager@test1则就会给出TNS-12154错误。
    要注意的是,有时即使在tnsnames.ora文件中有相应的网络服务名,可是用该网络服务名连接时还会出错,出现这种情况的典型配置如下(在客户端的机器上):
    sqlnet.ora文件:
    NAMES.DIRECTORY_PATH = (TNSNAMES, ….)
    NAMES.DEFAULT_DOMAIN = server.com
    tnsnames.ora文件:
    test =
    (DESCRIPTION=
    (ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=testserver)(PORT=1521))
    )
    (CONNECT_DATA=(SERVICE_NAME=orcl.testserver.com)
    )
    )
    sql*plus运行基本机理:
    在用户输入sqlplus system/manager@test后,sqlplus程序会自动到sqlnet.ora文件中找NAMES.DEFAULT_DOMAIN参数,假如该参数存在,则将该参数中的值取出,加到网络服务名的后面,即此例中你的输入由sqlplus system/manager@test自动变为sqlplus system/manager@test.server.com ,然后再到tnsnames.ora文件中找test.server.com网络服务名,这当然找不到了,因为该文件中只有test网络服务名,所以报错。解决的办法就是将sqlnet.ora文件中的NAMES.DEFAULT_DOMAIN参数注释掉即可,如 #NAMES.DEFAULT_DOMAIN = server.com。假如NAMES.DEFAULT_DOMAIN参数不存在,则sqlplus程序会直接到tnsnames.ora文件中找 test网络服务名,然后取出其中的host,port,tcp,service_name,利用这些信息将连接请求发送到正确的数据库服务器上。
    另外原则上tnsnames.ora中的配置不区分大小写,但是我的确遇到区分大小写的情况,所以最好将使用的网络服务与tnsnames.ora中配置的完全一样。
    ORA-12514: TNS:listener could not resolve SERVICE_NAME given in connect Descriptor.
    该错误表示能在tnsnames.ora中找到网络服务名,但是在tnsnames.ora中指定的SERVICE_NAME与服务器端的 SERVICE_NAME不一致。解决的办法是修改tnsnames.ora中的SERVICE_NAME。
    易混淆术语介绍:
    Db_name:对一个数据库(Oracle database)的唯一标识,该数据库为Oracle database。这种表示对于单个数据库是足够的,但是随着由多个数据库构成的分布式数据库的普及,这种命令数据库的方法给数据库的管理造成一定的负担,因为各个数据库的名字可能一样,造成管理上的混乱。为了解决这种情况,引入了Db_domain参数,这样在数据库的标识是由Db_name和 Db_domain两个参数共同决定的,避免了因为数据库重名而造成管理上的混乱。这类似于互连网上的机器名的管理。我们将Db_name和 Db_domain两个参数用’.’连接起来,表示一个数据库,并将该数据库的名称称为Global_name,即它扩展了Db_name。 Db_name参数只能由字母、数字、’_’、’#’、’$’组成,而且最多8个字符。
    Db_domain:定义一个数据库所在的域,该域的命名同互联网的’域’没有任何关系,只是数据库管理员为了更好的管理分布式数据库而根据实际情况决定的。当然为了管理方便,可以将其等于互联网的域。
    Global_name:对一个数据库(Oracle database)的唯一标识,oracle建议用此种方法命令数据库。该值是在创建数据库是决定的,缺省值为Db_name. Db_domain。在以后对参数文件中Db_name与Db_domain参数的任何修改不影响Global_name的值,如果要修改 Global_name,只能用ALTER DATABASE RENAME GLOBAL_NAME TO <db_name.db_domain>命令进行修改,然后修改相应参数。
    Service_name:该参数是oracle8i新引进的。在8i以前,我们用SID来表示标识数据库的一个实例,但是在Oracle的并行环境中,一个数据库对应多个实例,这样就需要多个网络服务名,设置繁琐。为了方便并行环境中的设置,引进了Service_name参数,该参数对应一个数据库,而不是一个实例,而且该参数有许多其它的好处。该参数的缺省值为Db_name. Db_domain,即等于Global_name。一个数据库可以对应多个Service_name,以便实现更灵活的配置。该参数与SID没有直接关系,即不必Service name 必须与SID一样。
    Net service name:网络服务名,又可以称为数据库别名(database alias)。是客户端程序访问数据库时所需要,屏蔽了客户端如何连接到服务器端的细节,实现了数据库的位置透明的特性。
    如何利用配置的网络服务名连接到数据库:
    用sqlplus程序通过test网络服务名进行测试,如sqlplus system/manager@test。如果不能连接到数据库,则在tnsname.ora文件中的test网络服务名(net service)后面加上Oracle数据库的DB_Domain参数值,通过用sqlplus> show parameter db_domain命令察看。此处db_domain参数值为testserver.com,将其加到网络服务名后面,修改后的tnsname.ora中关于该网络服务名的内容为:


    应该改为:
    如何利用配置的网络服务名连接到数据库:
    用sqlplus程序通过test网络服务名进行测试,如sqlplus system/manager@test。如果不能连接到数据库,则在tnsname.ora文件中的test网络服务名(net service)后面加上sqlnet.ora文件中NAMES.DEFAULT_DOMAIN参数的值,此处我的参数值为 testserver.com,将其加到网络服务名后面,修改后的tnsname.ora中关于该网络服务名的内容为:

    什么情况下会引起oracle自动设置NAMES.DEFAULT_DOMAIN参数?
    出现这种情况的典型环境为windows的客户端的‘我得电脑à属性à计算机名à更改à其它…à此计算机的主DNS后缀’中设置了‘primary dns suffix’,因为在这种情况下安装客户端时,会在sqlnet.ora文件中自动设置NAMES.DEFAULT_DOMAIN参数,或许当把计算机加入域中安装oracle客户端时也会出现这种情况,有条件的话大家可以试一下。

    我在设置oracle的客户端时一般手工修改tnsnames.ora文件,但是还有许多人喜欢用图形工具配置,该图形工具最终还是修改tnsnames.ora文件,但是它有时会引起其它的问题:
    在用oracle的图形配置软件''net assistant''或‘Net Configuration Assistant’配置网络服务名时,假如已经设置了‘primary dns suffix’,但是在图形配置软件中写的网络服务名的名字中没有‘primary dns suffix’,如只是写了test,则图形配置软件会自动在后面加上‘primary dns suffix’,使之变为test.testserver.com,并存在tnsnames.ora中,而不管你的sqlnet.ora文件中是否有 NAMES.DEFAULT_DOMAIN参数。此时,用图形工具进行测试连接是通过的,但是假如此时sqlnet.ora文件中没有 NAMES.DEFAULT_DOMAIN参数,则你在使用网络服务名时应该使用在tnsnames.ora中的 test.testserver.com,而不是你在图形配置软件中键入的test。解决的办法为:
    <1>可以在sqlnet.ora文件中设置NAMES.DEFAULT_DOMAIN= testserver.com,这时你可以用test或test.testserver.com连接数据库
    <2>在sqlnet.ora文件中不设置NAMES.DEFAULT_DOMAIN参数,在tnsnames.ora文件中将 test.testserver.com中的.testserver.com去掉,这时你可以用test连接数据库


    转摘自:http://database.e800.com.cn/articles/2008/125/1201205566221270164_1.html
    展开全文
  • 在WINDOWS下,安装完Oracle会自动完成好网络配置实现网络连接,但是在Linux下,得自己手动配置才行。客户端有tnsnames.ora的配置文件来配置网络服务名,如服务器地址,监听端口,数据库SID等。而服务器端有listener...

    目录

    1.11g的网络连接方式

    2.   11g中网络配置的主要文件

    3.静态注册和动态注册

    4.netca和netManager

     

    1.11g的网络连接方式

       在WINDOWS下,安装完Oracle会自动完成好网络配置实现网络连接,但是在Linux下,得自己手动配置才行。客户端有tnsnames.ora的配置文件来配置网络服务名,如服务器地址,监听端口,数据库SID等。而服务器端有listener.ora配置文件来配置监听器,如监听协议、地址及其他信息。从本地访问数据库服务器,首先要开启OracleServiceORCL服务,如果是通过网络访问数据库服务器,还要启动OracleOraDb11g_home1TNSListener服务。

      lsnrctl  [status/start/stop]  

      在WINDOWS和Linux下都可以用上面的命令来查看/开启/停止监听服务,当然如果是在WINDOWS下还可以在控制面板的服务里通过可视化界面直接 查看/开启/停止服务。

    2.   11g中网络配置的主要文件

    主要文件有三个,都位于 $ORACLE_HOME\NETWORK\ADMIN路径下的 sqlnet.ora 、listener.ora、tnsnames.ora.我的这三个文件在D:\oracle\product\11.2.0\dbhome_3\NETWORK\ADMIN。直接可以用可视界面进行修改参数,或者用vim编辑。

    2.1 打开sqlnet.ora 里面有这一句话:SQLNET.AUTHENTICATION_SERVICES= (NTS) 这是基于操作系统的验证方式。这可以让你在以管理员身份登录操作系统时,可以无需输入用户密码就可以以SYSDBA角色直接登录上,如下图所示。如果把NTS改成NONE,那么就是以口令形式进行登录,此时就不可以无密码直接登录了。

    sqlnet.ora 里面有还有一句话:NAMES.DIRECTORY_PATH= (TNSNAMES, EZCONNECT) , 这个是连接方式。默认是先按照tnsnmanes.ora文件里指定的连接方式,如果在文件里查无相应记录则会用简单连接的方式尝试连接。想要用什么连接方式连接往括号里面加参数就行,不想用该连接方式就删除对应参数即可。参数有TNSNAMES,ONAMES,HOSTNAME,EZCONNECT。越前面的参数的越先用对应的方式尝试连接。

    sqlplus user/password@IP:端口/orcl   --在cmd窗口下
    conn   user/password@IP:端口orcl    --在SQLPLUS窗口下
    例如:
    sqlplus voapd/voapd@hu-PC/orcl

    像这种方式就是简单连接,如果出现oracle中监听程序当前无法识别连接描述符中请求服务的错误,可以参考

    https://www.cnblogs.com/telwanggs/p/10935367.html 的解决方案。

    2.2listener.ora文件里有(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))      ,这个是调用外部过程的监听,比如调用C++/JAVA等一些高级语言的方法程序来完成相应的任务,如果把这行删了,就无法调用外部过程了.

    GLOBAL_DBNAME :全局数据库名。通过select * from global_name; 查询得出 。

    PROTOCOL:监听协议,一般都使用TCP 

    LISTENER :监听名称,可以配置多个监听。

    GLOBAL_DBNAME:全局数据库名

    SID_NAME:服务名,通常和全局数据库名一致。

    我的配置如图:

    2.3.在客户端没有tsnames.ora文件时,除了复制别人的,还可以用netca进行可视化配置。没有tsnames,ora文件也就无法按照tnsnmanes.ora文件里指定的连接方式进行连接了。

    打头的左对齐的变量就是服务名(SID),例如上文的ORCL、ORACLR_CONNECTION_DATA。

    其中在ADDRESS 写上要连接服务器的端的信息,连接方式TCP,主机为hu-PC端口为1521,当然HOST也可以是IP地址、域名等.

    可以在 cmd窗口中 输入  tnsping [服务名]  来看能不能ping通服务,而这里的服务名就是tsnames.ora里的SID来查找的。

    3.静态注册和动态注册

      3.1 在listener.ora里如果有类型下面的语句就是静态注册,指明了全局数据库名,服务名,Oracle主目录等。

    SID_LIST_LISTENER =
      (SID_LIST =
        (SID_DESC =
          (SID_NAME = CLRExtProc)
          (ORACLE_HOME = D:\oracle\product\11.2.0\dbhome_3)
          (PROGRAM = extproc)
          (ENVS = "EXTPROC_DLLS=ONLY:D:\oracle\product\11.2.0\dbhome_3\bin\oraclr11.dll")
        )
        (SID_DESC =
          (GLOBAL_DBNAME = ORCL)
          (ORACLE_HOME = D:\oracle\product\11.2.0\dbhome_3)
          (SID_NAME = ORCL)
        )
      )

    3.2 在listener.ora里如果有类型下面的语句就是动态注册

    LISTENER =
      (DESCRIPTION_LIST =
        (DESCRIPTION =
          (ADDRESS = (PROTOCOL = TCP)(HOST = hu-PC)(PORT = 1521))
    	  (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521)) 
        )
      )
    

    在cmd中输入lsnrctl status  如果状态为UNKNOWN就是静态注册,如果是READY就是动态注册.动态注册可以不需要listener.ora文件。在启动监听服务时需要读取listener.ora文件内容,如果没有listener.ora文件时,默认情况PMON会向LSNTCTL动态注册协议为TCP/IP,端口为1521注册到监听器。

     lsnrctl status 来查看我监听状态

     想要静态注册和动态注册之间转化,就需要把listener.ora的静态注册的部分给删掉,或者把listener.ora给删除。重启服务如图所示。在读listener.ora文件内容里要是没有相应的静态注册信息,待PMON进程重启后会对监听器进行动态注册。

    由于PMON后台进程是随着数据库打开才会打开的,动态注册大概需要1分钟才能完成。

     

    4.netca和netManager

        以管理员的身份启动cmd,输入netca会有一个界面,如图,这是一个对参数文件进行修改的可视化界面,要比上面操作文件来改参数要方便得多。监听程序配置实际上就是配置listener.ora配置文件的可视化界面。命名方法配置是配sql,ora的,本地网络服务配置tsnames.ora的。

    在WIN菜单下搜索net Manageer打开,这里面可以进行静态注册,选择添加数据库,写入相应的信息,Oracle主目录就是ORACLE_HOME.

    添加完数据库后,重启lsnrctl服务等待1分钟。

    可以重新查看listener.ora文件,发现静态注册信息又添加上去了。

    注意:不建议直接手动操作配置文件,尽量采用可视化管理工具来操作。如果出现TNS监听异常,或者服务无法打开,尝试把listener.ora备份后删除,在重新用可视化工具进行配置。

    展开全文
  • Oracle11g的网络配置

    2019-05-17 23:19:05
    oracle11g网络连接的方式。 oracle11g中进行网络配置的主要文件。 oracle11g的静态注册、动态注册的含义和相互转换的方式,以及何时必须使用静态注册。 netca和net manager的使用。 ...

    1)oracle11g网络连接的方式。
    2)oracle11g中进行网络配置的主要文件。
    3)oracle11g的静态注册、动态注册的含义和相互转换的方式,以及何时必须使用静态注册。
    4)netca和net manager的使用。


    Oracle安装后,服务器和客户端都需要进行网络配置才能实现网络连接。
    服务器端配置监听器,客户端配置网络服务名
    在这里插入图片描述


    如果通过网络访问数据库服务器,至少要启动OracleOraDb11g_home1TNSListener 和 OracleServiceORCL 服务。


    如果本地访问数据库服务器,至少要启动
    OracleServiceORCL 服务。


    服务器端监听器配置信息包括监听协议、地址及其他相关信息。配置信息保存在名为 listener.ora 的文件中。在安装服务器软件时自动配置一个监听器。

    客户端的网络服务名配置信息包括服务器地址、监听端口号和数据库SID等,与服务器的监听器建立连接。配置信息保存在名为 tnsnames.ora 的文件中。

    Oracle中的 Net Configuration Assistant 和 Net Manager 工具都能用来配置监听器和网络服务名。


    服务器端监听控制: lsnrctl start|stop|status
    图形界面配置监听: netca
    编辑文件方式配置监听: $ORACLE_HOME\NETWORK\ADMIN\listener.ora 文件。


    oracle11g中进行网络配置的主要文件有三个,位于$ORACLE_HOME\NETWORK\ADMIN下的
    sqlnet.ora, listener.ora, tnsnames.ora 文件。


    sqlnet.ora的作用:
    当用户登录到操作系统后,如果进而允许此用户登录数据库系统,则需要在sqlnet.ora中设置SQLNET.AUTHENTICATION_SERVICES=(NTS)
    如果设置为 SQLNET.AUTHENTICATION_SERVICES=(NONE),则不允许登录到数据库系统中。


    客户端连接的两种方式:
    1,简单连接:conn scott/scott@a84p1l1x02meo8p:1521/orcl 的连接方式,不需要客户端进行任何配置。
    2,本地命名:conn scott/scott@orcl 的连接方式,需要客户端配置一个本地命名解析文件,为$ORACLE_HOME\NETWORK\ADMIN\tnsnames.ora文件,可以使用netca配置。
    在sqlnet.ora文件中进行规定。


    服务名:服务名就是连接字符串,可以通过它访问远程数据库,可以通过NETCA配置,配置时要指明远程数据库的主机名,网络协议用TCP/IP,配置完成后可以用如下方式登陆:(以服务名为test) username/password@test ,
    也就是:是对数据库的一个标识,通过服务名可访问数据库 。
    测试服务能否连接上:tnsping <服务名>


    静态注册:
    注册就是将数据库作为一个服务注册到监听程序,在数据库服务器启动过程中,数据库服务器会向监听程序注册相应的服务 。
    在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)
        )
      )
    

    动态注册:
    在listener.ora中,如果有类似

    LISTENER =
      (DESCRIPTION_LIST =
        (DESCRIPTION =
          (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))
          (ADDRESS = (PROTOCOL = TCP)(HOST = a84p1l1x02meo8p)(PORT = 1521))
        ) 
      )
    

    动态注册的一个特点就是不需要LISTENER.ORA文件。默认情况PMONLSNRCTL注册TCP/IP协议,PORT为1521。


    使用lsnrctl status查看某个服务是静态注册、还是动态注册:
    如果是UNKNOWN,表示静态注册;
    如果是 READY ,表示动态注册。


    READY服务 是由PMON进程动态的注册到监听器,因此PMON进程所在的数据库一定处于打开状态,所以说这些服务名所对应的实例已经准备好(READY)接受用户的连接请求。

    UNKNOWN 服务 是通过编辑listener.ora而静态注册的服务名,监听器并不知道该服务名对应的实例是否打开了,所以用UNKNOWN表示。


    动态注册、静态注册可以根据需要进行转换。


    使用Net Configuration Assistant配置网络连接,实际上还是修改的listener.ora和tnsnames.ora文件。
    NETCA中进行命名方法配置,实际是修改sqlnet.ora文件中的内容。


    我的sqlnet.ora文件

    # sqlnet.ora Network Configuration File: C:\app\Administrator\product\11.2.0\dbhome_1\network\admin\sqlnet.ora
    # Generated by Oracle configuration tools.
    
    # This file is actually generated by netca. But if customers choose to 
    # install "Software Only", this file wont exist and without the native 
    # authentication, they will not be able to connect to the database on NT.
    
    SQLNET.AUTHENTICATION_SERVICES= (NTS)
    
    NAMES.DIRECTORY_PATH= (TNSNAMES, EZCONNECT)
    

    我的listener.ora文件

    # listener.ora Network Configuration File: C:\app\Administrator\product\11.2.0\dbhome_1\network\admin\listener.ora
    # Generated by Oracle configuration tools.
    
    SID_LIST_LISTENER =
      (SID_LIST =
        (SID_DESC =
          (SID_NAME = CLRExtProc)
          (ORACLE_HOME = C:\app\Administrator\product\11.2.0\dbhome_1)
          (PROGRAM = extproc)
          (ENVS = "EXTPROC_DLLS=ONLY:C:\app\Administrator\product\11.2.0\dbhome_1\bin\oraclr11.dll")
        )
    	(SID_DESC =
    		  (GLOBAL_DBNAME = ORCL)
    		  (ORACLE_HOME = C:\app\Administrator\product\11.2.0\dbhome_1)
    		  (SID_NAME = ORCL)
    	)
      )
    
    LISTENER =
      (DESCRIPTION_LIST =
        (DESCRIPTION =
          (ADDRESS = (PROTOCOL = TCP)(HOST = MDSDB)(PORT = 11521))
          (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))
        )
      )
    
    ADR_BASE_LISTENER = C:\app\Administrator
    

    我的tnsnames.ora文件

    # tnsnames.ora Network Configuration File: C:\app\Administrator\product\11.2.0\dbhome_1\network\admin\tnsnames.ora
    # Generated by Oracle configuration tools.
    
    ORACLR_CONNECTION_DATA =
      (DESCRIPTION =
        (ADDRESS_LIST =
          (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))
        )
        (CONNECT_DATA =
          (SID = CLRExtProc)
          (PRESENTATION = RO)
        )
      )
    
    ORCL =
      (DESCRIPTION =
        (ADDRESS = (PROTOCOL = TCP)(HOST = MDSDB)(PORT = 11521))
        (CONNECT_DATA =
          (SERVER = DEDICATED)
          (SERVICE_NAME = orcl)
        )
      )
    

    Oracle Database Extensions for .NET Architecture
    在这里插入图片描述

    展开全文
  • # tnsnames.ora Network Configuration File: J:\app\paul\product\11.2.0\orahome\network\admin\tnsnames.ora # Generated by Oracle configuration tools. LISTENER_ORCL =  (ADDRESS = (PROTOCOL = TCP)
  • Oracle 网络配置

    2020-03-19 18:40:51
    Oracle 网络配置 ----案例:教师机 IP 为 192.168.56.101,数据库 orcl,监听程序端口号 1522。将教师机 数据库表 emp 中 SCOTT 用户的工资 3000 改为 30000。创建一个指向教师机数据库 的网络连接服务名 teacherdb...
  • Oracle 11g的网络配置

    千次阅读 2017-05-11 11:16:08
    一、Oracle11g的网络配置 1. Oracle产品安装完成后,服务器和客户端都需要进行网络配置才能实现网络连接。 2. 服务器端配置监听器,客户端配置网络服务名。 tnsnames.ora 位于oracle的客户端,listener.ora 位于...
  • oracle简单网络配置

    2012-12-18 14:34:32
    下面给出一个最简单的Oracle网络配置,并且是行之有效的 [code="sql"] #sqlnet.ora SQLNET.AUTHENTICATION_SERVICES = (NTS)[/code] [code="sql"]#tnsnames.ora EXTPROC_CONNECTION_DATA...
  • 网络服务配置

    2020-03-13 23:31:17
    登录连接远程服务器需要对网络进行配置 利用网络服务配置向导配置 利用网络管理器进行配置 1:本地网络服务配置 2:添加 3.默认情况下是全局数据库的名字 4.默认情况下是TCP协议就可以了 5.主机名或ip名,端口...
  • Oracle的链接配置 如何配置监听 本地网络服务配置Oracle的链接配置讲解Oracle配置监听配置监听程序Oracle的本地网络服务配置须知配置进行访问 Oracle的链接配置讲解 我们进入Oracle的安装目录下 开始讲解: sql...
  • 文章目录Oracle的连接配置文件位置sqlnet.ora文件tnsnames.ora文件ORCLPROTOCOLHOSTPORTlistener.ora文件LISTENERPROTOCOLHOSTPORTOracle的监听配置配置监听程序配置本地网络服务 Oracle的连接配置 文件位置 Oracle...
  • 配置网络: 服务端需要配置监听程序 操作监听程序使用监听控制台 1.无配置启动监听程序 lsnrctl start Alias --> LISTENER (默认名称) HOST=oracle7.example.com PORT=1521(默认端口) lsnrctl status Service ...
  • 网络配置

    千次阅读 2013-03-02 15:56:46
    二、专用连接的网络配置 参考官方文档:Books => NET => Net Services Reference => 7 Listener Parameters (listener.ora)  1、监听器的启用与配置(listener.ora)  (1)动态监听与静态监听  ①默认...
  • 六、网络配置

    2021-06-11 13:34:20
    六、网络配置Oracle11g至少启动的...掌握oracle11g中进行网络配置的主要文件 掌握oracle11g的静态注册、动态注册的含义和相互转换的方式,以及何时必须使用静态注册。 掌握netca和net manager的使用 Oracle产品安装完.
  • oracle网络配置三个配置文件

    千次阅读 2011-07-05 11:23:28
    oracle网络配置三个配置文件 listener.ora、sqlnet.ora、tnsnames.ora ,都是放在$ORACLE_HOME\network\admin目录下。 1. sqlnet.ora-----作用类似于linux或者其他unix的nss
  • 其中便以网络配置为其中的典型。故我在这里记录一下oracle的网络配置,其中有一部分是网络上零零散散的内容,加上我自己的理解,便整理在一起了。用于自己查阅和其它同学参考。 以下内容我将按照以下顺序讲述 文章...
  • 网络配置的方法:1、tnsname客户端--A 直接修改文件 B 通过客户端工具“网络配置助手”--win端直接打开调用Linux端,netca命令调出配置工具2、监听器配置--服务器端客户端配置监听服务室没有任何意义的,因为客户端...
  • oracle网络配置有三个文件,它们都在D:\app\Administrator\product\11.2.0\dbhome_1\NETWORK\ADMIN 这个文件夹下面,有sqlnet.ora、listener.ora、tnsnames.ora。 sqlnet.ora里只有两行配置: 1、SQL...
  • Oracle的网络配置

    2020-09-15 15:54:22
    三个配置文件 listener.ora、sqlnet.ora、tnsnames.ora ,都是放在$ORACLE_HOME/network/admin目录下。...sqlplus sys/oracle@orcl 假如我的sqlnet.ora是下面这个样子 SQLNET.AUTHENTICATION_SERVICES= (NTS) N
  • oracle网络配置

    2014-11-03 16:53:52
    三个配置文件 listener.ora、sqlnet.ora、tnsnames.ora ,都是放在$ORACLE_HOME\network\admin目录下。  1. sqlnet.ora—–作用类似于linux或者其他...  例如我们客户端输入  sqlplus sys/oracle@orcl ...
  • 大家在学习oracle的时候,网络配置和os认证一般很困扰,下面来介绍下关于oracle的网络配置。 我的服务器是在虚拟机里,客户端是在我的电脑上。我的oracle服务器基本信息:数据库名:orcl3939 ip:178.3.601.172 ...
  • Oracle 网络配置与管理 详细信息可以参考以下信息: 【学习目标】 一、原理解析 二、配置侦听器(LISTENER) 三、配置客户端网络服务名 四、关于注册 五、查询某服务是静态还是动态注册 Oracle 网络配置方法 0...
  • 大家在学习oracle的时候,网络配置和os认证一般很困扰,下面来介绍下关于oracle的网络配置。我的服务器是在虚拟机里,客户端是在我的电脑上。我的oracle服务器基本信息:数据库名:orcl3939 ip:178.3.601.172 虚拟机...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 10,212
精华内容 4,084
关键字:

网络配置配置orcl