声明:版本11gR2,CentOS5.8 1 物理结构(文件) 主要性能影响在IO上 (1)controlfile select * from v$controlfile (2)datafile select * from dba_data_files (3)redo?(online logfile) select * from v$logfileselect * from v$log (4)password file
声明:版本11gR2,CentOS5.8
1 物理结构(文件)
主要性能影响在IO上
(1)controlfile
select * from v$controlfile
(2)datafile
select * from dba_data_files
(3)redo?(online logfile)
select * from v$logfile select * from v$log
(4)password file(sys)
select * from dba_users
(从11g开始password项里变为空了,以免被破解)
2 逻辑结构
2.1 实例
instance(memory[sga]+process[background])
实例=内存(sga)+后台进程(background)
查看内存,可以通过以下视图
select * from v$sga_dynamic_components
?后台进程,可以通过下面视图查看
select * fromv$bgprocess where paddr!='00';
? 我们只关心paddr不等于0的就可以了,等于0的都是没启用
2.2实例的管理
参数文件spfilesid.ora,initsid.ora
两个文件可以互相转化
create spfile from pfile; create pfile from spfile;
(1)开启实例分为nomount,mount,open三个阶段

l? nomount阶段
在开启到nomount阶段需要使用到参数文件,而从9i版本开始默认优先使用spfile参数文件,如果spfile文件没有就去使用pfile文件,如果pfile文件还没有,就会报找不到pfile文件的错误。
11g有一个新功能,也许是我才发现吧!!!首先先说下数据库开启时,如果参数文件丢失或者损坏,不会导致数据库直接宕掉,但是如果数据库重新启动的话,就会报错,而且如果要是没有个好的备份的话,那是非常麻烦的事情,如果数据库在运行时及时发现了参数文件丢失或者损坏,可以使用如下方法处理:
create pfile from memory;
所以参数文件一定要有个良好的备份。
可以通过v$instance视图查看数据库状态
select status from v$instance;
通过v$bgprocess视图可以查看后台进程的情况
select * from v$bgprocess where paddr’00’;

l? mount阶段
开启mount阶段需要用到控制文件
可以使用参数control_files查看控制文件所在位置:
show parameter control_files
如果控制文件损坏,在开启数据库的时候就会报错,而且告诉你去alert_sid.log里看具体错误信息,而这个文件所在位置,可以通过background_dump_dest参数去查看:
show parameter background
注:alert_sid.log最大支持到2G大小,所以当业务特殊繁忙或者文件变的比较大的时候需要备份。
l? open阶段
11gR2版本—经测试,其他版本不确定
可以从open阶段到mount阶段在到nomount阶段
alter database close; alter database dismount; shutdown immediate
(2)关闭实例
1.normal
2.transactional
系统有事务的时候就关闭不了
系统有没有事务可以查看v$transaction视图
3.immediate
4.abort
2.3 参数的粗略概述
用db_cache_size和processes两个参数举例
首先查看v$parameter视图可以查看是否是静态参数或者是动态
select name,issys_modifiablefromv$parameter wherename in ('db_cache_size','processes'); NAME ISSYS_MOD -------------------- --------- processes FALSE db_cache_size IMMEDIATE
从ISSYS_MOD字段可以看出db_cache_size参数是立即生效,所以从这个可以看出db_cache_size字段是动态参数。
注意:其中processes参数如果过多比如更改为50000个数量的时候,数据库在重新启动的时候会挂住。
?
2.4 session(process)
A)process
select * from v$process;
包含v$bgprocess
l? 通过如下以下方法可以追溯到OS系统的进程
SQL> select distinct sid fromv$mystat; SID ---------- 37 SQL> select sid,paddr fromv$session where sid=37; SID PADDR ---------- -------- 37 43BC365C SQL> select addr,pid,spidfrom v$process where addr='43BC365C'; ADDR PID SPID -------- ---------------------------------- 43BC365C 20 11633 [root@elvis ~]# ps -ef | grepora root 3762 3732 0 May30 ? 00:01:02 hald-addon-storage: polling/dev/hdc oracle 4604 1 0 May30 ? 00:00:02/u01/oracle/product/11.2.0/dbhome_1/bin/tnslsnr LISTENER -inherit oracle 7624 1 0 06:22 ? 00:00:07 ora_pmon_elvis oracle 7628 1 0 06:22 ? 00:00:35 ora_vktm_elvis oracle 7634 1 0 06:22 ? 00:00:00 ora_gen0_elvis oracle 7638 1 0 06:22 ? 00:00:01 ora_diag_elvis oracle 7642 1 0 06:22 ? 00:00:00 ora_dbrm_elvis oracle 7646 1 0 06:22 ? 00:00:01 ora_psp0_elvis oracle 7650 1 0 06:22 ? 00:00:35 ora_dia0_elvis oracle 7654 1 0 06:22 ? 00:00:05 ora_mman_elvis oracle 7658 1 0 06:22 ? 00:00:03 ora_dbw0_elvis oracle 7662 1 0 06:22 ? 00:00:02 ora_lgwr_elvis oracle 7666 1 0 06:22 ? 00:00:16 ora_ckpt_elvis oracle 7670 1 0 06:22 ? 00:00:06 ora_smon_elvis oracle 7674 1 0 06:22 ? 00:00:00 ora_reco_elvis oracle 7678 1 0 06:22 ? 00:00:11 ora_mmon_elvis oracle 7682 1 0 06:22 ? 00:00:07 ora_mmnl_elvis oracle 7686 1 0 06:23 ? 00:00:00 ora_d000_elvis oracle 7690 1 0 06:23 ? 00:00:00 ora_s000_elvis oracle 9125 1 0 10:26 ? 00:00:00 ora_arc0_elvis oracle 9129 1 0 10:26 ? 00:00:00 ora_arc1_elvis oracle 9133 1 0 10:26 ? 00:00:00 ora_arc2_elvis oracle 9137 1 0 10:26 ? 00:00:00 ora_arc3_elvis oracle 9177 1 0 10:31 ? 00:00:00 ora_smco_elvis root 11596 11564 0 16:36 pts/0 00:00:00 su - oracle oracle 11597 11596 0 16:36 pts/0 00:00:00 -bash oracle 11629 11597 0 16:36 pts/0 00:00:00 rlwrapsqlplus / as sysdba oracle 11630 11629 0 16:36 pts/1 00:00:00sqlplus as sysdba oracle 11633 11630 0 16:36 ? 00:00:00oracleelvis (DESCRIPTION=(LOCAL=YES)(ADDRESS=(PROTOCOL=beq))) oracle 11637 1 0 16:36 ? 00:00:01 oracleelvis (LOCAL=NO) oracle 11678 1 0 16:38 ? 00:00:00 oracleelvis (LOCAL=NO) oracle 11682 1 0 16:39 ? 00:00:00 ora_w000_elvis root 11735 11695 0 16:42 pts/2 00:00:00 grep ora
注:如果是windows环境下情况较复杂,具体的进程ID需要去查看线程,而Windows不能直接查看进程下的线程必须通过第三方工具去查看。
l? 从进程资源占用情况追溯到session
这种情况下,可以查找到是哪个session在占用大量资源,甚至能查找到
B)session
l? 资源视图—重要
select * from v$resource_limit;
l? 命令类型视图,根据v$session视图里的command列判断
select * from audit_actions;
l?通过session视图的sql_id列,查看到sql语句
select * from v$sql where sql_id=’ ’;
模拟消耗资源的死循环的语句
declare number:=0; begin loop i:=1; end loop: end;
找到后Kill掉session
alter system kill session ’67,23’;
或者直接Kill掉进程
Window下是orakill命令,服务器端具备
Linux下是kill,top,ps –ef | grep ora等命令
Kill用法
--kill -9 sid 强制kill掉
C)connection
专有连接
共享连接
基本不使用,了解即可
池中连接
3 深入逻辑结构
3.1 表空间
database->tablespace->segments->extents->osblocks
===============================================
selelct * from dba_tablespaces; select * from dba_data_files; select * from dba_temp_files; select * from dba_segment;
?--一个表空间可以包含最多1023个数据文件
注:从11g开始有延迟段的概念,就是表中无数据的话,Oracle不分配空间
通过参数deferred_segment_creation查看延迟段的开启情况
--show parameterdeferred_segment_creation
===============================================
创建一个表空间
create tablespace orcl datafile 'E:\ORADATA\orcl\orcl01.dbf' size 10M;
然后创建一个表并指定存到orcl表空间中
create table t(id int) tablespace orcl;
表空间的分配方式 (extent为单位)
autoallocate(默认)
>1g???? 64m???8096blocks
Uniform [指定增长大小]
始终都会按指定的大小增长
分配方式可以查看dba_tablespace视图中allocate_type字段为system就是默认??
在关掉这个表空间
alter tablespace orcl offline;
->notes:虽然表不能访问和修改了,但可以删除,相当于数据库
? 关闭了,只不过这是局部关闭。
回收站命令 show recyclebin 可以查询,但不可以对回收站里的表执行DDL/DML
select * from " BIN$wHUg/RiVRxuXtwyypSxnTw==$0 TABLE" ;
从回收站里拿出来?闪回
flashback table t to before drop;
?
================================================
可以使用EM来观察表空间的使用率
?--登录->administration->tablespace
3.2 表空间和数据文件的管理
创建一个表
create table tt tablespace orcl as select * from dba_objects;
持续插入数据
insert into tt select * from tt;
当表空间大小不足时,扩展表空间大致有以下几种方式:
1.直接扩展数据文件大小
alter database datafile file_id resize 20M;
2.自动扩展数据文件大小
alter database datafile 5 autoextend on next 1M maxsize 1024M;
3.手动扩展表空间的大小
alter tablespace orcl add datafile 'D:\oradata\orcl\orcl02.dbf' autoextend on next 1M maxsize 1024M;
为tt表分配了40M的空间大小且会显示但里面没有数据是空的(插入会遵循有空间的优先插入)
alter table tt allocate extent(datafile'D:\oradata\orcl\orcl02.dbf' size 40M);
查看表中块的使用情况方法:
1.包的方式
execdbms_stats.gather_table_stats(‘table’,’TEST’);
2.分析表—这种更准确
analyze table tt computestatistics;
从10g开始可以为tt表紧缩
alter table t shrink space;
但紧缩需要行移动(row movement)
alter table t shrink space;
这样就可以紧缩了。。。
查看row movement 是否可以移动
select * from dba_tables where table_name='T';
===============================================================
把表t移动到表空间2里,观察会有什么变化
alter table t move tablespace orcl02;
案例一:
?优化问题,观察磁盘读取速率及各个文件的读取情况。
?视图:
?--dba打头的属于静态数据来自于system里的数据字典
??--v$打头的属于动态,一般来自于控制文件等,且存储在内存中,所以服务器尽量不要重启,重启后,动态信息会消失,当然从10g
?开始oracle已经每隔一个小时会存储下动态信息
select * from v$filestat;
3.3 undo表空间
创建undo表空间
create undo tablespace undotbs2 database'E:\oradata\orcl\undotbs02.dbf' size 10M;
在表t中加入一列
alter table t add name varchar2(10) default 'a'; insert into t values(1,'elvis'); insert into t values(2,'elvis'); commit;
然后更新下列值
updata t set name='c' where id=1; select * from t;
不提交通过另外一个窗口同一个用户身份去查询观察。
?--当然不会看到,因为没有提交
作者:elvis_dataguru 发表于2013-6-21 15:07:40 原文链接
阅读:38 评论:0 查看评论
原文地址:Oracle的体系结构概览, 感谢原作者分享。

存储过程是MySQL中的预编译SQL语句集合,用于提高性能和简化复杂操作。1.提高性能:首次编译后,后续调用无需重新编译。2.提高安全性:通过权限控制限制数据表访问。3.简化复杂操作:将多条SQL语句组合,简化应用层逻辑。

MySQL查询缓存的工作原理是通过存储SELECT查询的结果,当相同查询再次执行时,直接返回缓存结果。1)查询缓存提高数据库读取性能,通过哈希值查找缓存结果。2)配置简单,在MySQL配置文件中设置query_cache_type和query_cache_size。3)使用SQL_NO_CACHE关键字可以禁用特定查询的缓存。4)在高频更新环境中,查询缓存可能导致性能瓶颈,需通过监控和调整参数优化使用。

MySQL被广泛应用于各种项目中的原因包括:1.高性能与可扩展性,支持多种存储引擎;2.易于使用和维护,配置简单且工具丰富;3.丰富的生态系统,吸引大量社区和第三方工具支持;4.跨平台支持,适用于多种操作系统。

MySQL数据库升级的步骤包括:1.备份数据库,2.停止当前MySQL服务,3.安装新版本MySQL,4.启动新版本MySQL服务,5.恢复数据库。升级过程需注意兼容性问题,并可使用高级工具如PerconaToolkit进行测试和优化。

MySQL备份策略包括逻辑备份、物理备份、增量备份、基于复制的备份和云备份。1.逻辑备份使用mysqldump导出数据库结构和数据,适合小型数据库和版本迁移。2.物理备份通过复制数据文件,速度快且全面,但需数据库一致性。3.增量备份利用二进制日志记录变化,适用于大型数据库。4.基于复制的备份通过从服务器备份,减少对生产系统的影响。5.云备份如AmazonRDS提供自动化解决方案,但成本和控制需考虑。选择策略时应考虑数据库大小、停机容忍度、恢复时间和恢复点目标。

MySQLclusteringenhancesdatabaserobustnessandscalabilitybydistributingdataacrossmultiplenodes.ItusestheNDBenginefordatareplicationandfaulttolerance,ensuringhighavailability.Setupinvolvesconfiguringmanagement,data,andSQLnodes,withcarefulmonitoringandpe

在MySQL中优化数据库模式设计可通过以下步骤提升性能:1.索引优化:在常用查询列上创建索引,平衡查询和插入更新的开销。2.表结构优化:通过规范化或反规范化减少数据冗余,提高访问效率。3.数据类型选择:使用合适的数据类型,如INT替代VARCHAR,减少存储空间。4.分区和分表:对于大数据量,使用分区和分表分散数据,提升查询和维护效率。

tooptimizemysqlperformance,lofterTheSeSteps:1)inasemproperIndexingTospeedUpqueries,2)使用ExplaintplaintoAnalyzeandoptimizequeryPerformance,3)ActiveServerConfigurationStersLikeTlikeTlikeTlikeIkeLikeIkeIkeLikeIkeLikeIkeLikeIkeLikeNodb_buffer_pool_sizizeandmax_connections,4)


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

禅工作室 13.0.1
功能强大的PHP集成开发环境