oracle 服务器

article/2025/10/13 22:44:42

简单概念:
1. 数据库(database):物理操作系统文件或磁盘的集合(可能不是操作系统中独立文件),数据库是磁盘上存储的数据集合。数据库可以由一个或多个实例装载和打开。
2. 实例(instance):一组oracle后台进程/线程以及一个共享内存区,这些内存由同一个计算机上运行的线程/进程共享。实例“一生”只能装载并打开一个数据库。
3. Oracle有一个很大的内存块,称为系统全局区(SGA),它的工作有:
(1)维护所有进程需要访问的多种数据结构
(2)缓存磁盘上的数据,另外重做数据写至磁盘之前先在这里缓存
(3)保存已解析的SQL计划

Oracle服务器处理请求的两种最常见的工作方式:

  • 专用服务器(dedicated server)
  • 共享服务器(shared server)

专用服务器

  • 登录时,oracle会创建一个新的进程,通常称为专用服务器配置,这个服务器进程会在会话生存期中提供专门服务。
  • 专用服务器不是实例的一部分
  • 应用程序会通过某种网络通信与专用服务器直接通信,并由这个服务器进程接受和执行应用程序的SQL。

专用服务器的特点
客户连接与服务器进程之间存在一对一映射
使用场景

  • 非OLTP环境中,也就是可能有长时间运行事务的情况
  • 专用服务器是oracle的推荐配置,能很好地扩缩。配置合理的话,可用于数千条并发连接。
  • 某些操作必须在专用服务器模式下执行,如数据库启动和关闭。每个数据库可能同时有专用服务器和共享服务器。

通信方式:
这里写图片描述
共享服务器
正式的说法是多线程服务器(Multi-Threaded Server)或简称为MTS。

  1. 专用服务器为每个会话建立专门进程
  2. MTS使用“共享进程”池为大量用户提供服务
  3. MTS实际上就是一种连接池机制,从而能够让更多的用户与数据库连接
  4. 采用共享服务器模式,共享进程通常与数据库一同启动,使用ps命令/pslist工具可以看到该进程。
    通信方式:
    这里写图片描述
    共享服务器与专用服务器的重大区别:

    • 专用服务器与客户能够直接通信
    • 共享服务器不会与客户进程直接通信
      -调度器(dispatcher, 也称为分派器)
      -客户进程与调度器进程通信
      -调度器进程通过SGA来完成与共享服务器的通信

共享服务器的特点

  • 客户连接与服务器进程之间存在多对一映射
  • 共享服务器是一种共享资源,使用时必须当心,不要太长时间独占这种资源。如果独占了共享服务资源,会导致系统好像挂起了一样
  • 共享服务器的首要原则:要确保事务的持续时间尽量短。事务可以频繁地执行,但必须在短时间内执行完(这正是OLTP系统的特点)。

    可能存在问题:

  • 人工死锁(artificial deadlock):锁的拥有者永久也拿不到共享服务器来完成提交,除非某个等待的会话放弃其共享服务器;

  • 但是,除非等待的会话所等待的是一个有超时时间的锁,否则它们绝对不会放弃其共享服务器。
  • 例如:5个共享服务器,100个用户会话。同一个时间点上最多可以有5个会话并行运行。

共享服务器优点:

  • 减少操作系统进程/线程数
  • 刻意地限制并发度
  • 减少系统所需的内存

限制并发的原因:

  • 在对系统进行基准测试时,人们经常要求支持尽可能多的用户,直至系统崩溃。
  • 并发数和事务数之间的关系:
    • 最初增加并发用户,事务数会增加;
    • 到某一点时,再增加并发用户,事务数不但没有增加,反而开始下降。吞吐量有一个峰值,是系统上允许的最大并发度。从这一点开始,系统开始出现拥塞。
  • 伴随拥塞,系统将开始:
    • 为了完成工作,用户将开始排队
    • 响应时间可能大幅增加,系统的吞吐量也可能开始下跌
    • 上下文切换要占用资源,众多用户之间共享资源需要开销。

这样一来虽然并发数量多,但是并不能起到原有的加快处理速度去的效果,响应时间大幅度上升,反而使性能下降,这就是要限制并发的原因。

使用共享服务器减少内存的原因:

  • 共享服务器用户和进程之间是多对一得关系,这样一来比专用服务器减少很多进程开销。
  • 共享服务器减少的主要是PGA(进程全局区)(不包括UGA(用户全局区))所占用的内存。例如,从5000个专用服务器转变到100个共享服务器,则会节省4900个PGA的内存;
  • 共享服务器会增加SGA的内存,因为将5000个UGA放到了SGA中;
  • 从总量上来讲,减少了4900个PGA的内存

http://chatgpt.dhexx.cn/article/ysa3XOMT.shtml

相关文章

Oracle云服务器安全配置

在Oracle云上申请了一个免费云空间,据说是永久免费,这里记录一下安全配置问题。 一、访问Oracle云服务器 1、云服务器申请 如何在oracle注册申请云服务可自行搜索一下,有很多文章介绍。 甲骨文Oracle云服务器详细申请教程步骤及注意事项 …

抽象类和接口的区别,以及使用场景?

抽象类 接口 抽象类和接口区别 Java 8中关于接口的改进 接口中的默认方法: 抽象类和接口使用场景 ① 抽象类是对一种事物的抽象,即对类抽象,而接口是对行为的抽象。抽象类是对整个类整体进行抽象,包括属性、行为,但…

抽象类和接口的详解(实例)

抽象类和接口在我们的代码中,生活中息息相关,与上图所示,操纵复杂,密切相关,那么问题来了,何谓抽象类,何谓接口? 带着这层薄纱,慢慢揭开这层薄纱;也许在古代…

接口和抽象类的区别

转自:https://www.cnblogs.com/yongjiapei/p/5494894.html 接口和抽象类有什么区别 你选择使用接口和抽象类的依据是什么? 接口和抽象类的概念不一样。接口是对动作的抽象,抽象类是对根源的抽象。 抽象类表示的是,这个对象是什…

接口与抽象类的区别

c# 一、抽象类: 抽象类是特殊的类,只是不能被实例化;除此以外,具有类的其他特性;重要的是抽象类可以包括抽象方法,这是普通类所不能的。抽象方法只能声明于抽象类中,且不包含任何实现&…

Java抽象类与接口(学习笔记)

抽象类 什么是抽象类: 类和类之间具有共同特征,讲这些共同特征抽取出来,就形成了抽象类。因为类本身是不存在的,所以抽象类无法创建对象(无法实例化)。 以下借用视频中总结的思维层次图: 抽象类…

接口与抽象类的区别 详细总结

------------------------- 在这里我总结了五点区别 ----------------------- 区别一: 抽象类中可以存在非抽象的方法 VS 接口中的方法被默认的变成抽象方法,只要是定义了接口,接口中的方法 就全部变成了抽象类即使你不写 abstract 它也是抽…

Java-抽象类与接口

前言 温故而知新 最近从头来看当初学过的语法知识点, 温故而知新, 发现当初还有许多未掌握的知识, 所以我建议大家也要多温故, 可能当初有好多知识点是没掌握到的. 这篇博客的重点就是介绍抽象类与接口, 并阐述他们的区别. 一. 抽象类 1. 概念 在面向对象的概念中, 所有的…

一文带你了解【抽象类和接口】

1. 抽象类概念 在面向对象的概念中,所有的对象都是通过类来描绘的,但是并不是所有类都是用来描绘对象的。如果一个类中没有包含足够的信息来描绘一个具体的对象,这样的类就是抽象类。 举个简单的例子 上图中,三角形&#xff0…

抽象类和接口

目录 抽象类 抽象类使用abstract修饰类 抽象类当中可以包含普通类所能包含的成员 抽象类和普通类不一样的是,抽象类当中可以包含抽象方法。 抽象类方法是使用abstract修饰的,这个方法没有具体的实现 不能实例化抽象类 抽象类存在的意义是为了被继承…

Java抽象类和接口 -- 深度剖析

💖欢迎来阅读子豪的博客(Java语法篇🧔) 👉有什么宝贵的意见或建议可以在留言区留言 💻欢迎 素质三连 点赞 关注 收藏 🧑‍🚀码云仓库:补集王子的代码仓库 Java抽象类和接…

Java学习系列之抽象类和接口的区别和联系

导读 本文首先分别介绍抽象类和接口的基础概念、特征和应用场景,然后介绍其区别和联系。 1 抽象类 1.1 定义抽象类 在Java中被abstract关键字修饰的类称为抽象类,被abstract关键字修饰的方法称为抽象方法,抽象方法只有方法的声明&#xff…

从抽象类到接口—手把手教你写抽象类(一)—还在Ctrl C的伙伴们看过来了

目录 一、抽象类概述 二、抽象类的特点 三、抽象类的案例 四、抽象类的细节 五、抽象类的思想 抽象类概述 抽象定义 –抽象是从多个事物中将共性的,本质的内容抽取出来。 –例:狼和狗共性都是犬科,犬科就是抽象出来的概念。 抽象类 –…

Java基础学习:抽象类和接口

目录,更新ing,学习Java的点滴记录 目录放在这里太长了,附目录链接大家可以自由选择查看--------Java学习目录 抽象类和接口_抽象类和抽象方法 抽象类是普通的类与接口之间的一种中庸之道,尽管你可能在构建某些未实现方法的类是,第一想法可能是创建接口,但是抽象类仍旧是用于此…

SVD奇异值分解(理论与C++实现)

SVD奇异值分解 前言理论推导部分代码实现 前言 奇异值分解(singular value decomposition,以下简称SVD)是线性代数中一种重要的矩阵分解。SVD将矩阵分解为奇异向量(singular vector)和奇异值(singular value)。SVD将矩阵 A A A分解成三个矩阵的乘积 A U D V T A …

matlab实现奇异值分解

一、原理 二、实现 %% 两种方法计算矩阵 A 的 SVD A [0,1; 1,1; 1,0];%% 方法一:利用特征分解eig % 计算右奇异矩阵V [V,D1] eig(A*A); n size(D1,1); index n:-1:1; D1 diag(D1); D1 D1(index); D1 diag(D1, 0); V V(:,index); % 计算左奇异矩阵U [U,D2…

特征值分解和奇异值分解

特征值分解 特征值分解是将一个方阵A分解为如下形式: A Q Σ Q − 1 AQ\Sigma Q^{-1} AQΣQ−1 其中,Q是方阵A的特征向量组成的矩阵, Σ \Sigma Σ是一个对角矩阵,对角线元素是特征值。 通过特征值分解得到的前N个特征向量&am…

奇异值分解的揭秘(一):矩阵的奇异值分解过程

转载来源: 作者:Xinyu Chen 链接:https://zhuanlan.zhihu.com/p/26306568 来源:知乎 矩阵的奇异值分解(singular value decomposition,简称SVD)是线性代数中很重要的内容,并且奇…

奇异值分解(Singular Values Decomposition,SVD)

奇异值分解 1.奇异值分解1.1 变换(Transformations)1.2 线性变换(Linear Transformations)1.3 降维(Dimensionality Reduction)1.4 奇异值分解(SVD)1.4.1 如果矩阵 A A A是方阵&…

奇异值分解(SVD)的原理详解及推导

1. 写在前面 最近整理推荐系统模型的时候, 第二个模型打算整理一下隐语义模型, 这里面绕不开一种思想就是矩阵分解, 而作为矩阵分解的经典方法SVD感觉这次有必要学学了, SVD不仅是一个数学问题,在工程应用中的很多地方…