面向dba的linux shell 脚本简介,面向dba的linuxshell脚本简介.doc

41528d3028836879cd698677c3999917.gif面向dba的linuxshell脚本简介.doc

面向DBA的LinuxShell脚本简介7年前,Oracle发布了Linux上的第一个商业数据库。从那时起,Oracle、RedHat和Novell/SUSE就不断地合作更改Linux内核,从而提高数据库和应用程序的性能。正因为这样,用于Linux的Oracle数据库10g才包含了与操作系统紧密相关的许多增强功能。DBA比以往任何时候更需要了解和使用此平台来在其监视下对系统进行最佳管理。以往,系统管理员与DBA之间在职责方面存在差别。但实际上,这种差别通常并不明显。许多IT部门雇佣一些可解决数据库级以及操作系统级问题的员工。当然,Oracle数据库本身使用操作系统资源,并能与其环境紧密交互。此外,许多系统管理员和DBA发现将其工作相关的任务自动化很有必要或比较方便。软件安装、系统资源监视以及系统管理涉及一些重复和容易出错的任务,而自动过程可以比手动过程更好地完成这些任务。将这些任务自动化的方法之一是shell脚本。Shell脚本自Linux系统安装之初就起着重要作用。启动和关闭系统时就会调用各种脚本。Oracle和其他第三方供应商的实用程序也是通过shell脚本可调用的。由于这些脚本可以快速开发,因此历来就用它们构建应用程序原型。系统管理员已利用通过shell脚本实现的功能提供针对其监视的系统的特定要求和特征定制的解决方案了。在本文中,我将介绍“bash”shell脚本可以实现的、与在Linux平台上安装、运行和维护Oracle数据库相关的功能。注意,本文适用于Linux脚本初学者或对Linux相对陌生的DBA;对大多数经验丰富的Linux系统管理员则不适用。Shell脚本是什么?shell脚本是一个包含命令序列的文本文件。当运行文件(或脚本)时,将执行该文件中包含的命令。术语shell仅指与Linux内核通信所使用的特定命令行用户界面。目前有多个不同的shell,其中包括Cshell(csh)、Kornshell(ksh)、Bourneshell(sh)和Bourne-Againshell(bash)。shell本身就是一个从文件或终端读取命令、解释这些命令并通常执行其他命令的命令。Bourne-Againshell合并了上述其他shell的特性,本文就使用该脚本进行演示。脚本文件中的第一行可用于指定使用哪个shell来运行该脚本。以下是所有脚本示例中包含的第一行的含义:#!/bin/bash为什么使用Shell脚本?由于shell脚本与DBA的工作相关,因此您可能不会马上看到shell脚本的价值,这跟您的工作经历有关。如果您以前从未使用过UNIX或类似UNIX的系统,那么可能会对大量含义晦涩的命令感到一愁莫展。此外,除了作为关系数据库外,Oracle10g还提供了一个用于处理数据库数据的强健平台以及几个用于在数据库外部与操作系统交互的方法。但您会发现几个探究shell脚本领域的原因,其中包括:必须支持已经存在的脚本。需要在安装Oracle软件前自动设置系统。例如,您可以编写一个脚本来检查OS的初始状态并报告安装软件前必须满足的任何前提条件。该脚本还可以创建相关的OS用户和组并为用户设置环境变量。可以使用正在运行的Oracle数据库来执行手动或计划的任务。但在数据库未运行时需要运行某些任务。可以使用脚本停止或启动数据库(以及侦听器或相关的数据库进程)。无法从数据库内部启动此类动作。您需要一种监视数据库状态(例如,是否正在运行并可进行进程查询)的机制。这样的脚本还可以监视非特定于Oracle的其他进程和资源,从而提供系统当前运行情况的更详细信息。需要将备份自动化。OracleRecoveryManager(RMAN)是一个用于开发可以在任何平台上运行的备份脚本的实用程序。可以从shell脚本中调用OracleRecoveryManager并使用它执行各种备份和恢复活动。您可能有一个并非特定于某个数据库的要求。您可能在一台计算机上安装了多个数据库。建议您不要使用单个数据库满足此要求,因为那样会引发潜在的安全性问题。在这些情况下,shell脚本提供了一种既可以满足此要求又不会将进程与单个数据库关联的方法。什么情况下不使用Shell脚本Oracle数据库包含了超出RDBMS传统定义的功能。与软件的任何其他部分一样,它使用操作系统提供的资源,但它所“看到”并“更改”其环境的程度远远超过了其他软件。SQL和Oracle的固定视图从数据库内部提供了系统视图,而shell脚本从数据库外部提供了系统视图。Shell脚本并不是适用于所有问题的解决方案。必须意识到,操作系统的许多方面可以从数据库内部进行监视和修改。可以使用Oracle的固定视图(带v$前缀的视图)确定计算机的主机名(v$instance)或数据库正在其中运行的平台的名称(v$database)。还可以通过这种方式确定与数据库相关的文件的位置和其他属性。可以直接从数据库中查询数据文件(v$datafile、dba_data_files)、临时文件(v$tempfile、dba_temp_files)、重做日志(v$logfile)、存档日志(v$archived_log)和控制文件(v$controlfile)的位置和其他属性。可以通过该视图以及通过查看某些init.ora参数(db_recovery_file_dest、db_recovery_file_dest_size)确定有关闪回恢复区($recovery_file_dest)的信息。还可以查询进程(v$process)和内存(v$sga、v$sgastat等)的状态。有各种内置的PL/SQL程序包,并能够创建允许对底层OS进行其他访问的Java和C数据库对象。如果您正在考虑为一个需要大量数据库访问的任务编写脚本,则脚本可能并不是最佳选择。本文的稍后部分将介绍如何使用SQL*Plus访问数据库,但在很多情况下,使用其他语言可以更好地解决此问题。下表归纳了可以从数据库中访问的信息:服务器/操作系统信息服务器标识典型查询附注实例运行在的主机的名称selecthost_namefromv$instance;也可以通过从bash运行以下命令来获得该信息:hostname或uname–n操作系统平台selectplat_namefromv$database–-(10g)如果运行uname–s,则将返回类似信息文件信息Oracle文件位置典型查询附注控制文件selectnamefromv$controlfile;数据库控制文件的位置。init.ora的参数control_files也包含该信息。数据文件selectfile_namefromDba_data_files;数据库数据文件的位置临时文件selectfile_namefromDba_temp_files;数据库临时文件的位置日志文件selectmemberfromv$logfile;重做日志的位置归档日志selectnamefromv$archived_log归档重做日志的位置。init.ora的参数log_archive_dest_n也包含该信息。如果数据库不在Archivelog模式下

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值