设为首页 收藏本站
查看: 830|回复: 2

[经验分享] oracle数据库新环境常见配置

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2013-10-30 09:21:15 | 显示全部楼层 |阅读模式


**************************
1.开启归档
**************************
archive log list;
alter system set log_archive_dest_1='location=/u01/app/oracle/arch' scope=spfile;
shutdown immediate
startup mount
alter database  archivelog ;
或关闭自动归档
alter database noarchivelog;
alter database open;
**************************
2.redo
**************************
--2.1 查看需要增加日志大小
/**
如果平均时间<5分钟,则需要增加日志大小
**/
col min_minutes format 999.99
col max_minutes format 999.99
col avg_minutes format 999.99
set pagesize 1000
set lines 70
set echo on
WITH log_history AS
       (SELECT thread#, first_time,
               LAG(first_time) OVER (ORDER BY thread#, sequence#)
                  last_first_time,
               (first_time
                - LAG(first_time) OVER (ORDER BY thread#, sequence#))
                    * 24* 60   last_log_time_minutes,
               LAG(thread#) OVER (ORDER BY thread#, sequence#)
                   last_thread#
        FROM v$log_history)
SELECT ROUND(MIN(last_log_time_minutes), 2) min_minutes,
       ROUND(MAX(last_log_time_minutes), 2) max_minutes,
       ROUND(AVG(last_log_time_minutes), 2) avg_minutes
FROM log_history
WHERE     last_first_time IS NOT NULL
      AND last_thread# = thread#
      AND first_time > SYSDATE - 1;
--2.2 列出Oracle每小时的redo重做日志产生量
ALTER SESSION SET NLS_DATE_FORMAT = 'DD-MON-YY HH24:MI:SS';
WITH times AS
(SELECT /*+ MATERIALIZE */
   hour_end_time
    FROM (SELECT (TRUNC(SYSDATE, 'HH') + (2 / 24)) - (ROWNUM / 24) hour_end_time
            FROM DUAL
          CONNECT BY ROWNUM <= (1 * 24) + 3),
         v$database
   WHERE log_mode = 'ARCHIVELOG')
SELECT hour_end_time, NVL(ROUND(SUM(size_mb), 3), 0) size_mb, i.instance_name
  FROM(
SELECT hour_end_time, CASE WHEN(hour_end_time - (1 / 24)) > lag_next_time THEN(next_time + (1 / 24) - hour_end_time) * (size_mb / (next_time - lag_next_time)) ELSE 0 END + CASE WHEN hour_end_time < lead_next_time THEN(hour_end_time - next_time) * (lead_size_mb / (lead_next_time - next_time)) ELSE 0 END + CASE WHEN lag_next_time > (hour_end_time - (1 / 24)) THEN size_mb ELSE 0 END + CASE WHEN next_time IS NULL THEN(1 / 24) * LAST_VALUE(CASE WHEN next_time IS NOT NULL AND lag_next_time IS NULL THEN 0 ELSE(size_mb / (next_time - lag_next_time)) END IGNORE NULLS) OVER(
ORDER BY hour_end_time DESC, next_time DESC) ELSE 0 END size_mb
  FROM(
SELECT t.hour_end_time, arc.next_time, arc.lag_next_time, LEAD(arc.next_time) OVER(
ORDER BY arc.next_time ASC) lead_next_time, arc.size_mb, LEAD(arc.size_mb) OVER(
ORDER BY arc.next_time ASC) lead_size_mb
  FROM times t,(
SELECT next_time, size_mb, LAG(next_time) OVER(
ORDER BY next_time) lag_next_time
  FROM(
SELECT next_time, SUM(size_mb) size_mb
  FROM(
SELECT DISTINCT a.sequence#, a.next_time, ROUND(a.blocks * a.block_size / 1024 / 1024) size_mb
  FROM v$archived_log a,(
SELECT /*+ no_merge */
CASE WHEN TO_NUMBER(pt.VALUE) = 0 THEN 1 ELSE TO_NUMBER(pt.VALUE) END VALUE
  FROM v$parameter pt
WHERE pt.name = 'thread') pt
WHERE a.next_time > SYSDATE - 3 AND a.thread# = pt.VALUE AND ROUND(a.blocks * a.block_size / 1024 / 1024) > 0)
GROUP BY next_time)) arc
WHERE t.hour_end_time = (TRUNC(arc.next_time(+), 'HH') + (1 / 24)))
WHERE hour_end_time > TRUNC(SYSDATE, 'HH') - 1 - (1 / 24)), v$instance i
WHERE hour_end_time <= TRUNC(SYSDATE, 'HH')
GROUP BY hour_end_time, i.instance_name
ORDER BY hour_end_time
/
2.3创建2个新的中间临时日志组
alter database add logfile group 4
('/u01/app/oracle/oradata/orcl/redo04.log') size 200M;
alter database add logfile group 5
('/u01/app/oracle/oradata/orcl/redo05.log') size 200M;
--查看日志使用情况
SQL> select group#,status,archived from v$log;
    GROUP# STATUS           ARC
---------- ---------------- ---
         1 CURRENT          NO
         2 INACTIVE         NO
         3 INACTIVE         NO
         4 UNUSED           YES
         5 UNUSED           YES
2.4 切换当前日志到新的日志组,切换current日志到添加的日志组
alter system switch logfile;
alter system switch logfile;
alter system checkpoint;
SQL> select group#,status,archived from v$log;
    GROUP# STATUS           ARC
---------- ---------------- ---
         1 INACTIVE         YES
         2 INACTIVE         YES
         3 INACTIVE         YES
         4 INACTIVE         YES
         5 CURRENT          NO
####如果你想删除哪个日志就要把他的状态切换为:inactive
2.5 删除旧的日志组
alter database drop logfile group 1;
alter database drop logfile group 2;
alter database drop logfile group 3;
2.6 操作系统下删除原日志组1、2、3中的文件
rm -f /u01/app/oracle/oradata/orcl/redo01.log
rm  -f /u01/app/oracle/oradata/orcl/redo02.log
rm -f  /u01/app/oracle/oradata/orcl/redo03.log
2.7 重建日志组1、2、3
alter database add logfile group 1
('/u01/app/oracle/oradata/orcl/redo01.log',
'/u01/app/oracle/oradata/orcl/redo001.log')
size 1000m;
alter database add logfile group 2
('/u01/app/oracle/oradata/orcl/redo02.log',
'/u01/app/oracle/oradata/orcl/redo002.log')
size 1000m;
alter database add logfile group 3
('/u01/app/oracle/oradata/orcl/redo03.log',
'/u01/app/oracle/oradata/orcl/redo003.log')
size 1000m;
2.8 切换日志组
####你想删除哪个日志就要把他的状态切换为:inactive
select group#,status,archived from v$log;
SQL> select group#,status,archived from v$log;
    GROUP# STATUS           ARC
---------- ---------------- ---
         1 UNUSED           YES
         2 UNUSED           YES
         3 UNUSED           YES
         4 INACTIVE         YES
         5 CURRENT          NO
--切换日志,
alter system switch logfile;
--切换到1-3日志组中任意一个current,其它都是active执行checkpoint即可
alter system checkpoint;
SQL> select group#,status,archived from v$log;
    GROUP# STATUS           ARC
---------- ---------------- ---
         1 CURRENT          NO
         2 INACTIVE         YES
         3 INACTIVE         YES
         4 INACTIVE         YES
         5 INACTIVE         YES
2.9 删除中间过渡用的日志组4、5
alter database drop logfile group 4;
alter database drop logfile group 5;
2.10 到操作系统下删除原日志组4、5中的文件
rm -f /u01/app/oracle/oradata/orcl/redo04.log
rm -f  /u01/app/oracle/oradata/orcl/redo05.log
**************************
3.temp表空间组
**************************
create temporary tablespace temp01
tempfile '/u01/app/oracle/oradata/orcl/TEMP001.DBF'
size 2000M;
create temporary tablespace temp02
tempfile '/u01/app/oracle/oradata/orcl/TEMP002.DBF'
size 2000M;
create temporary tablespace temp03
tempfile '/u01/app/oracle/oradata/orcl/TEMP003.DBF'
size 2000M;
create temporary tablespace tempex
tempfile '/u01/app/oracle/oradata/orcl/tempex.DBF'
size 2000M;
select tablespace_name from dba_tablespaces where contents='TEMPORARY';
TABLESPACE_NAME
------------------------------
TEMP
TEMP01
TEMP02
TEMP03
TEMPEX
---设置过度临时表空间
alter database default temporary tablespace tempex;
--删除临时表空间
drop tablespace temp including contents and datafiles;
select tablespace_name from dba_tablespaces where contents='TEMPORARY';
TABLESPACE_NAME
------------------------------
TEMP01
TEMP02
TEMP03
TEMPEX
----将不同的表空间加入到相同的文件组
alter tablespace temp01 tablespace group temp;
alter tablespace temp02 tablespace group temp;
alter tablespace temp03 tablespace group temp;
SQL> select * from dba_tablespace_groups;
GROUP_NAME             TABLESPACE_NAME
------------------------------ ------------------------------
TEMP                   TEMP01
TEMP                   TEMP02
TEMP                   TEMP03
---设置默认表空间
alter database default temporary tablespace temp;
删除临时表空间组
alter tablespace tmp01 tablespace group '';
--删除过度临时表空间
drop tablespace tempex including contents and datafiles;
**************************
4.UNDO表空间
**************************
show parameters undo;
NAME                                 TYPE        VALUE
------------------------------------ ----------- ----------------
undo_management                      string      AUTO
undo_retention                       integer     1800
undo_tablespace                      string      UNDOTBS
select tablespace_name from dba_tablespaceswhere contents='UNDO';
---1.确定UNDO表空间大小
/****
1.计算业务高峰期每秒产生undo数据块的个数:
SQL> select max(undoblks / ((end_time - begin_time)*24*3600))  from v$undostat;
2.得到undo数据块在undo表空间中可以保留的最长时间
show parameter undo_retention
3.得到数据块大小
show parameter db_block;
4.将以上三者的数据相乘就是所需undo表空间的大小数。
select begin_time,end_time,undoblks
from v$undostat;
********/
----2.确定最优的撤销保留时间
/****
如果需要使用undo_retention的前提:
1.撤销表空间设置AUTOEXTEND选项
2.如果得到ORA-0155快照太久的错误,说明oracle闪回操作,意味数据库没有能有效的
动态的调整撤销保留时间.这种情况下可以增大undo_retention的时间值.
alter system set undo_retention=1800 scope=both;
通过下面的公式计算:
undo_retention=undo size/(db_block_size*undo_block_per_sec)
第1步:计算数据库中实际产生的撤销数据:
select sum(a.bytes) "UNDO"
from v$datafile a,
v$tablespace b,
dba_tablespaces c
where c.contents='UNDO'
and c.status='ONLINE'
and b.name=c.tablespace_name
and a.ts#=b.ts#;
--
335544320
第2步:计算undo_block_per_sec
select ceil(max(undoblks/((end_time-begin_time)*3600*24))) "UNDO_BLOCK_PER_SEC"
from v$undostat;
--
8
第3步:查看db_block_size
show parameters db_block_size;
--8192
第4步:计算出undo_retention
undo_retention=335544320/(8*8192)=5120
结果为目前undo的大小可以保留5120秒.我们设置的undo_retention=1800秒,其实可以设置的时间更长.
---自动优化撤销保留时间
select to_char(begin_time,'hh24:mi:ss') begin_time,
to_char(end_time,'hh24:mi:ss') end_time,
maxquerylen,nospaceerrcnt,tuned_undoretention  --maxquerylen最长的查询
from v$undostat;
---查询撤销数据块的使用率,以及每十分钟间隔内的事务计数
select to_char(begin_time,'hh24:mi:ss'),to_char(end_time,'hh24:mi"ss'),
maxquerylen,ssolderrcnt,nospaceerrcnt,undoblks,txncount from v$undostat
order by undoblks
;
***/
---3.设置undo
select tablespace_name from dba_tablespaces where contents='UNDO';
create undo tablespace undotbs2
datafile '/u01/app/oracle/oradata/orclUNDOTBS02.DBF' size 100M
reuse autoextend on next 100M MAXSIZE UNLIMITED;
Alter system set undo_tablespace=undotbs2;
drop tablespace undotbs1 including contents and datafiles;
create undo tablespace undotbs1
datafile '/u01/app/oracle/oradata/orclUNDOTBS01.DBF' size 5000M
reuse autoextend on next 100M MAXSIZE UNLIMITED;
Alter system set undo_tablespace=undotbs1;
Alter tablespace undotbs1 retention guarantee;
drop tablespace undotbs2 including contents and datafiles;
**************************
5.修改多路控制文件
**************************
select name from v$controlfile;
create pfile='/u01/app/oracle/initorcl.ora' from spfile;
shutdown immediate
修改/u01/app/oracle/initorcl.ora:
*.control_files='/u01/app/oracle/oradata/orcl/control01.ctl',
'/u01/app/oracle/oradata/orcl/control02.ctl'',
'/u01/app/oracle/oradata/orcl/control03.ctl''
cp /u01/app/oracle/oradata/orcl/control01.ctl   /u01/app/oracle/oradata/orcl/control02.ctl
cp /u01/app/oracle/oradata/orcl/control01.ctl   /u01/app/oracle/oradata/orcl/control03.ctl
根据需要,复制控制文件名到相应路径并修改名
create spfile from pfile='/u01/app/oracle/initorcl.ora';
startup
select name from v$controlfile;
**************************
6.全局配置文件的设置
**************************
vi   /u01/app/oracle/product/11.2.0/db_1/sqlplus/admin/glogin.sql
或E:\app\Administrator\product\11.2.0\dbhome_1\sqlplus\admin\glogin.sql
--dba add for oracle
alter session set nls_date_format='YYYY-MM-DD HH24:MI:SS';
define _editor=vi
set serveroutput on size 1000000
set trimspool on
set long 5000
set linesize 100
set pagesize 9999
column plan_plus_exp format a80
column global_name new_value gname
set termout off
define gname=idle
column global_name new_value gname
select lower(user) || '@' || substr( global_name, 1,
decode( dot, 0, length(global_name), dot-1) ) global_name
from (select global_name, instr(global_name,'.') dot from global_name );
set time on
set sqlprompt '&gname>'
**************************
7.防止密码过期
**************************
SELECT * FROM dba_profiles WHERE profile='DEFAULT' AND resource_name='PASSWORD_LIFE_TIME';
ALTER PROFILE DEFAULT LIMIT PASSWORD_LIFE_TIME UNLIMITED ;
**************************
8.rman修改控制文件保存时间
**************************
select name,value from v$parameter where name='control_file_record_keep_time';
alter system set control_file_record_keep_time=31;
show parameter control_file_record_keep_time
**************************
9.process设置
**************************
show parameter  dispatchers
show parameter processes
alter system set DISPATCHERS = '(protocol=tcp)(dispatchers=3)';
alter system set processes=500 scope=spfile;


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-10103-1-1.html 上篇帖子: Oracle 查看表空间使用率 SQL 脚本 下篇帖子: oracle在线日志文件分析 oracle 数据库

尚未签到

发表于 2013-12-10 18:09:20 | 显示全部楼层
我们以前是那么快乐,现在算什么、

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

尚未签到

发表于 2014-1-6 15:09:25 | 显示全部楼层
-至少涐扪中还有人快乐,这样就已足够了,

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表