数据库服务器_服务器数据库 - CSDN
  • 原 如何搭建一个数据库服务器平台https://blog.csdn.net/tianlesoftware/article/details/5602291版权声明: https://blog.csdn.net/tianlesoftware/article/details/5602291 玩Oracle 2年多了,从接触Oracle 到现在...

    原 如何搭建一个数据库服务器平台https://blog.csdn.net/tianlesoftware/article/details/5602291版权声明: https://blog.csdn.net/tianlesoftware/article/details/5602291
     玩Oracle 2年多了,从接触Oracle 到现在,一直没有停止过学习。 要学的东西太多,刚入门的时候是这样的感觉,现在还是这样的感觉。 有时候也在想,还要学多长时间才能感觉自我良好了,有十足的自信心了。 很多朋友都想做DBA, 因为他们觉得这一个高薪的行业。 但是并不是所有都明白为什么DBA是个高薪的行业。 高薪意味着压力大,责任大。
     现代化的程度越高,对数据库的依赖性越大。 数据安全性和系统的安全性也就越大。比如公司业务系统。 数据库是直接的存储地方的,他的重要性是不言而喻的,宕机带来的损失可能是按分钟或者秒算的。 而谁对这些数据库负责--DBA。 所以很多公司,企业都是找有经验的DBA ,他们也是在为他们的系统买保险。 这也是为什么企业不愿意招一个没有实战经验的DBA来管理自己的数据库。
     试想某个省移动的数据库出了问题,造成数据丢失,在比如银行数据库挂了。 他们带来的损失不光是影响正常的业务运行,还有可能是数据错误。假如你在银行存了100万,结果银行一不小心,在数据库里少了几个0. 这个是谁也不愿意看到的。 当然以上都是假设的情况。 因为像这些数据重要性极高的单位,他们都有一整套数据的保护机制。 是不会发生这种情况的。
     下面就来总结一下如何的来搭建一个数据库平台。 主要从参数和一些特性的配置上来说明。当然我玩Oracle也才2年,经验不足,可能对与这些参数的设置也不是很合理。
     从网上看到过一句话:每个DBA心中对重要的参数都有一个标准。 我想这也是经验的价值。
       一. Linux 系统
     说明,在安装操作系统之前,现在服务器上做个RAID。一般都用RAID5.
     1.LINUX磁盘划分:
    .对于内置2块磁盘(146GB)的系统,/目录20GB,SWAP与内存大小相当(8GB以下内存机器SWAP配置8GB),/boot 100MB。如果作为应用服务器,那么其余空间建立/apps文件系统,mke2fs –j 命令;如果作为数据库平台,那么建立/dba文件系统20GB,其余建立/u01文件系统。
    .对于内置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
     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        FALSE
    SQL> 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;
    系统已更改。

    Oracle sessions,processes 和 transactions 参数 关系 说明
    http://blog.csdn.net/tianlesoftware/article/details/6893561

    5. 修改session_cached_cursors 和 open_cursors 参数
     设置open_cursors=1000
    设置session_cached_cursors= 100.  这个参数是静态参数,修改需要重启数据库。

    SQL> Alter system set open_cursors=1000scope=both sid='*';
    System altered.
     SQL> Alter system setsession_cached_cursors=100 scope=spfile sid='*';
     System altered.

    5. 启动归档模式,并部署定期删除归档文件脚本.
    生产库必定运行在归档模式下,因为通过归档,我们对数据进行恢复。我们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;
    Database log mode              Archive Mode
    Automatic archival             Enabled
    Archive destination            /u01/newccs_archive
    Oldest online log sequence     27622
    Next log sequence to archive   0
    Current log sequence           27624
     Oracle 归档与非归档的切换
    http://blog.csdn.net/tianlesoftware/archive/2009/10/19/4693470.aspx
     要强调的一点,在切换为归档之前一定要指定归档目录,即log_archive_dest_1。 这个目录用来指定归档文件存放的位置,如果不指定,就会放到闪回区。 闪回区默认只有2G,一但满了之后就会出现问题,如导致数据库hang或者不能启动。 这个也是初学者容易犯的问题。 要是遇到这种问题,处理方法参考我的blog:
     ORA-16014: log string sequence# string not archived, no available destinations Flash Recovery Area 空间不足
    http://blog.csdn.net/tianlesoftware/archive/2010/04/29/5537550.aspx
     删除归档日志的脚本,请参考BLog:
    http://blog.csdn.net/tianlesoftware/archive/2010/01/20/5211659.aspx
     6. 开启Flashback
    Flashback 技术是以Undo segment中的内容为基础的, 因此受限于UNDO_RETENTON参数。要使用flashback 的特性,必须启用自动撤销管理表空间。
    在Oracle 10g中, Flash back家族分为以下成员: Flashback Database, Flashback Drop,Flashback Query(分Flashback Query,Flashback Version Query, Flashback Transaction Query 三种) 和Flashback Table。
    Flashback 是不完全恢复的一种补充,它很灵活。但是Flashback Database默认是关闭的,所以我们要启动它。
     要注意的是:启动它必须在mount 状态
    SQL> startup mount
    SQL> select name, current_scn, flashback_on from v$database;
    NAME      CURRENT_SCN FLASHBACK_ON
    --------- ----------- ------------------
    ORCL                0 NO
    SQL> alter database flashback on;
    数据库已更改。
    SQL> select name, current_scn, flashback_on from v$database;
    NAME      CURRENT_SCN FLASHBACK_ON
    --------- ----------- ------------------
    ORCL                0 YES
      Oracle Flashback 技术 总结
    http://blog.csdn.net/tianlesoftware/archive/2009/10/16/4677378.aspx
     7. 检查redo
    Redo 里记录的是数据库的操作。 在相关事务操作的时候,都会是先写redo,等redo 写完会再去修改相应的数据。 这也Oracle的一种机制。如果出现问题,也可以通过这些记录进行恢复。
    Redo 默认有3个组,每个组有一个文件,每个文件50M。
            将redo log 的文件大小改成100M一个。 每组创建2个成员。 最好将每组的2个成员放在不同的磁盘上。 因为写redo 的时候是并行的,放在一起,可能会出现等待事件:Log file parallel write。
           关于等待事件,参考:
                  Oracle 常见的33个等待事件
                  http://blog.csdn.net/tianlesoftware/archive/2010/08/12/5807800.aspx
     与控制文件一样,如果每组具有多个成员(事实也应当如此),那么仍然不必担心保持这些成员同步的问题。LGWR能够确保对所有成员进行并行写操作,从而使这些成员完全相同。如果丢失某个组的一个成员,只要还存在其他成员,数据库仍然能够继续运行。
     Redo 空间的不足还会导致一种警告: checkpoint not complete. 具体参考Blog:
     Redo Log 和Checkpoint not complete
    http://blog.csdn.net/tianlesoftware/archive/2009/12/01/4908066.aspx
     RedoLog Checkpoint 和 SCN关系
    http://blog.csdn.net/tianlesoftware/archive/2010/01/25/5251916.aspx
       显示当前归档日志组和成员:
    SQL> select group#,member from v$logfile;
    GROUP# MEMBER
    ---------- ---------------------------------------------------
      3               D:/ORACLE/PRODUCT/10.2.0/ORADATA/ORCL/REDO03.LOG
      2               D:/ORACLE/PRODUCT/10.2.0/ORADATA/ORCL/REDO02.LOG
      1               D:/ORACLE/PRODUCT/10.2.0/ORADATA/ORCL/REDO01.LOG
      
    添加redo log组:
    SQL> alter database add logfile group 4 ('D:/ORACLE/PRODUCT/10.2.0/ORADATA/ORCL/REDO04.LOG') size 10m;
    SQL> select group#,member from v$logfile;
        GROUP# MEMBER
    ---------- ----------------------------------------------------
             3 D:/ORACLE/PRODUCT/10.2.0/ORADATA/ORCL/REDO03.LOG
             2 D:/ORACLE/PRODUCT/10.2.0/ORADATA/ORCL/REDO02.LOG
             1 D:/ORACLE/PRODUCT/10.2.0/ORADATA/ORCL/REDO01.LOG
             4 D:/ORACLE/PRODUCT/10.2.0/ORADATA/ORCL/REDO04.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
        SQL> alter database add logfile member 'D:/ORACLE/PRODUCT/10.2.0/ORADATA/ORCL/REDO05.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          1 INACTIVE
        这里的group组中的member就变为2;

           SQL> select member from v$logfile where group#=1;
    MEMBER
    -------------------------------------------------------
    D:/ORACLE/PRODUCT/10.2.0/ORADATA/ORCL/REDO01.LOG
    D:/ORACLE/PRODUCT/10.2.0/ORADATA/ORCL/REDO05.LOG

    删除新增的group 4
        SQL> alter database drop logfile group 4;

    删除新增的group 1的logfile;
        SQL> alter database drop logfile member 'D:/ORACLE/PRODUCT/10.2.0/ORADATA/ORCL/REDO05.LOG';

    清空logfile:
        SQL> alter database clear logfile 'D:/ORACLE/PRODUCT/10.2.0/ORADATA/ORCL/REDO01.LOG';
      
           SQL> select group#,sequence#,bytes,members,status from v$log;
        GROUP#  SEQUENCE#      BYTES    MEMBERS STATUS
    ---------- ---------- ---------- ---------- ----------------
             1         17   52428800          1 ACTIVE
             2         18   52428800          1 CURRENT
             3          0   52428800          1 UNUSED

    8. 设置CONTROL_FILE_RECORD_KEEP_TIME 参数
           该参数设置控制文件中存储备份记录的时间,在用RMAN的时候会涉及到这个参数。 备份记录包括完全的数据库备份记录,以及指定的数据文件,控制文件,参数文件和归档目录的备份记录。数据库参数CONTROL_FILE_RECORD_KEEP_TIME以天为单位(默认值为7天),因此在默认情况下,Oracle 会将RMAN备份和恢复记录保存7天。 可以将该参数设置为0到365之间的任意值。
           CONTROL_FILE_RECORD_KEEP_TIME参数会影响一系列的数据库操作。 首先,产生RMAN备份时,由于与这些备份相关的记录存储在控制文件中,所以该参数直接影响数据库控制文件的大小。 备份记录将不断的保存在控制文件中,控制文件将耗尽空间。 这时,Oracle 会扩展控制文件来调整备份记录所需的存储空间。 此外,设置为0时,将禁止扩展控制文件,并且会使得RMAN备份的保存周期不稳定。
           建议将CONTROL_FILE_RECORD_KEEP_TIME 参数设置为不小于选中数据库的备份保存周期,否则就可能在备份介质上有数据库备份,但是控制文件不存在与备份相关的备份记录,在这种情况下,将无法恢复这些较早的文件。这个参数根据自己的本份策略来决定。
           SQL> select name,value from v$parameter where name='control_file_record_keep_time';
    NAME                           VALUE
    ------------------------------ -------------------------------------------------
    control_file_record_keep_time   7
    SQL> alter system set control_file_record_keep_time=20;
    系统已更改。
    SQL> show parameter control_file_record_keep_time
    NAME                                 TYPE        VALUE
    ------------------------------------ ----------- ------------------------------
    control_file_record_keep_time        integer     20
    SQL>
     关于RMAN与control_file_record_keep_time的内容参考:
           RMAN 系列(二) ---- RMAN 设置和配置
           http://blog.csdn.net/tianlesoftware/archive/2010/06/16/5674309.aspx
     9. 设置open_links_per_instance 和 open_links 参数
           关于这2个参数的说明,参考Blog:
           open_links_per_instance 和 open_links 参数说明
           http://blog.csdn.net/tianlesoftware/archive/2010/12/22/6090729.aspx
                  这2个参数修改之后,需要重启才能生效,所以,在安装DB的时候,就把这个参数修改了。 默认值是4,如果用到话就太小了。 所以在安装的时候,就给修改了。 修改建议值:100。
            SQL> alter system set open_links=100 scope=spfile;
           系统已更改。
    10.修改用户的profile 参数
    SQL> alter profile DEFAULT limit FAILED_LOGIN_ATTEMPTS UNLIMITED;

    Profile altered.


     11. 部署statistic Job
           Oracle 10g statistic数据统计,Oracle会根据这些统计信息来决定是走RBO(Rule-BasedOptimization),还是走CBO(Cost-BasedOptimization),会去选择哪种执行计划更划算,影响是否走相关的索引等.如果是CBO的话,它依靠准确的(或者说比较准确的)统计信息来产生优化的执行路径,如果没有做过统计,CBO也就没有做cost评估的依据,所以虽然是CBO,但是实际上还是用RBO了,而且如果不常做统计的话,由于CBO是以统计为依据的,所以这时CBO的依据信息有问题,CBO也会不准。 所以 DBA 需要确保定期收集统计信息,创建另一个执行核对清单。
           更多内容,参考:
                  Oracle 10g Statistic数据统计
                  http://blog.csdn.net/tianlesoftware/archive/2009/10/15/4668723.aspx
     11.1 创建存储过程:
    CREATE OR REPLACE PROCEDURE USER."ANALYZEDB"
    IS
       CURSOR get_ownertable
       IS
          SELECT table_name
            FROM user_tables;
       ownertable   get_ownertable%ROWTYPE;
    BEGIN
       OPEN get_ownertable;
       LOOP
          FETCH get_ownertable
           INTO ownertable;
          EXIT WHEN get_ownertable%NOTFOUND;
          EXECUTE IMMEDIATE    'analyze table '
                            || ownertable.table_name
                            || ' compute statistics for table for all indexes for all indexed columns ';
       END LOOP;
    EXCEPTION
       WHEN OTHERS
       THEN
          RAISE;
    END;
     11.2. 将存储过程写进JOB
    DECLARE
      X NUMBER;
    BEGIN
      SYS.DBMS_JOB.SUBMIT
      ( job       => X
       ,what      => 'ANALYZEDB;'
       ,next_date => to_date('14-10-2009 06:00:00','dd/mm/yyyy hh24:mi:ss')
       ,interval  => 'trunc(sysdate + 7) + 6/24'
       ,no_parse  => FALSE
      );
      SYS.DBMS_OUTPUT.PUT_LINE('Job Number is: ' || to_char(x));
    COMMIT;
    END;
            具体多长时间执行一次,根据自己的业务来决定, 这个Job 对DB的影响是比较大的,找个业务不忙的时候来执行。
     12. 注意对索引的维护
                  这块具体参考Blog:
                  Oracle 索引的维护
                  http://blog.csdn.net/tianlesoftware/archive/2010/06/19/5680706.aspx
      13. 部署监控系统
    这里的监控系统包括磁盘空间,alert log日志等。 以前整理的一篇blog里有8个DBA 常用的脚本。 可以参考:
     8个DBA最常用的监控Oracle数据库的常用shell脚本
    http://blog.csdn.net/tianlesoftware/archive/2009/11/11/4792798.aspx
     在补充几个脚本,很简单。
     13.1 监控磁盘空间并发送到邮箱:
     Checkdisk.sh
    df -k >/data/app/scripts/monitor/DiskSpace.log
    /usr/bin/mailx -s "Whitney(Disk Space)" tianlesoftware@vip.qq.com < /data/app/scripts/monitor/DiskSpace.log
     13.2 Windows 下,如果alert 的日志文件日志文件如果太大,查看起来非常麻烦,所以每天进行一次备份,这样只需要查看一天的即可.
    back_log_file.bat
    rem 复制日志文件并改名,请根据各区SID情况修改脚本
    set year=%DATE:~0,4%
    set month=%DATE:~5,2%
    set day=%DATE:~8,2%
    copy D:/oracle/admin/wbi/bdump/alert_wbi.log D:/oracle/admin/wbi/bdump/alert_wbi"%year%%month%%day%".log
    rem 清空日志文件
    rem 下面一句是用来清空alert_wbi.log的
    cd. >D:/oracle/admin/wbi/bdump/alert_wbi.log
      14. 制定备份策略
    主要指制定RMAN 备份策略。 RMAN 备份的东西,细讲起来也很多。 具体参考:
                  如何 搭建 RMAN 备份平台
                  http://blog.csdn.net/tianlesoftware/archive/2010/07/16/5740896.aspx
      14. 做DG,RAC等高可用性并对相关环境进行监控
            这块的东西暂时还没有整理全,等以后整理全了在补充。
     DG,RAC 的安装请参考我的Blog:
    Oracle Data Gurad -- Logical Standby 相关说明
    http://blog.csdn.net/tianlesoftware/archive/2010/05/07/5564208.aspx
     Oracle Data Gurad Physical Standby 相关说明
    http://blog.csdn.net/tianlesoftware/archive/2010/05/05/5557410.aspx
     RAC 的一些概念性和原理性的知识
    http://blog.csdn.net/tianlesoftware/archive/2010/02/28/5331067.aspx
     RAW+ASM 的RAC 安装文档
    http://blog.csdn.net/tianlesoftware/archive/2010/02/28/5332909.aspx
     OCFS2+ASM 的RAC安装文档
    http://blog.csdn.net/tianlesoftware/archive/2010/02/28/5331074.aspx
     删除归档日志的脚本,请参考BLog:
    http://blog.csdn.net/tianlesoftware/archive/2010/01/20/5211659.aspx
     补充一个脚本:
    对DG 系统的监控还有一个小脚本。批处理格式的。比较方便:
     Check.sql
    conn sys/PWD@SID as sysdba
    host title 数据库日常检查
    column dest_name format a30
    column destination format a20
    column MEMBER format a45
    column 归档地 format a20
    column TABLESPACE_NAME format a10
    column FREE_RATE format a10
    host cls
    prompt **************************** 实 例 状 态 ************************************;
    select instance_name 实例名,version 版本,status 状态,database_status 数据库状态 from v$instance;
    prompt **************************** 数据库状态 *************************************;
    select name,log_mode 归档模式,open_mode 打开模式 from v$database;
    prompt **************************** 控制文件状态 ***********************************;
    column name format a40
    select status,name from v$controlfile;
    prompt **************************** 日志文件状态 ***********************************;
    select GROUP#,status,type,member from v$logfile;
    prompt***************************** 归档目的地状态 *********************************;
    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;
    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)/1024/1024 free_size
             from dba_free_space
             group by tablespace_name ) b
           where a.tablespace_name = b.tablespace_name(+);
     prompt **************************** 表空间OFFLINE(显示为空正常) ********************;
    select tablespace_name 表空间名,status 状态 from dba_tablespaces where status='OFFLINE';
    prompt **************************** SEQUENCE同步数 *********************************;
    select max(sequence#)from v$log_history;
     CONN sys/PWD@SID_ST as sysdba;
    prompt **************************** 备库SEQUENCE同步数 *****************************;
    select max(sequence#)from v$log_history;
    prompt **************************** 备库日志未应用(显示为空正常) *******************;
    select sequence#,applied from v$archived_log where applied='NO' and sequence#>2453;
    prompt **************************** 备库日志应用(显示最近十个日志) *****************;
    select * from(select sequence#,applied from v$archived_log order by sequence# desc) where rownum<=10;
    set time on
    disconnect
     Check.bat
    sqlplus /nolog @check.sql
      8. 定期的做AWR,statspack 分析
    Oracle AWR 介绍
    http://blog.csdn.net/tianlesoftware/archive/2009/10/17/4682300.aspx
     statspack安装使用 和 report 分析
    http://blog.csdn.net/tianlesoftware/archive/2009/10/17/4682329.aspx
      小结:
           作为一个DBA,我们要考虑的是如何保证系统7*24的正常运行,如何保证系统高效的运行,还有就是保证数据的安全性。 所有的监控都是辅助的,关键还得靠DBA,需要DBA的经验来处理各种异常情况。就像电视剧《士兵突击》里老A 袁朗 讲的一句话:战争的最后, 还是人与人之间的较量,同样对数据库的维护最终还是要靠DBA,用存储也罢,高性能的服务器也罢,使用更健壮的监控的系统也罢。但这些都是机器,谁也不能保证这些硬件或者软件100% 不出问题,这些只是我们的工具,就像士兵使用的抢一样,保养的好,就好使,但也不能保证它不出问题。 指不定哪天就出先故障或者出现bug。所以经验对一个DBA来说,是一笔财富。
     最后强调一点,要养成做备份的习惯,慎用RM 命令。 只要有备份, 就还有挽回的余地。 不经想起去年帮一个朋友恢复过的一个数据库。 当时的情况是: 数据库除了半年前的一次冷备外,没有其他的备份,也没有归档。然后有一天出了问题,朋友折腾了半天,实在搞不定。 拿到这样的库,我也没办法,最后用了最近一次的冷备还原了下。 数据丢失了半年。教训也是深刻的。
     这也是中国很多小公司或者企业的现状,不注重数据库的维护,只要能运行就可以了。对与这种情况,我也只能说祈求老天,不让数据库库出问题,因为出问题就是灾难。
     我也是刚踏上DBA的路,希望能在这条路上能走的更远,借用网友的吉言:成为明日之eygle(Oracle ACE,OCM).
          ------------------------------------------------------------------------------
    Blog: http://blog.csdn.net/tianlesoftware
    网上资源: http://tianlesoftware.download.csdn.net
    相关视频:http://blog.csdn.net/tianlesoftware/archive/2009/11/27/4886500.aspx
    DBA1 群:62697716(满); DBA2 群:62697977(满)
    DBA3 群:62697850   DBA 超级群:63306533;    
    聊天 群:40132017
    --加群需要在备注说明Oracle表空间和数据文件的关系,否则拒绝申请
     具体参考:
    Oracle 用户 profile 属性
    http://blog.csdn.net/tianlesoftware/archive/2011/03/10/6238279.aspxhttps://img-blog.csdnimg.cn/20190217105710569.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3UwMTEwNzgxNDE=,size_16,color_FFFFFF,t_70《算法导论 第三版英文版》_高清中文版.pdf
    https://pan.baidu.com/s/17D1kXU6dLdU0YwHM2cvNMw
    《深度学习入门:基于Python的理论与实现》_高清中文版.pdf
    https://pan.baidu.com/s/1IeVs35f3gX5r6eAdiRQw4A
    《深入浅出数据分析》_高清中文版.pdf
    https://pan.baidu.com/s/1GV-QNbtmjZqumDkk8s7z5w
    《Python编程:从入门到实践》_高清中文版.pdf
    https://pan.baidu.com/s/1GUNSg4mdpeOf1LC_MjXunQ
    《Python科学计算》_高清中文版.pdf
    https://pan.baidu.com/s/1-hDKhK-7rDDFll_UFpKmpw

    展开全文
  • 数据库服务器

    2019-01-06 00:18:09
    mysql数据库服务器:就是安装了mysql数据库管理软件 mysql数据库:数据库管理软件 服务器:就是一台电脑,这台安装相关的服务器软件,这些软件会监听不同的端口号, 根据用户访问的端口号,提供不同的服务。 ...

    关系型数据库:

    主要用来描述实体与实体之间的关系。

    实实在在存在的实物:学生与班级,员工与部门

    E-R关系图:

    实体:方框

    属性:椭圆

    关系:菱形

    mysql数据库服务器:就是安装了mysql数据库管理软件

    mysql数据库:数据库管理软件

    服务器:就是一台电脑,这台安装相关的服务器软件,这些软件会监听不同的端口号,

    根据用户访问的端口号,提供不同的服务。

    通常一个应用对应一个数据库。

    mysql的sql语句

    SQL:结构化查询语句

    DDL:数据定义语言:定义数据库,数据表他们的结构:create,drop,alter

    DML:数据操纵语言:主要用来操作数据,inert,update,delete

    DCL:数据控制语言:定义访问权限,取消访问权限,安全设置 grant

    DQL:数据查询语言:select from where

    数据库的CRUD的操作

    首先要登录数据库服务器:mysql -uroot -p123

    创建数据库

    修改数据库的操作:

     

    删除数据库

    drop  database 数据库名称

    切换数据库

    use 数据库名称

    查看当前正在使用的数据库

    select database();

    展开全文
  • 服务端的作用是保存、处理、分发数据,客户端的作用是请求数据并显示出来 ...数据库是通过服务端访问的,访问后处理并包装为JSON,通过socket发送给客户端。客户端收到后解释这个JSON,从中提前所需的数据并显示。...

    服务端的作用是保存、处理、分发数据,客户端的作用是请求数据并显示出来

    数据库是通过服务端访问的,访问后处理并包装为JSON,通过socket发送给客户端。客户端收到后解释这个JSON,从中提前所需的数据并显示。

    展开全文
  • 1.打开phpstudy,点击“其他选项菜单”,点击...   ...   3.登录phpMyAdmin,找到job数据库,如图:   4.点击job数据库,进入job数据库后点击“导出”,如图:   5.选择SQL格式,点击执行,如图: ...

    1.打开phpstudy,点击“其他选项菜单”,点击phpMyAdmin

     

    2.打开phpstorm,点击tiku,点击application,选择database.php文件,查看数据库名,如图:

     

    3.登录phpMyAdmin,找到job数据库,如图:

     

    4.点击job数据库,进入job数据库后点击“导出”,如图:

     

    5.选择SQL格式,点击执行,如图:

     

    6.点击下载,选择下载位置,把下载好的文件 复制到服务器上,如图:

     

    7.在服务器上找到phpStudy,点击‘’其他选项菜单‘’,点击phpMyAdmin,选择‘’中文简体‘’,如图:

     

     

    8.在服务器phpMyAdmin里面,点击‘’导入‘’,如图:

     

    9.在服务器phpMyAdmin里面,选择‘’浏览‘’,选择job.sql文件,点击‘’打开‘’,如图:

     

    10.在服务器phpMyAdmin里面,点击''执行'',如图:

     

    11.在服务器phpMyAdmin里面,出现没找到数据库,如图:

     

    12.在服务器phpMyAdmin里面,新建一个叫job数据库,选择utf8_gengral_ci点击‘’创建‘’,如图:

    13.在服务器phpMyAdmin里面,创建数据库job成功,如图:

     

    14.在服务器phpMyAdmin里面,点击job数据库,选择‘’导入‘’,如图:

     

    15..在服务器phpMyAdmin里面,选择job数据库,点击‘’浏览‘’,选择job.sql文件,点击‘’打开‘’,如图:

     

    16.在服务器phpMyAdmin里面,点击“执行”,如图:

     

    17.在服务器phpMyAdmin里面,job数据库里面,出现了导入的表单名字,导入成功,如图:

     

    18.在服务器phpMyAdmin里面,job数据库里面,显示了导入数据,如图:

     

     

     

     

     

    展开全文
  • 数据库服务器一般都装有数据库如oracle,mssql,mysql等,如:oracle的linux服务器, 应用服务器是你的应用得服务器,提供应用服务,如你的j2ee中间件:基于jboss,weblogic等的应用,也可以是自己的网络应用服务器...
  • 运行在局域网中的一台或多台计算机和数据库管理系统软件共同构成了数据库服务器数据库服务器为客户应用提供服务,这些服务是查询、更新、事务管理、索引、高速缓存、查询优化、安全及多用户存...
  • 服务器就像筷子 ,数据库就像是一盘菜 程序就像人,人们用筷子夹盘子里的菜来吃。 一般来说图片保存在服务器上 确切说应该是保存在服务器主机上,服务器可以保存东西 那要数据库来做什么?数据库是用来保存数据让...
  • Cloudscape 是一个以 Java 类库形式提供的、轻量级的、可嵌入的关系引擎。它的本机接口是带有 Java 关系扩展的 Java Database Connectivity(JDBC)。它实现了 SQL92E 标准和许多 SQL 99 扩展。...
  • 数据库服务器是当今应用最为广泛的一种服务器类型,许多企业在信息化建设过程中都要购置数据库服务器数据库服务器主要用于存储、查询、检索企业内部的信息,因此需要搭配专用的数据库系统,对服务器的兼容性、可靠...
  •   指一台服务器充当主数据库服务器,另一台或多台服务器充当从数据库服务器,主服务器中的数据自动复制到从服务器之中。对于多级复制,数据库服务器即可充当主机,也可充当从机。MySQL主从复制的基础是主服务器对...
  • sql server 远程连接服务器时,常用的服务器信息:服务器名称信息,登录名,密码等信息。...右键-》新建服务器组,输入组名称进行管理。 3、新建服务器注册,对数据库登录信息进行管理。录入相应的登录信息,
  • 请简述什么是数据模型。 答:数据模型是数据库系统的核心和基础,它是对现实世界数据特征的抽象,用来描述数据,可以理解成一种数据结构。在数据库的发展过程中,出现了3种...答:一个数据库服务器可以管理多个数...
  • Q:在使用过程中出现了这样的错误提示“DedeCMS Error Track:DedeCMS错误警告:连接数据库失败,可能数据库密码不对或数据库服务器出错!”,请问这是什么问题? A:这是因为DedeCMS没有正确的和数据库服务器连接,...
  • 随着服务器硬件的功能变得越来越强大,而价格一路急剧下跌,许多公司(尤其是小公司)发现如今购买数据库服务器面临众多选择。这意味着,经验相对欠缺的数据库管理员们也被要求设计功能越来越强大的系统。你在为大型...
  • web服务器 和数据库服务器都会造成很大的压力,对于web服务器我们可以很容易进行横向扩展,说白了,就是增加一些一样的服务器,然后在服务器上就可以部署我们的web服务,只要服务部署的程序是一样,那么每台web...
  • 主从同步一般使用在多台服务器上读写分离的数据库架构。为了提交数据库的效率,其实现的原理如下 分别配置了主从服务器。...这里的slave database不一定只是一台数据库服务器,可以使slave database的集
  • 最近在做数据库的性能测试,发现一个奇怪的现象,当并发数在两百以内的时候,数据库服务器的CPU使用率为70%多,数据库服务器的CPU是40个,每个CPU的使用率都很平均。当并发量达到一千的时候,数据库服务器的使用率...
  • 公司项目用到了PostgreSQL...装好之后,选择pgAdmin III启动服务控制台,里面有一个Database Server,数据库服务器,里面有四个选项,数据库,表空间,群组角色,登入角色。数据库需要自己建立,不过安装的时候就初始化
  • 数据库服务器到底是用机械硬盘还是固态硬盘 答案是:固态硬盘   //1.固态硬盘已经便宜了 //2.做了RAID5,之后有了数据安全保障,不放心的话 就做RAID1,更何况现在都是数据库集群,所以不担心数据丢失的问题了 ...
  • 测试部门发生了多次数据库服务器空间满而导致无法登陆oracle实例的事情,在此特地整理一篇文章以提供测试部门人员参考。根据原因是由于测试部门在内网测试环境中开启了数据库的归档模式,一般由于测试数据库服务器...
1 2 3 4 5 ... 20
收藏数 1,480,794
精华内容 592,317
热门标签
关键字:

数据库服务器