oracle 12c 多线程,Oracle 12c(12.1)中性能优化功能增强之通过参数THREADED_EXECTION使用多线程模型...

1.  后台

UNIX/Linux系统上,Oracle用多进程模型。例如:linux上一个常规安装的数据库会有如下进程列:

$ ps -ef | grep [o]ra_

oracle  15356    1  0 10:53 ?        00:00:00 ora_pmon_db12c

oracle  15358    1  0 10:53 ?        00:00:00 ora_psp0_db12c

oracle  15360    1  8 10:53 ?        00:01:27 ora_vktm_db12c

oracle  15364    1  0 10:53 ?        00:00:00 ora_gen0_db12c

oracle  15366    1  0 10:53 ?        00:00:00 ora_mman_db12c

oracle  15370    1  0 10:53 ?        00:00:00 ora_diag_db12c

oracle  15372    1  0 10:53 ?        00:00:00 ora_dbrm_db12c

oracle  15374    1  0 10:53 ?        00:00:00 ora_dia0_db12c

oracle  15376    1  0 10:53 ?        00:00:00 ora_dbw0_db12c

oracle  15378    1  010:53 ?        00:00:00 ora_lgwr_db12c

oracle  15380    1  0 10:53 ?        00:00:00 ora_ckpt_db12c

oracle  15382    1  0 10:53 ?        00:00:00 ora_smon_db12c

oracle  15384    1  0 10:53 ?        00:00:00 ora_reco_db12c

oracle  15386    1  0 10:53 ?        00:00:00 ora_lreg_db12c

oracle  15388    1  0 10:53 ?        00:00:03 ora_mmon_db12c

oracle  15390    1  0 10:53 ?        00:00:00 ora_mmnl_db12c

oracle  15392    1  0 10:53 ?        00:00:00 ora_d000_db12c

oracle  15394    1  010:53 ?        00:00:00 ora_s000_db12c

oracle  15407    1  0 10:54 ?        00:00:00 ora_tmon_db12c

oracle  15409    1  0 10:54 ?        00:00:00 ora_tt00_db12c

oracle  15411    1  0 10:54 ?        00:00:00 ora_smco_db12c

oracle  15413    1  0 10:54 ?        00:00:00 ora_fbda_db12c

oracle  15415    1  0 10:54 ?        00:00:00 ora_aqpc_db12c

oracle  15419    1  0 10:54 ?        00:00:00 ora_p000_db12c

oracle  15421    1  0 10:54 ?        00:00:00 ora_p001_db12c

oracle  15423    1  0 10:54 ?        00:00:00 ora_p002_db12c

oracle  15425    1  0 10:54 ?        00:00:00 ora_p003_db12c

oracle  15435    1  0 10:54 ?        00:00:00 ora_cjq0_db12c

oracle  15459    1  0 10:54 ?        00:00:00 ora_qm02_db12c

oracle  15463    1  0 10:54 ?        00:00:00 ora_q002_db12c

oracle  15465    1  0 10:54 ?        00:00:00 ora_q003_db12c

oracle  15612    1  0 11:04 ?        00:00:00 ora_w000_db12c

oracle  15679    1  0 11:10 ?        00:00:00 ora_j000_db12c

oracle  15681    1  0 11:10 ?        00:00:00 ora_j001_db12c

oracle  15683    1  0 11:10 ?        00:00:00 ora_w001_db12c

$

即使在多进程模型中,某些个别进程内部运行在多线程模式。

相反,在windows系统上,Oracle数据库作为一个多线程进程运行,而每个UNIX/Linux下的进程作为一个或多个线程运行。Oracle12c可以在UNIX/Linux上运行在多线程模式下,就像运行在window上那样。

2.  THREADED_EXECUTION参数

线程模型通过初始化参数THREADED_EXECUTION指定。

1)  THREADED_EXECUTION=FALSE:为默认值,oracle运行在多进程模式下。

2)  THREADED_EXECUTION=TRUE: Oracle以多线程模式运行。

如果想切换到多线程模式,只需设置THREADED_EXECUTION参数并重启数据库就可以。

CONN sys AS SYSDBA

ALTER SYSTEM SET threaded_execution=TRUESCOPE=SPFILE;

SHUTDOWN IMMEDIATE;

STARTUP;

一旦数据库被重启,我们会发现操作系统进程数减少了很多。

$ ps -ef | grep [o]ra_

oracle  15839    1  0 11:26 ?        00:00:00 ora_pmon_db12c

oracle  15841    1  0 11:26 ?        00:00:00 ora_psp0_db12c

oracle  15843    1  8 11:26 ?        00:00:03 ora_vktm_db12c

oracle  15847    1  0 11:26 ?        00:00:00 ora_u004_db12c

oracle  15853    1 34 11:26 ?        00:00:13 ora_u005_db12c

oracle  15859    1  0 11:26 ?        00:00:00 ora_dbw0_db12c

$

另外,需将如下参数添加至"$ORACLE_HOME/network/admin/listener.ora"文件中,以允许产生新线程来支持监听产生的连接,记得要用正确监听名替换

DEDICATED_THROUGH_BROKER_=ON

当需要切换回多进程模型时,只需切换该初始化参数值并重启数据库。

CONN sys AS SYSDBA

ALTER SYSTEM SET threaded_execution=FALSESCOPE=SPFILE;

SHUTDOWN IMMEDIATE;

STARTUP;

记得清楚"listener.ora"文件中的参数。

3.  OS认证

多线程模型不支持OS认证,这是一个特点而不是bug。看前面的例子,使用线程模型时,通过"SYS ASSYSDBA"而不是 "/ AS SYSDBA"连接数据库。试着以OS认证连接库会报错。

$ sqlplus / as sysdba

SQL*Plus: Release 12.1.0.1.0 Production onThu Jul 4 11:28:16 2013

Copyright (c) 1982, 2013, Oracle.  All rights reserved.

ERROR:

ORA-01017: invalid username/password;logon denied

Enter user-name: sys as sysdba

Enter password:

Connected to:

Oracle Database 12c Enterprise EditionRelease 12.1.0.1.0 - 64bit Production

With the Partitioning, OLAP, AdvancedAnalytics and Real Application Testing options

SQL>

文档上说会报错ORA-01031 "insufficientprivileges" 。

4.  杀会话

视图V$PROCESS包括一个叫STID的新列,该列显示会话的线程ID。

SET LINESIZE 140

COLUMN username FORMAT A15

COLUMN oSUSEr FORMAT A15

COLUMN spid FORMAT A10

COLUMN stid FORMAT A10

SELECT s.username,

s.osuser,

s.sid,

s.serial#,

p.spid,

p.stid,

s.status

FROM  v$session s,

v$process p

WHERE s.paddr = p.addr

AND  s.username IS NOT NULL

ORDER BY s.username, s.osuser;

USERNAME        OSUSER                SID    SERIAL# SPID      STID      STATUS

--------------- --------------- -------------------- ---------- ---------- --------

SYS            oracle                  35          3 18844      18901    ACTIVE

TEST            oracle                  40        37 18844      19020    INACTIVE

SQL>

在Oracle内杀会话的方法没变,因为你还是可以找到SID和SERIAL#。

SQL> ALTER SYSTEM KILL SESSION '40,37';

System altered.

SQL>

但一定不要用UNIX/Linux命令杀掉会话进程(SPID)对应的OS进程,否则,我们会杀掉多个会话,而不是我们真正想杀的会话。

$ ps -ef | grep 18844 | grep -v grep

oracle  18844    1  1 16:27 ?        00:00:22 ora_u005_db12c

$

5.  总结

1)  使用该特点的唯一可信理由是将多个实例集成到一个服务器上,同时,没用多宿主数据库选项。因为,如果不用多线程模型,OS进程数将会很高。

2)  如果你的硬件架构相对进程而言,更适合处理线程,那么,该特点也许会带来一些好处。

3)  RAC环境中,各节点必须都用同样的线程模型。

0b1331709591d260c1c78e86d0c51c18.png

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

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

相关文章

使用工作单元UnitOfWork实现事务

概述工作单元模式有如下几个特性:1、使用同一上下文2、跟踪实体的状态3、保障事务一致性。工作单元用来维护一个由已经被业务事物修改的业务对象组成的列表。Unit Of Work模式负责协调这些修改的持久化工作以及所有标记的并发问题。在数据访问层中采用Unit Of Work…

MyEclipse配置Tomcat(图解)

1) 安装完MyEclipse后,在Eclpise的菜单栏可看到MyEclipse一项, 下面的工具栏中可看到MyEclipse的Tomcat图标2) 进行MyEclipse的配置, 从菜单栏中进入“Windows --> Preferences”3) 先要进行JDK的配置&#x…

Python难懂?买一次西瓜就懂了!

什么是code?code就就是一种语言,一种计算机能读懂的语言。计算机是一个傻*,他理解不了默认两可的任何东西。比如,你让你老公去买个西瓜,你老公会自己决定去哪里买,买几个,找个搞活动打折的买,总…

制作oracle11g yum源,利用安装盘简单制作yum源

第一步:创建一个新文件夹,并挂载光驱.[rootlocalhost ~]# mkdir /yum[rootlocalhost ~]# mount /dev/cdrom /mnt/cdrom第二步:安装工具包:[rootlocalhost ~]# rpm -ivh /mnt/cdrom/CentOS/createrepo-0.4.11-3.el5.noarch.rpm第三步&#xff…

安全删除U盘时,遇到提示“无法停止‘通用卷’设备时解决方法

安全删除U盘时,大家常常会遇到提示“无法停止‘通用卷’设备,请稍候再停止该设备。” 这种情况下可以强行拔下U盘吗?当然不可以!这时候如果强行拔除的话,很容易损坏计算机U口或者你的U盘。如果你的U盘上有重要的资料&a…

宠粉老鱼皮带你 “入坑” GitHub!

昨天刚刚教大家 如何更快地访问 GitHub,按照惯例,今天不得来一个 GitHub 教程?最近,鱼皮在持续完善自己 GitHub 上的开源项目,也分享给了很多小伙伴,苦苦哀求大家可以给个 star。liyupi 的 GitHub但是&…

linux中显示目录名,在linux下显示中文目录和文件名

选择一个一劳永逸的方法,就是修改/etc/下的fstab文件,我的fstab内容如下:/dev/hda9 / ext2 defaults 1 1/dev/hda8 /boot ext2 defaults 1 2none /dev/pts devpts gid5,mode620 0 0none /proc proc defaults 0 0none /dev/shm tmpfs defaults…

统计学入门需掌握的四点思想

大家晚上好,自从小天悄悄报名Power Query课程并利用休息时间学习,结果因为太嗨被超模君发现了之后,小天又多了一个任务:利用统计学知识处理和分析之前累积的大量数据。(抱歉,暴露超模君老是鞭策我的事实了&…

PIX的AAA认证配置

#vir telnet 10.1.1.1 (一般使用global地址) #access-list auth permit tcp any any eq http #access-list auth permit tcp any any eq telnet //http和telnet协议捆绑抓流量#aaa-server 3a protocol tacacst #aaa-server 3a host 20.1.1.241 //20.1.1.241是aaa服务器…

UML常用图的几种关系的总结

在UML的类图中,常见的有以下几种关系: 泛化(Generalization), 实现(Realization), 关联(Association), 聚合(Aggregation), 组合(Composition), 依赖(Dependency)1. 泛化&…

linux编程两个子进程,Linux中fork同时创建多个子进程的方法

怎么创建多个进程呢&#xff1f;我说那还不容易&#xff0c;看下边代码://省略必要头文件int main(){pid_t pid[2];int i;printf("This is %d\n",getpid());for(i 0;i < 2;i ){if((pid[0] fork()) < 0){printf("Fork() Error!");exit(-1);}if(pid[…

我为什么鼓励你读计算机博士

看过《水浒传》的朋友都知道&#xff0c;梁山的一百单八将因为各种理由加入了水寨&#xff0c;走上了劫富济贫、替天行道的路。我2006年从南京大学本科毕业以后&#xff0c;耳闻目睹了数百位计算机专业的博士&#xff08;生&#xff09;&#xff0c;他们选择读博士的理由可以说…

重构者的20种死法

最近涉及重构话题的文章不少啊&#xff0c;其实我也一直在憧憬重构&#xff0c;重构很绿色&#xff0c;重构很河蟹&#xff0c;重构令人很激动&#xff0c;重构可能让人死得很惨。 我在这里&#xff0c;就列举一下Refactorman的种种死法&#xff0c;以警后人&#xff1a; 一、一…

一日一技:在Ocelot网关中统一配置Swagger

概述Swagger 是一个规范和完整的框架&#xff0c;用于生成、描述、调用和可视化 RESTful 风格的 Web 服务。在Ocelot网关中&#xff0c;我们提供给前端的直接是Swagger&#xff0c;如果Swagger分布在各个API中&#xff0c;前端查看Swagger的时候非常不便&#xff0c;Ocelot与Sw…

linux命令行模式kvm,Linux命令行管理KVM虚拟机【一】 | C/C++程序员之家

Linux命令行管理KVM虚拟机&#xff0c;几个常见的Linux-KVM虚拟机 管理命令&#xff0c;保存备用&#xff0c;方便快速部署搭建Linux开发环境&#xff0c;搞来搞去还是Linux下虚拟化好使&#xff0c;方便Linux和Win&#xff01;virsh$ sudo virsh -c qemu:///system listId Nam…

Oracle Solaris 11 Express发布了

甲骨文Solaris 11 Express操作系统在Solaris 10的基础上进一步加强了各种功能&#xff0c;Solaris 11 Express将为关键的企业系统环境提供最佳的UNIX体验(与之相对应的是Oracle Enterprise Linux&#xff0c;将提供最优的Linux体验)。举例而言新系统中基于网络的包管理工具(pac…

自从我上了数据结构课之后……

在 Reddit 上看到一个英文帖子&#xff0c;问&#xff1a;上了数据结构课后&#xff0c;还有正常生活么&#xff1f;有人引用了 Quora 上的一个英文回答&#xff0c;大意如下&#xff1a;嗯&#xff0c;没有&#xff01;你看东西的眼光&#xff0c;不可能和以前一样了。不管你信…

如何在 C#9 中使用 static 匿名函数

匿名函数 在 C# 中已经出现很多年了&#xff0c;虽然匿名函数用起来很爽&#xff0c;但代价是不小的&#xff0c;为了避免不必要那些你意想不到的内存分配&#xff0c;这就是为什么 C#9 中引入 static 匿名函数的原因&#xff0c;这篇文章我们将会讨论如何使用 静态匿名函数 以…

Linux 远程桌面 rdesktop 软件

为什么80%的码农都做不了架构师&#xff1f;>>> 众所周知XP下有"远程桌面连接"用来远程登录桌面&#xff0c;设置也非常简单。那有没有什么办法在linux 下远程登录到XP呢&#xff1f;有。用rdesktop这个linux下的软件就能实现。 发现新立得也有下载&…

linux进程的高级管理,Linux高级程序设计(第2版) PDF扫描版[94MB]

Linux高级程序设计(第2版)以Linux操作系统(内核为2.6版本)为开发平台、GCC 4.0/GDB 6.3为开发调试环境&#xff0c;详细介绍了Linux系统下编程环境及编程工具、文件管理(文件类型、ANSI以及POSIX标准下文件读写操作)、进程管理(创建、退出、执行、等待、属性控制)、进程间通信(…