如何搭建一个数据库服务器平台_第1页
如何搭建一个数据库服务器平台_第2页
如何搭建一个数据库服务器平台_第3页
如何搭建一个数据库服务器平台_第4页
如何搭建一个数据库服务器平台_第5页
已阅读5页,还剩6页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、Tianlesoftware 学习Oracle 玩Oracle也有2年的时间了,从接触Oracle 到现在,一直没有停止过学习。 要学的东西太多,刚入门的时候是这样的感觉,现在还是这样的感觉。 有时候也在想,还要学多长时间才能感觉自我良好了,有十足的自信心了。 很多朋友都想做DBA, 因为他们觉得这一个高薪的行业。 但是并不是所有都明白为什么DBA是个高薪的行业。 高薪意味着压力大,责任大。现代化的程度越高,对数据库的依赖性越大。 数据安全性和系统的安全性也就越大。比如公司业务系统。 数据库是直接的存储地方的,他的重要性是不言而喻的,宕机带来的损失可能是按分钟或者秒算的。 而谁对这些数据库负责

2、-DBA。 所以很多公司,企业都是找有经验的DBA ,他们也是在为他们的系统买保险。 这也是为什么企业不愿意招一个没有实战经验的DBA来管理自己的数据库。试想某个省移动的数据库出了问题,造成数据丢失,在比如银行数据库挂了。 他们带来的损失不光是影响正常的业务运行,还有可能是数据错误。假如你在银行存了100万,结果银行一不小心,在数据库里少了几个0. 这个是谁也不愿意看到的。 当然以上都是假设的情况。 因为像这些数据重要性极高的单位,他们都有一整套数据的保护机制。 是不会发生这种情况的。 下面就来总结一下如何的来搭建一个数据库平台。 主要从参数和一些特性的配置上来说明。当然我玩Oracle也才2

3、年,经验不足,可能对与这些参数的设置也不是很合理。 从网上看到过一句话:每个DBA心中对重要的参数都有一个标准。 我想这也是经验的价值。1 Linux 系统说明,在安装操作系统之前,现在服务器上做个RAID。一般都用RAID5.1LINUX磁盘划分: a对于内置2块磁盘(146GB)的系统,/目录20GB,SWAP与内存大小相当(8GB以下内存机器SWAP配置8GB),/boot 100MB。如果作为应用服务器,那么其余空间建立/apps文件系统,mke2fs j 命令;如果作为数据库平台,那么建立/dba文件系统20GB,其余建立/u01文件系统。 b对于内置4-6块磁盘的系统,/目录60G

4、B,SWAP与内存大小相当(8GB以下内存机器SWAP配置8GB),/boot 100MB。如果作为应用服务器,那么其余空间建立/apps文件系统,mke2fs j 命令;如果作为数据库平台,那么建立/dba文件系统40GB,其余建立/u01文件系统。 c对于oracle数据文件目录文件系统使用mke2fs j T largefiles命令建立2对于非外接存储情况下:aORACLE目录标准:ORACLE_HOME=/dba/app/oracle/product/10.2.0.4(按版本指定) ORACLE_BASE=/dba (dump目录为/dba/admin/sid/) Datafile目

5、录为/u01/oradata/sid 归档空间目录/u01/oradata/archive_sid b对于有外接存储(/u02)情况下:ORACLE目录标准:ORACLE_HOME=/dba/app/oracle/product/10.2.0.4(按版本指定) ORACLE_BASE=/u01 (dump目录为/u01/admin/sid/) Datafile目录为/u02/oradata/sid 归档空间目录/u01/oradata/archive_sidcORACLE建库采用CUSTOMER方式,直接更改初始UNDO和TEMP空间8GB(或者4GB,或者通过增加文件数目到更大,根据业务系统

6、),system空间512MB(或者1GB)。Redolog为100MB,单个数据文件大小以8GB为宜(因EXT3文件系统特性使然),建议数据文件一次性划分到8G, 以保证数据文件的连续性。3参数及服务配置: 方法一:建立NTP时间同步服务,/etc/ntp.conf中加入server 10.0.30.172,执行# ntpdate 10.0.30.172,# service ntpd start ,# chkconfig -level 235 ntpd on 方法二: 时间同步配置(编辑crontab) 输入命令:ntpdate 10.0.30.172 crontab e(编辑crontab

7、) 按i进入输入状态,输入以下一行: 01 01 * * * root /usr/sbin/ntpdate 10.0.30.172 >/dev/null 2>&1(每天01:01与时间服务器10.0.30.172同步时间) :wq!(保存退出)更多信息参考我的Blog: Linux 时间同步配置4. Linux 内核参数修改 4.1 修改内核参数/etc/sysctl.conf,对于8GB-16GB内存机器 kernel.shmall = 2097152 à 4194304 ( 4KB单位,总内存大小)kernel.shmmax = à858993459

8、2(实际物理内存的2/3)kernel.shmmni = 4096 对于16GB内存以上机器 kernel.shmall = 2097152 à 8388608 ( 4KB单位,总内存大小)kernel.shmmax = à10179869184(比实际物理内存的2/3)kernel.shmmni = 4096 >8192 net.ipv4.ip_local_port_range = 9000 65500 net.core.rmem_default = 262144 net.core.rmem_max = 4194304 net.core.wmem_default =

9、 262144 net.core.wmem_max = 1048586 以前也整理的相关的资料,详见blog: Linux 内核参数及Oracle相关参数调整 4.2根据应用情况修改进程数限制 /etc/security/limits.conf * soft nproc 2047* hard nproc 16384* soft nofile 1024 ->2048* hard nofile 65536注:关于内核参数的修改,在Oracle 官方的安装文档里也有相关说明:在连接中的第 2.7 Configure Oracle Installation Owner Shell Limits

10、节。也有详细介绍。2 Oracle 配置1. 创建pfile 参数Oracle 默认只会创建spfile,但这是个二进制文件,无法进行修改。 为了保险期间。我们要在开始就创建一个pfile 文件,语句很简单,但作用不可忽略。SQL>Create pfile from spfile;Windows 下生成的pfile 文件默认在$ORACLE_HOME/database 下Linux 默认位置在$ORACLE_HOME/dbs 下2. SGA, PGA 设置先来看几个SQLSQL> show parameter sgaNAME TYPE VALUE- - -lock_sga bool

11、ean FALSEpre_page_sga boolean FALSEsga_max_size big integer 584Msga_target big integer 584MSQL> show parameter pgaNAME TYPE VALUE- - -pga_aggregate_target big integer 194MSQL> select name,value ,ISSYS_MODIFIABLE from v$parameter where name like 'sga%'NAME VALUE ISSYS_MOD- - -sga_max_si

12、ze 612368384 FALSEsga_target 612368384 IMMEDIATESQL> select name,value,issys_modifiable from v$parameter where name like 'pga%'NAME VALUE ISSYS_MOD- - -pga_aggregate_target 203423744 IMMEDIATE如果ISSYS_MODIFIABLE 返回的是false,说明该参数无法用alter system语句动态修改,需要重启数据库。所以sga_max_size 是不可以动态调整的。在安装之后我们要

13、对PGA 和 SGA 进行设置。 因为sga_max_size 是非动态的,修改后需要重启,所以我们在开始设置的时候可以把sga_max_size设大一点。 sga_target 是动态的,我们可以根绝需要进行调整。这个调整主要根据命中率来。这里就不多说。当指定SGA_TARGET小于SGA_MAX_SIZE,实例重启后,SGA_MAX_SIZE就自动变为和SGA_TARGET一样的值了。对于OLTP系统,一般的建议是将SGA_MAX_SIZE 设为物理内存的60%,PGA 设为20%。下表是一个参考值:系统内存SGA_MAX_SIZE值1G400-500M2G1G4G2500M8G5G这个参

14、数修改可以在pfile里修改,也可以通过命令直接来:SQL> alter system set pga_aggregate_target=150m scope=spfile;系统已更改。SQL> alter system set sga_target=500m scope=spfile;系统已更改。SQL> alter system set sga_max_size=510m scope=spfile; -要是参数生效,需要重启系统已更改。SQL> alter system set sga_max_size=510m scope=both;alter system se

15、t sga_max_size=510m scope=both *第 1 行出现错误:ORA-02095: 无法修改指定的初始化参数SQL> alter system set sga_target=550m scope=both;系统已更改。SQL> show parameter sgaNAME TYPE VALUE- - -lock_sga boolean FALSEpre_page_sga boolean FALSEsga_max_size big integer 584Msga_target big integer 550M以上都是针对Oracle 10g 版本的。 如果是9i

16、的话,还需要对每个参数进行配置,如Share Pool,DB buffer,Java Pool,redo log buffer等。Oracle 内存详细分析请参考CSDN blog:Oracle 内存 架构 详解3. UNDO, TEMP 表空间设置3.1 UNDOundo 表空间放的是数据的前镜像,当做某个记录多修改时,原记录就会放到undo 中。所以Undo 表空间的大小影响数据的恢复能力。 对它的配置要用点心思。SQL> show parameter undoNAME TYPE VALUE- - -undo_management string AUTOundo_retention

17、integer 900undo_tablespace string UNDOTBS1undo_retention 只是指定undo 数据的过期时间,默认是900s,15分钟。建议改成10800s,即3个小时。SQL> alter system set undo_retention=10800 scope=both;系统已更改。至于undo 表空间的大小,如果磁盘空间允许,就将表空间设为20G,如果空间有限,就设为8G。不过现在的服务器硬盘都是比较大,如果放在存储上,那空间更大,所以20G。相对而言就就是一个很小的空间了。ALTER DATABASE DATAFILE 'D:ORA

18、CLEPRODUCT10.2.0ORADATAORCLUNDOTBS01.DBF' RESIZE 50M;ALTER TABLESPACE UNDOTBS1 ADD DATAFILE 'D:ORACLEPRODUCT10.2.0ORADATAORCLUNDOTBS02.DBF' SIZE 5M AUTOEXTEND ON NEXT 5M MAXSIZE UNLIMITED;大量的DML 操作会产生大量的undo,尤其是update,delete。 当Undo 特别大的时候,我们可以把undo 删了重建。 具体参考我的blog:Oracle undo 回滚段管理3.2 T

19、emp临时表空间主要用途是在数据库进行排序运算、管理索引、访问视图等操作时提供临时的运算空间,当运算完成之后系统会自动清理。当oracle里需要用到sort的时候,PGA中sort_area_size大小不够时,将会把数据放入临时表空间里进行排序,同时如果有异常情况的话,也会被放入临时表空间,正常来说,在完成Select语句、create index等一些使用TEMP表空间的排序操作后,Oracle是会自动释放掉临时段的。但有些有侯我们则会遇到临时段没有被释放,TEMP表空间几乎满的状况,甚至是我们重启了数据库仍没有解决问题。ALTER DATABASE TEMPFILE 'D:ORA

20、CLEPRODUCT10.2.0ORADATAORCLTEMP01.DBF' RESIZE 30M;ALTER TABLESPACE TEMP ADD TEMPFILE 'D:ORACLEPRODUCT10.2.0ORADATAORCLTEMP02.DBF' SIZE 10M AUTOEXTEND ON NEXT 1M MAXSIZE UNLIMITED;和UNDO 一样,可以设为20G 或者8G,具体情况具体对待。如果遇到temp tablespace 满了的话,我们也可以重建其表空间。 具体操作方法,参考blog:Oracle Temp 临时表空间4. 修改sess

21、ions 和 processes 参数 数据库默认的sessions 是170,Processes 是150. 这2个数值肯定是不能满足系统需要的。我们需要把这2个参数调大一点。 方法还是一样,可以直接修改pfile,也可以用SQL. 建议把processes改成1000.sessions 改成2000. 当然具体情况具体对待。SQL> select name,value,issys_modifiable from v$parameter where name='sessions'NAME VALUE ISSYS_MOD- - -sessions 170 FALSESQL

22、> select name,value,issys_modifiable from v$parameter where name='processes'NAME VALUE ISSYS_MOD- - -processes 150 FALSE从上面的结果我们可以知道,修改这2个参数必须重启数据库。 SQL> alter system set sessions=2000 scope=spfile;系统已更改。SQL> alter system set processes=1000 scope=spfile;系统已更改。5. 启动归档模式,并部署定期删除归档文件脚本

23、.生产库必定运行在归档模式下,因为通过归档,我们对数据进行恢复。我们RMAN 备份,Data Guard也需要归档文件。数据库归档非归档的切换比较简单。SQL> alter system set log_archive_dest_1='location=/u01/newccs_archive'SQL> shutdown immediate SQL> startup mount; SQL> alter database archivelog; SQL> alter database open; SQL> archive log list;Dat

24、abase log mode Archive ModeAutomatic archival EnabledArchive destination /u01/newccs_archiveOldest online log sequence 27622Next log sequence to archive 0Current log sequence 27624Oracle 归档与非归档的切换要强调的一点,在切换为归档之前一定要指定归档目录,即log_archive_dest_1。 这个目录用来指定归档文件存放的位置,如果不指定,就会放到闪回区。 闪回区默认只有2G,一但满了之后就会出现问题,如导

25、致数据库hang或者不能启动。 这个也是初学者容易犯的问题。 要是遇到这种问题,处理方法参考我的blog:ORA-16014: log string sequence# string not archived, no available destinations Flash Recovery Area 空间不足删除归档日志的脚本,请参考BLog:6. 开启FlashbackFlashback 技术是以Undo segment中的内容为基础的, 因此受限于UNDO_RETENTON参数。要使用flashback 的特性,必须启用自动撤销管理表空间。在Oracle 10g中, Flash back

26、家族分为以下成员: Flashback Database, Flashback Drop,Flashback Query(分Flashback Query,Flashback Version Query, Flashback Transaction Query 三种) 和Flashback Table。Flashback 是不完全恢复的一种补充,它很灵活。但是Flashback Database默认是关闭的,所以我们要启动它。要注意的是:启动它必须在mount 状态SQL> startup mountSQL> select name, current_scn, flashback_

27、on from v$database;NAME CURRENT_SCN FLASHBACK_ON- - -ORCL 0 NOSQL> alter database flashback on;数据库已更改。SQL> select name, current_scn, flashback_on from v$database;NAME CURRENT_SCN FLASHBACK_ON- - -ORCL 0 YESOracle Flashback 技术 总结7. 检查redo Redo 里记录的是数据库的操作。 在相关事务操作的时候,都会是先写redo,等redo 写完会再去修改相应的数

28、据。 这也Oracle的一种机制。如果出现问题,也可以通过这些记录进行恢复。Redo 默认有3个组,每个组有一个文件,每个文件50M。 不过建议改成100M.出于性能考虑,可以创建2个以上的组,出于安全起见,每组要有多个成员。与控制文件一样,如果每组具有多个成员(事实也应当如此),那么仍然不必担心保持这些成员同步的问题。LGWR能够确保对所有成员进行并行写操作,从而使这些成员完全相同。如果丢失某个组的一个成员,只要还存在其他成员,数据库仍然能够继续运行。Redo 空间的不足还会导致一种警告: checkpoint not complete. 具体参考Blog:Redo Log 和Checkpo

29、int not completeRedoLog Checkpoint 和 SCN关系显示当前归档日志组和成员:SQL> select group#,member from v$logfile;GROUP# MEMBER- - 3 D:ORACLEPRODUCT10.2.0ORADATAORCLREDO03.LOG 2 D:ORACLEPRODUCT10.2.0ORADATAORCLREDO02.LOG 1 D:ORACLEPRODUCT10.2.0ORADATAORCLREDO01.LOG 添加redo log组:SQL> alter database add logfile gr

30、oup 4 ('D:ORACLEPRODUCT10.2.0ORADATAORCLREDO04.LOG') size 10m;SQL> select group#,member from v$logfile; GROUP# MEMBER- - 3 D:ORACLEPRODUCT10.2.0ORADATAORCLREDO03.LOG 2 D:ORACLEPRODUCT10.2.0ORADATAORCLREDO02.LOG 1 D:ORACLEPRODUCT10.2.0ORADATAORCLREDO01.LOG 4 D:ORACLEPRODUCT10.2.0ORADATAORC

31、LREDO04.LOG检查新加入的log状态SQL> select group#,sequence#,bytes,members,status from v$log; GROUP# SEQUENCE# BYTES MEMBERS STATUS- - - - - 1 17 52428800 1 CURRENT 4 0 10485760 1 UNUSED 3 16 52428800 1 INACTIVE 2 15 52428800 1 INACTIVE (虽然这里是UNUSED的状态,但是通过切换日志文件或者数据库自动切换,该文件会被改为active状态) 添加新的文件到group 1 SQ

32、L> alter database add logfile member 'D:ORACLEPRODUCT10.2.0ORADATAORCLREDO05.LOG' to group 1;SQL> select group#,sequence#,bytes,members,status from v$log; GROUP# SEQUENCE# BYTES MEMBERS STATUS- - - - - 1 17 52428800 2 CURRENT 4 0 10485760 1 UNUSED 3 16 52428800 1 INACTIVE 2 15 52428800

33、 1 INACTIVE 这里的group组中的member就变为2;SQL> select member from v$logfile where group#=1;MEMBER-D:ORACLEPRODUCT10.2.0ORADATAORCLREDO01.LOGD:ORACLEPRODUCT10.2.0ORADATAORCLREDO05.LOG删除新增的group 4 SQL> alter database drop logfile group 4;删除新增的group 1的logfile; SQL> alter database drop logfile member &

34、#39;D:ORACLEPRODUCT10.2.0ORADATAORCLREDO05.LOG'清空logfile: SQL> alter database clear logfile 'D:ORACLEPRODUCT10.2.0ORADATAORCLREDO01.LOG' SQL> select group#,sequence#,bytes,members,status from v$log; GROUP# SEQUENCE# BYTES MEMBERS STATUS- - - - - 1 17 52428800 1 ACTIVE 2 18 52428800

35、 1 CURRENT 3 0 52428800 1 UNUSED8. 部署监控系统这里的监控系统包括磁盘空间,alert log日志等。 以前整理的一篇blog里有8个DBA 常用的脚本。 可以参考:8个DBA最常用的监控Oracle数据库的常用shell脚本在补充几个脚本,很简单。8.1 监控磁盘空间并发送到邮箱:Checkdisk.shdf -k >/data/app/scripts/monitor/DiskSpace.log/usr/bin/mailx -s "Whitney(Disk Space)" tianlesoftware < /data/app/

36、scripts/monitor/DiskSpace.log8.2 Windows 下,如果alert 的日志文件日志文件如果太大,查看起来非常麻烦,所以每天进行一次备份,这样只需要查看一天的即可.back_log_file.batrem 复制日志文件并改名,请根据各区SID情况修改脚本set year=%DATE:0,4%set month=%DATE:5,2%set day=%DATE:8,2%copy D:oracleadminwbibdumpalert_wbi.log D:oracleadminwbibdumpalert_wbi"%year%month%day%".l

37、ogrem 清空日志文件rem 下面一句是用来清空alert_wbi.log的cd. >D:oracleadminwbibdumpalert_wbi.log9. 制定备份策略主要指制定RMAN 备份策略Oracle 备份 与 恢复 概述10. 做DG,RAC等高可用性并对相关环境进行监控DG,RAC 的安装请参考我的Blog:Oracle Data Gurad - Logical Standby 相关说明Oracle Data Gurad Physical Standby 相关说明RAC 的一些概念性和原理性的知识RAW+ASM 的RAC 安装文档OCFS2+ASM 的RAC安装文档删除

38、归档日志的脚本,请参考BLog:补充一个脚本:对DG 系统的监控还有一个小脚本。批处理格式的。比较方便:Check.sqlconn sys/PWDSID as sysdbahost title 数据库日常检查column dest_name format a30column destination format a20column MEMBER format a45column 归档地 format a20column TABLESPACE_NAME format a10column FREE_RATE format a10host clsprompt * 实 例 状 态 *;select i

39、nstance_name 实例名,version 版本,status 状态,database_status 数据库状态 from v$instance;prompt * 数据库状态 *;select name,log_mode 归档模式,open_mode 打开模式 from v$database;prompt * 控制文件状态 *;column name format a40select status,name from v$controlfile;prompt * 日志文件状态 *;select GROUP#,status,type,member from v$logfile;prompt

40、* 归档目的地状态 *;select dest_name ,status 状态,database_mode 数据库模式,destination 归档地 from v$archive_dest_status where dest_id in ('1','2');set heading off;select '*数据库已连续运行 '| round(a.atime-b.startup_time)|' 天 '|'*' from(select sysdate atime from dual) a,v$instance b;

41、set heading on;prompt* 会 话 数 *;select sessions_current 当前会话数,sessions_highwater 实例最高值 from v$license;prompt* 表空间监控(FREE_RATE小于10%为异常) *;select a.tablespace_name, round(a.total_size) "total_size(MB)", round(a.total_size)-round(b.free_size,3) "used_size(MB)", round(b.free_size,3) "free_size(MB)", round(b.free_size/total_size*100,2)|'%' free_rate from ( select tablespace_name, sum(bytes)/1024/1024 total_size from dba_data_files group by tablespace_name ) a, ( select tablespace_name, sum(bytes

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论