玩Oracle 2年多了,从接触Oracle 到现在,一直没有停止过学习。 要学的东西太多,刚入门的时候是这样的感觉,现在还是这样的感觉。 有时候也在想,还要学多长时间才能感觉自我良好了,有十足的自信心了。 很多朋友都想做DBA, 因为他们觉得这一个高薪的行业。 但是并不是所有都明白为什么DBA是个高薪的行业。 高薪意味着压力大,责任大。
现代化的程度越高,对数据库的依赖性越大。 数据安全性和系统的安全性也就越大。比如公司业务系统。 数据库是直接的存储地方的,他的重要性是不言而喻的,宕机带来的损失可能是按分钟或者秒算的。 而谁对这些数据库负责--DBA。 所以很多公司,企业都是找有经验的DBA ,他们也是在为他们的系统买保险。 这也是为什么企业不愿意招一个没有实战经验的DBA来管理自己的数据库。
试想某个省移动的数据库出了问题,造成数据丢失,在比如银行数据库挂了。 他们带来的损失不光是影响正常的业务运行,还有可能是数据错误。假如你在银行存了100万,结果银行一不小心,在数据库里少了几个0. 这个是谁也不愿意看到的。 当然以上都是假设的情况。 因为像这些数据重要性极高的单位,他们都有一整套数据的保护机制。 是不会发生这种情况的。
下面就来总结一下如何的来搭建一个数据库平台。 主要从参数和一些特性的配置上来说明。当然我玩Oracle也才2年,经验不足,可能对与这些参数的设置也不是很合理。
从网上看到过一句话:每个DBA心中对重要的参数都有一个标准。 我想这也是经验的价值。
一. Linux 系统
说明,在安装操作系统之前,现在服务器上做个RAID。一般都用RAID5.
1.LINUX磁盘划分:
a.对于内置2块磁盘(146GB)的系统,/目录20GB,SWAP与内存大小相当(8GB以下内存机器SWAP配置8GB),/boot 100MB。如果作为应用服务器,那么其余空间建立/apps文件系统,mke2fs –j 命令;如果作为数据库平台,那么建立/dba文件系统20GB,其余建立/u01文件系统。
b.对于内置4-6块磁盘的系统,/目录60GB,SWAP与内存大小相当(8GB以下内存机器SWAP配置8GB),/boot 100MB。如果作为应用服务器,那么其余空间建立/apps文件系统,mke2fs –j 命令;如果作为数据库平台,那么建立/dba文件系统40GB,其余建立/u01文件系统。
c.对于oracle数据文件目录文件系统使用mke2fs –j –T largefiles命令建立
2.对于非外接存储情况下:
a.ORACLE目录标准:ORACLE_HOME=/dba/app/oracle/product/10.2.0.4(按版本指定)
ORACLE_BASE=/dba (dump目录为/dba/admin/sid/)
Datafile目录为/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_sid
c.ORACLE建库采用CUSTOMER方式,直接更改初始UNDO和TEMP空间8GB(或者4GB,或者通过增加文件数目到更大,根据业务系统),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)
按i进入输入状态,输入以下一行:
01 01 * * * root /usr/sbin/ntpdate 10.0.30.172 >/dev/null 2>&1(每天01:01与时间服务器10.0.30.172同步时间)
:wq!(保存退出)
更多信息参考我的Blog: Linux 时间同步配置
http://blog.csdn.net/tianlesoftware/archive/2010/02/22/5315587.aspx
4. Linux 内核参数修改
4.1 修改内核参数/etc/sysctl.conf,对于8GB-16GB内存机器
kernel.shmall = 2097152 à 4194304 ( 4KB单位,总内存大小)
kernel.shmmax = à8589934592(实际物理内存的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 = 262144
net.core.wmem_max = 1048586
以前也整理的相关的资料,详见blog: Linux 内核参数及Oracle相关参数调整
http://blog.csdn.net/tianlesoftware/archive/2009/10/15/4668741.aspx
4.2.根据应用情况修改进程数限制 /etc/security/limits.conf
* soft nproc 2047
* hard nproc 16384
* soft nofile 1024 ->2048
* hard nofile 65536
注:关于内核参数的修改,在Oracle 官方的安装文档里也有相关说明:
http://download.oracle.com/docs/cd/B28359_01/install.111/b32002/pre_install.htm#BABFDGHJ
在连接中的第 2.7 Configure Oracle Installation Owner Shell Limits 节。也有详细介绍。
二. Oracle 配置
安装实例之前,记得修改db_files , maxdatafiles 和MAXLOGHISTORY 参数。 这2个参数是放在控制文件里的,如果在安装实例的时候没有设置成合适的值,以后调整起来会很麻烦。
具体参考:
Oracle db_files 和 maxdatafiles 说明
http://blog.csdn.net/tianlesoftware/archive/2011/06/07/6530421.aspx
1. 创建pfile 参数
Oracle 默认只会创建spfile,但这是个二进制文件,无法进行修改。 为了保险期间。我们要在开始就创建一个pfile 文件,语句很简单,但作用不可忽略。
SQL>Create pfile from spfile;
Windows 下生成的pfile 文件默认在$ORACLE_HOME/database 下
Linux 默认位置在$ORACLE_HOME/dbs 下
2. SGA, PGA 设置
先来看几个SQL
SQL> show parameter sga
NAME TYPE VALUE
------------------------------------ ----------- -------
lock_sga boolean FALSE
pre_page_sga boolean FALSE
sga_max_size big integer 584M
sga_target big integer 584M
SQL> show parameter pga
NAME TYPE VALUE
------------------------------------ ----------- ------
pga_aggregate_target big integer 194M
SQL> select name,value ,ISSYS_MODIFIABLE from v$parameter where name like 'sga%';
NAME VALUE ISSYS_MOD
--------------- --------------- ---------
sga_max_size 612368384 FALSE
sga_target 612368384 IMMEDIATE
SQL> 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 是不可以动态调整的。
在安装之后我们要对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值
|
1G
|
400-500M
|
2G
|
1G
|
4G
|
2500M
|
8G
|
5G
|
这个参数修改可以在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 set sga_max_size=510m scope=both
*
第 1 行出现错误:
ORA-02095: 无法修改指定的初始化参数
SQL> alter system set sga_target=550m scope=both;
系统已更改。
SQL> show parameter sga
NAME TYPE VALUE
------------------------------------ ----------- --------
lock_sga boolean FALSE
pre_page_sga boolean FALSE
sga_max_size big integer 584M
sga_target big integer 550M
以上都是针对Oracle 10g 版本的。 如果是9i的话,还需要对每个参数进行配置,如Share Pool,DB buffer,Java Pool,redo log buffer等。
Oracle 内存详细分析请参考CSDN blog:Oracle 内存 架构 详解
http://blog.csdn.net/tianlesoftware/archive/2010/05/16/5594080.aspx
3. UNDO, TEMP 表空间设置
3.1 UNDO
undo 表空间放的是数据的前镜像,当做某个记录多修改时,原记录就会放到undo 中。所以Undo 表空间的大小影响数据的恢复能力。 对它的配置要用点心思。
SQL> show parameter undo
NAME TYPE VALUE
------------------------------------ ----------- -----------
undo_management string AUTO
undo_retention integer 900
undo_tablespace string UNDOTBS1
undo_retention 只是指定undo 数据的过期时间,默认是900s,15分钟。建议改成10800s,即3个小时。
SQL> alter system set undo_retention=10800 scope=both;
系统已更改。
至于undo 表空间的大小,如果磁盘空间允许,就将表空间设为32G,分成4个数据文件,单个数据文件8G。 如果空间有限,就设为8G或者16G(8*2)。
不过现在的服务器硬盘都是比较大,如果放在存储上,那空间更大,所以32G。相对而言就就是一个很小的空间了。
ALTER DATABASE DATAFILE 'D:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\UNDOTBS01.DBF' RESIZE 50M;
ALTER TABLESPACE UNDOTBS1 ADD DATAFILE 'D:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\UNDOTBS02.DBF' SIZE 5M AUTOEXTEND ON NEXT 5M MAXSIZE UNLIMITED;
大量的DML 操作会产生大量的undo,尤其是update,delete。 当Undo 特别大的时候,我们可以把undo 删了重建。
具体参考我的blog:Oracle undo 回滚段管理
http://blog.csdn.net/tianlesoftware/archive/2009/11/30/4901666.aspx
3.2 Temp
临时表空间主要用途是在数据库进行排序运算、管理索引、访问视图等操作时提供临时的运算空间,当运算完成之后系统会自动清理。当oracle里需要用到sort的时候,PGA中sort_area_size大小不够时,将会把数据放入临时表空间里进行排序,同时如果有异常情况的话,也会被放入临时表空间,正常来说,在完成Select语句、create index等一些使用TEMP表空间的排序操作后,Oracle是会自动释放掉临时段的。但有些有侯我们则会遇到临时段没有被释放,TEMP表空间几乎满的状况,甚至是我们重启了数据库仍没有解决问题。
ALTER DATABASE TEMPFILE 'D:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\TEMP01.DBF' RESIZE 30M;
ALTER TABLESPACE TEMP ADD TEMPFILE 'D:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\TEMP02.DBF' SIZE 10M AUTOEXTEND ON NEXT 1M MAXSIZE UNLIMITED;
和UNDO 一样,可以设为32G (4*8G)或者16G(2*8G),具体情况具体对待。如果遇到temp tablespace 满了的话,我们也可以重建其表空间。 具体操作方法,参考blog:Oracle Temp 临时表空间
http://blog.csdn.net/tianlesoftware/archive/2009/10/20/4697417.aspx
4. 修改sessions 和 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 FAL
分享到:
相关推荐
linux下搭建web服务器及数据库服务器
为了建立具有动态的 Web 应用程序,必须建立一个 Web 服务器,选择一门 Web 应用程序的开发语言,为了应用的深入还需要选择一款数据库管理软件。同时因为是在 Dreamweaver 中开发的,还需要建立一个 Dreamweaver 的...
通过以上知识点的学习和实践,我们可以成功搭建一个服务器数据库框架,并为其他项目提供稳定的底层支持。在实际操作中,应结合具体的项目需求和技术栈,灵活运用这些知识。在"serverText"文件中,可能包含了关于这个...
云服务器上的数据库通常采用云数据库服务,这是因为多个服务器无法直接共享一个数据库,这样可以确保数据的安全性和独立性。云数据库提供高可用性和可扩展性,当需要备份、迁移或扩大存储容量时,可以轻松实现。用户...
Debian系统平台下搭建Mysql数据库服务器(简单安装)
用Servlet搭建的简单服务器,有两个数据库实例,进行数据库连接
MySQL数据库服务器的搭建和配置的知识点,涵盖了MySQL的基本概念、特点、安装、配置和使用等方面的知识点,并且讨论了动态网站和数据库服务器的关系,为读者提供了一个全面的 MySQL数据库服务器搭建指南。
搭建Linux数据库服务器.pdf
本文档主要讲述的是搭建Oracle数据库服务器;希望对读者会有帮助;感兴趣的朋友可以过来看看
- **安装必要的软件和服务**: 如Web服务器(Apache/Nginx)、数据库服务器(MySQL/MariaDB)等。 - **配置安全策略**: 包括防火墙设置、SSL证书安装等。 - **部署应用**: 将开发好的Android应用后端服务部署到服务器上。...
Linux是个一个性能优异,安全的操作系统,互联网超多的web应用都是基于Linux作为服务器,所以系统的学习一下Linux操作系统是非常有必要的。 1.JAVA开发环境的安装与配置(JDK安装,环境变量的配置) 2.Tomcat服务器...
总的来说,搭建Linux环境下的Web服务器及数据库服务器是一个涉及多步骤的过程,包括操作系统安装、网络配置、软件安装、环境变量配置以及服务管理等。熟悉这些步骤有助于构建稳定、安全的服务器环境,为后续的Web...
【MySQL数据库服务器搭建详解】 MySQL是一种广泛使用的开源关系型数据库管理系统,特别适合于Web应用程序。在Linux环境下,尤其是Fedora 14系统中,搭建MySQL数据库服务器涉及几个关键步骤。 首先,确认系统是否已...
"ios mdm 设备管理服务器搭建"这个主题涉及了如何构建一个用于管理iOS设备的MDM服务器,以确保企业数据的安全并优化设备的使用效率。 MDM解决方案允许IT管理员远程控制和管理组织内的各种移动设备,包括配置设置、...
这个数据库系统可能是一个基础服务,用于支持某种在线应用或游戏,因为提到了“搭建老飞飞服务器基础服务器sql2008数据库”,暗示了它依赖于SQL Server 2008作为其后端数据存储平台。 描述中的关键信息是这个数据库...