Oracle(2-2)Oracle Net Architecture

文章目录

  • 一、基础知识
    • 1、Oracle Net Connections Oracle网络连接
    • 2、C/S Application Connection C/S应用程序连接
    • 3、OSI Communication Layers OSI通信层
    • 4、Oracle Protocol Support Oracle协议支持
    • 5、B/S Application Connections B/S应用程序连接
    • 6、TwoTypes JDBC Drivers 两种JDBC连接方式
    • 7、Web Connection Using HTTP web浏览器使用HTTP连接Oracle
    • 8、Concepts & Terminology 概念和术语介绍
    • 9、连接三步走的过程
    • 10、Net Configuration Models 网络配置模型
    • 11、Overview of Naming Methods 命名方法概述
    • 12、Configuration Files Oracle配置文件
    • 13、Three Key Parameters 连接的三个关键参数
  • 二、基础操作
    • 1、监听程序的启动
    • 2、查看Oracle服务名字的方法

在这里插入图片描述

Oracle Net Architecture Oracle Net体系结构
目标:

  • 解释Oracle网栈通信架构的关键组件
  • 解释Oracle网在客户端-服务器连接中的作用
  • 描述如何通过Oracle网络产品建立Web客户端连接

一、基础知识

1、Oracle Net Connections Oracle网络连接

  • Oracle网用于建立网络上的应用程序之间的连接,这取决于以下几点:
    • 网络配置
    • 节点的位置(Oracle数据服务器的位置)
    • 应用程序
    • 网络协议
  • 连接类型可以是:
    • 客户端一服务器应用程序
    • Java应用程序
    • Web客户端应用程序

2、C/S Application Connection C/S应用程序连接

在这里插入图片描述

3、OSI Communication Layers OSI通信层

在这里插入图片描述

  • 其中TCP层在运输层,IP在网络层

4、Oracle Protocol Support Oracle协议支持

  • TCP/IP (主流的协议)
  • TCP/IP with SSL (具有SSL加密,更加安全)
  • Named Pipes (微软开发专门支持在局域网的一种协议)
  • SDP(性能高于TCP/IP,用于高端的网络要求)
    • SDP 套接字目录协议 (SDP) 是Infiniband网络对等点之间的行业标准有线协议。当SDP在Infiniband网络上使用时,它通过消除数据的中间复制和将大部分消息传递负担从CPU转移到网络硬件上来减少TCP/IP的开销。

5、B/S Application Connections B/S应用程序连接

Web浏览器(这里指的javaweb,如果使用的是C/C++可以使用OCI连接)可以通过以下方式连接到Oracle服务器:

  • 将应用程序Web服务器用作中间层,该中间层配置有以下任一项:
    • JDBC Oracle Call Interface (OCl) driver
    • Thin JDBC driver
  • 使用HTTP直接连接到Oracle服务器(这种方法使用的比较少)

6、TwoTypes JDBC Drivers 两种JDBC连接方式

Oracle Java数据库连接 (JDBC) 驱动程序提供Java应用程序访问甲骨文数据库。甲骨文提供了两个JDBC驱动程序:

  • JDBC OCI Driver驱动程序是一个2级JDBC驱动程序,用于客户端/服务器Java应用程序。JDBC OCI驱动程序将JDBC调用转换为对OCI的调用,然后通过Oracle网络发送到Oracle数据库服务
    器。
  • JDBC Thin Driver驱动程序是Java applet使用的4级驱动程序。JDBC Thin驱动程序通过Java套接字建立到Oracle数据库服务器的直接连接。TTC和Oracle Net的轻量级实现有助于对数据库的访问。

以下是两种连接方式的工作流程图:
在这里插入图片描述

7、Web Connection Using HTTP web浏览器使用HTTP连接Oracle

在这里插入图片描述

以下是HTTP连接的工作流程图:
在这里插入图片描述

8、Concepts & Terminology 概念和术语介绍

  • Database services 数据库服务
  • Service Name 服务名字
    • 数据库的逻辑表示
    • 将数据库呈现给客户端的方式
  • Connect Descriptor 连接描述
    • 数据库的位置
    • 数据库服务的名称
  • Listener Oracle监听
    • 接收客户端连接请求
    • 将请求传递给数据库服务器
  • Service Registration 服务注册
    • 数据库向侦听器注册信息
    • 每个实例可用的服务处理程序
  • Service Handlers 服务器管理员
    • 连接点 (客户端和服务器的连接点)
    • 调度器或专用服务器

Service Registration 服务注册流程
在这里插入图片描述
一旦客户机请求到达侦听器,侦听器将选择适当的service handler来服务客户机的请求,并将客户机的请求转发给它。侦听器确定是否可以通过service registration使用数据库服务及其服务处理程序。在服务注册期间,PMON进程 (一个实例后台进程) 为侦听器提供以下信息:

  • 数据库提供的数据库服务的名称
  • 与服务关联的实例的名称及其当前和最大负载
  • 实例可用的服务处理程序(调度程序和专用服务器),包括它们的类型、协议地址以及当前和最大负载

此信息使侦听器能够正确地引导客户端的请求

9、连接三步走的过程

在这里插入图片描述

  • 需要先启动Listener
  • 然后启动数据库实例
  • 数据库实例向Listener注册服务
  • 然后客户端与Listener建立连接服务
  • 最后直接将客户端和服务端连接在一起,能够直接进行双向通信

10、Net Configuration Models 网络配置模型

  • 本地化管理
    • 网络中每台计算机上有一个本地配置文件
  • 集中化管理
    • 符合LDAP的目录服务器(适合大规模的配置)
    • Oracle命名服务器

11、Overview of Naming Methods 命名方法概述

  • 当尝试连接到数据库服务时,客户端应用程序使用命名方法将连接标识符解析为连接描述符。我们要连接数据库需要知道数据库服务的ip地址和端口号
  • Oracle网络提供了五种命名解析方法:
    • Host naming (基于操作系统的解析方法)
    • Local naming (使用tnsnames.ora配置文件)(最常用)适合小规模
    • 使用目录服务 (最常用)适合大规模
    • Oracle服务名称
    • 第三方提供的信息服务

12、Configuration Files Oracle配置文件

在这里插入图片描述

  • 其中最重要的的就是tnsnames.oralistener.ora

配置文件的位置位于:$ORACLE_HOME/network/admin目录下
我们可以切换到这里进行查看:

cd $ORACLE_HOME/network/admin

在这里插入图片描述
我们现在查看一下tnsnames.ora

cat tnsnames.ora

在这里插入图片描述

  • 我们能够看出它的协议是TCP,HOST是本机(如果是远程连接的话会显示ip地址),端口号是1521,服务名是orcl
  • 注意做上方第一个红框的ORCL,在我们连接数据库的时候就可以使用这个
    • 语法举例:sqlplus system/123@orcl 连接我们使用sqlplus,用户名是system(这个可以是其他的),密码是123(要连接的用户的用户名),@符号后边跟着图中坐上第一个红方框中的内容就可以完成连接
    • 在这里插入图片描述
    • 连接后会有两个版本号,第一个是连接机器上的版本号,第二个是你连接到的Oracle的版本号

13、Three Key Parameters 连接的三个关键参数

  • 连接描述符:

    • 数据库的位置
    • 数据库服务的名称
  • 三个关键参数:

    • IP地址
    • 端口号
    • 服务名称

二、基础操作

1、监听程序的启动

在客户端进行远程连接的时候需要启动监听程序:
使用ps -ef | grep oracle来查看监听程序是否启动
在这里插入图片描述
如果没发现红框内部这一条的话说明监听是没有启动的,我们需要启动
启动监听的命令:lsnrctl start
只有启动监听我们外部才能进行连接,当然有许多人是在自己本地执行命令进行连接的,再本地进行连接监听不启动也能够用连接到数据库实例。

  • 对于本地连接,您不需要启动监听。您可以直接连接到本地数据库实例,而无需通过监听器。这对于开发和测试来说非常方便。

但是对于非本地连接,当您要连接到一个数据库实例时,如果监听没有运行,那么PMON(实例后台进程)将无法注册服务。因此,如果不启动监听,无论是通过SQLPLUS还是其他方式,都不可能连接到数据库。

2、查看Oracle服务名字的方法

登录数据库执行语句:show parameter service

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/143325.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Vue 2学习(路由、history 和 hash 模式、)-day014

一、路由简介 路由(route)就是一组 key-value 的对应关系多个路由,需要经过路由器(router)的管理 在 Vue 中也有路由,Vue 中的路由主要是通过 vue-rounter 这个插件库来实现,它的作用就是专门用…

力扣双周赛 -- 117(容斥原理专场)

class Solution { public:long long c2(long long n){return n > 1? n * (n - 1) / 2 : 0;}long long distributeCandies(int n, int limit) {return c2(n 2) - 3 * c2(n - limit 1) 3 * c2(n - 2 * limit) - c2(n - 3 * limit - 1);} };

Python+selenium自动化测试

批量执行完用例后,生成的测试报告是文本形式的,不够直观,为了更好的展示测试报告,最好是生成HTML格式的。 unittest里面是不能生成html格式报告的,需要导入一个第三方的模块:HTMLTestRunner 一、导入HTML…

Peoeasy机器人:原点无法重置问题

机械手在伺服关闭的模式下,插入定位插销,进入机构设定重置原点,发现PUU值没有变化 问题原因 台达软件版本比较多,每个版本重置原点的模式和马达偏差角的默认值是有一定差异的。再重置原点之前尽可能先确认一下重置原点的模式和马…

博流BL602芯片 - 烧录配置

硬件介绍 淘宝上买的核心板,大概结构如上。 直接插入电脑usb,即可实现供电、下载(控制BOOT/EN)、串口通讯 固件包 1、环境配置 1.1串口 开发板使用了 CH340G 的 USB 转串口芯片,自行安装CH340串口驱动。 1.2编译环境…

【Android】统一系统动画

需求:除panel动画效果为弹出之外,其余的应用效果为渐入渐出 从系统层面统一把控动画效果,而不是单个应用自己处理 Android系统版本:9.0 代码地址 \frameworks\base\core\res\res\values\styles.xml 当时看注释,以为…

iOS:何为空指针和野指针

一:什么是空指针和野指针 1、空指针 ①.没有存储任何内存地址的指针就成为空指针(NULL指针) ②.空指针就是被赋值为0的指针,在没有被具体初始化之前,其值为0. //以下都是空指针,eg: Person *p1 NULL; …

RGB转Bayer,一个小数点引发的血案

前几天写了一个RGB数据转Bayer格式的函数,经过测试功能正常。后来把这个函数用到一个数据库构建中,结果数据库出来的结果一直是一张黑图,追查了好几个小时,总算把这只虫子找出来了,原来是一个整数后面的小数点作祟。 …

⑦【MySQL】什么是约束?如何使用约束条件?主键、自增、外键、非空....

个人简介:Java领域新星创作者;阿里云技术博主、星级博主、专家博主;正在Java学习的路上摸爬滚打,记录学习的过程~ 个人主页:.29.的博客 学习社区:进去逛一逛~ 约束 ⑦【MySQL】约束条件1. 约束的基本使用2.…

Flutter笔记:使用Flutter构建响应式PC客户端/Web页面-案例

Flutter笔记 使用Flutter构建响应式PC客户端/Web页面-案例 作者:李俊才 (jcLee95):https://blog.csdn.net/qq_28550263 邮箱 :291148484163.com 本文地址:https://blog.csdn.net/qq_28550263/article/detai…

软件工程-第7章 面向对象方法基础

第7章 面向对象方法基础 面向对象的基本概念 面向对象方法的世界观:一切系统都是由对象构成的,他们的相互作用、相互影响,构成了大千世界的各式各样系统。面向对象方法是一种以对象、对象关系等来构造软件系统模型的系统化方法。 面向对象 …

从0到0.01入门React | 009.精选 React 面试题

🤍 前端开发工程师(主业)、技术博主(副业)、已过CET6 🍨 阿珊和她的猫_CSDN个人主页 🕠 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》 🍚 蓝桥云课签约作者、已在蓝桥云课上架的前后端实战课程《Vue.js 和 Egg.js 开发企业级健康管理项目》、《带你从入…

Mac M3 芯片安装 Nginx

Mac M3 芯片安装 Nginx 一、使用 brew 安装 未安装 brew 的可以参考 【Mac 安装 Homebrew】 或者 【Mac M2/M3 芯片环境配置以及常用软件安装-前端】 二、查看 nginx 信息 通过命令行查看 brew info nginx可以看到 nginx 还未在本地安装,显示 Not installed …

k8s之Helm

理论: 什么是 He lm 在没使用 helm 之前,向 kubernetes 部署应用,我们要依次部署 deployment、svc 等,步骤较繁琐。 况且随着很多项目微服务化,复杂的应用在容器中部署以及管理显得较为复杂,helm 通过打包…

k8s的error: metrics not available yet问题处理

kubectl top node报错处理 解决步骤环境说明问题现象初次排查问题解决版本兼容性metric-server.yaml 问题验证 解决步骤 因项目要求,需在k8s集群中使用 kubectl top node命令,但是一直报error: metrics not available yet错误。为了更好的复现问题&…

数据结构-时间复杂度与空间复杂度详解

文章目录 算法效率时间复杂度概念计算例1例2例3补充例4 空间复杂度例1例2 算法效率 算法效率分析分为两种:第一种是时间效率,第二种是空间效率。时间效率被称为时间复杂度,而空间效率被称作空间复杂度。时间复杂度主要衡量的是一个算法的运行速度&#…

新一轮SocialFi浪潮来袭,Atem Network 再次打响注意力争夺战

火爆如潮的 Atem Network 再次从 CyberConnect 以及 Friend.tech 手中接过 SocialFi 赛道的热度大棒,同时这也表明,协议层仍将是 Web3 社交领域的主要叙事。 前不久,Web3社交协议Atem Network 在白皮书中披露了ATEM的代币经济模型&#xff0c…

牛客网刷题笔记231112 最小k位数+二叉树层序遍历+SQL异常邮件概率

算法题牛客网NC119 最小的k个数 题目: 用了一下python列表的便利,不知道在面试时允许用不。当然最简单的方法其实是直接sort()一下取前k位数即可。本次写的思路如下: 用一个最大容量为k的列表存储结果,遍历n个元素,当…

技术架构 - 应用数据分离,应用服务集群架构

前言 上一篇文章介绍了单机架构,由于性能瓶颈,满足不了高访问量,所以演化出了数据分离架构。 这种架构也很简单只是将应用服务和数据库服务分离开来,避免单一架构的资源争夺的情况。 一、 应用数据分离架构 1. 简介 应用服务和…