linux_oracle_healthcheck.sh
#!/bin/bash
##########################################################################################
# Script: LINUX_ORACLE.bash
##########################################################################################
#
# ORACLE HEALTH CHECK
##########################################################################################
DATE=$(date +%Y%m%d)
HOSTNAME=$(hostname)
HCDIR=/oracle/xunjian
HCFILE=${HCDIR}/orachk_${DATE}_${HOSTNAME}.log
#export ORACLE_SID=orcl1
#export ORACLE_BASE=/oracle/oracle
#export ORACLE_HOME=$ORACLE_BASE/product/11.2.0/db_1
#export PATH=/usr/kerberos/bin:/usr/local/bin:/bin:/usr/bin:/home/oracle/bin:/u01/11.2.0/grid/bin:$ORACLE_HOME/bin:$ORACLE_HOME/dcm/bin:$ORACLE_HOME/webcache/bin:$ORACLE_HOME/opmn/bin
#export LD_LIBRARY_PATH=$ORACLE_HOME/lib
exec > $HCFILE
##############OS AND CLUSTER CHECK###########################################################
date
echo '######################################VMSTAT 2 10###########################################'
vmstat -S M 2 10
echo '######################################MEM USAGE#############################################'
free -m
echo '######################################FS STATUS#############################################'
df -h
echo '######################################CLUSTER STATUS########################################'
su - grid -c "crs_stat -t"
echo '######################################CRS STATUS############################################'
su - grid -c "crsctl check crs"
echo '######################################VOTEDISK STATUS#######################################'
su - grid -c "crsctl query css votedisk"
echo '######################################OCR STATUS############################################'
su - grid -c "ocrcheck"
echo '######################################OCR BACKUP############################################'
su - grid -c "ocrconfig -showbackup"
echo '######################################LSNR STATUS###########################################'
su - grid -c "lsnrctl status"
####################DB CHECK###########################################################
su - oracle -c "sqlplus -S / as sysdba" <<EOF
set pagesize 1000;
set linesize 200;
prompt ######################################DB NAME###############################################
select name from v\$database;
prompt ######################################INSTANCE STATUS######################################
select instance_name,status from gv\$instance;
prompt ######################################ARCHIVELOG MOD#######################################
archive log list;
prompt ######################################DB SIZE##############################################
select sum(bytes)/1024/1024/1024 DBSIZE_GB from dba_segments;
prompt ######################################STORAGE USEGE##############################################
col NAME for a20
set lin 150
select NAME,TOTAL_MB,FREE_MB,STATE from v\$asm_diskgroup;
prompt ######################################USERS################################################
col username format a25
col account_status format a18
col default_tablespace format a20
col temporary_tablespace format a20
select username,account_status,default_tablespace,temporary_tablespace from dba_users;
prompt ######################################CONTROLFILE###########################################
col name format a65;
select name,status from v\$controlfile;
prompt ######################################REDO LOG##############################################
col member format a60;
select f.member "member", f.group# "group", l.bytes/1024/1024 "size", l.status from v\$logfile f, v\$log l where f.group#=l.group# order by f.group#,f.member;
prompt ######################################TABLESPACE############################################
set line 200 pagesize 9999
col tablespace_name for a20
select b.tablespace_name,round(sum(b.bytes)/1024/1024,0) sum_MB,
round(sum(b.bytes)/1024/1024,0)-round(sum(nvl(a.bytes,0))/1024/1024,0) use_MB,
round(sum(nvl(a.bytes,0))/1024/1024,0) free_MB,
round((sum(b.bytes)-sum(nvl(a.bytes,0)))/sum(b.bytes),4)*100 use_precent
from (select tablespace_name,file_id,sum(bytes) bytes from dba_free_space group by tablespace_name,file_id) a,
dba_data_files b
where a.file_id(+)=b.file_id and a.tablespace_name(+)=b.tablespace_name
group by b.tablespace_name
union all
select b.tablespace_name,round(b.bytes/1024/1024,0) sum_MB,
round(nvl(a.bytes,0)/1024/1024,0) use_MB,
round(b.bytes/1024/1024,0)-round(nvl(a.bytes,0)/1024/1024,0) free_MB,
round(nvl(a.bytes,0)/b.bytes,4)*100 use_precent
from (select tablespace_name,sum(nvl(bytes_used,0)) bytes from gv\$temp_extent_pool group by tablespace_name) a,
(select tablespace_name,sum(bytes) bytes from dba_temp_files group by tablespace_name)b
where a.tablespace_name(+)=b.tablespace_name
order by use_precent desc;
prompt ######################################DATA-TEMP FILE##############################################
col TABLESPACE_NAME for a15
col file_name for a50
set linesize 150
select TABLESPACE_NAME,FILE_NAME,FILE_ID,BYTES/1024/1024 mb,ONLINE_STATUS from dba_data_files
union all
select TABLESPACE_NAME,FILE_NAME,FILE_ID,BYTES/1024/1024 mb,STATUS from dba_temp_files
order by 1;
prompt ######################################INVALID OBJECTS#######################################
select count(*) from dba_objects where status = 'INVALID';
prompt ######################################UNUSE INDEX###########################################
select count(*) from dba_indexes where status='UNUSABLE';
exit;
EOF
echo 'BACKGROUD ALERT'
echo '######################################BACKGROUD ALERT#########################################'
tail -500 /oracle/oracle/diag/rdbms/orcldb/orcldb1/trace/alert_orcldb1.log
echo '######################################END#####################################################'
########################FTP TO LOCAL###########################
HOST_IP=192.168.1.18
USRNM="ftp"
PWD="password"
LOCAL_DIR=/oracle/xunjian
REMOTE_DIR=/dbcheck/test
ftp -inv $HOST_IP<<!
user ${USRNM} ${PWD}
bin
prompt
lcd ${LOCAL_DIR}
cd ${REMOTE_DIR}
mput orachk_${STAMP}_${HOSTNAME}.log
bye
!
exit
linux_oracle_healthcheck.sh的更多相关文章
- 数据库备份并分离日志表(按月)sh 脚本
#!/bin/sh year=`date +%Y` month=`date +%m` day=`date +%d` hour=`date +%H` dir="/data/dbbackup/f ...
- Linux下如何查找.sh后缀的文件
find / -name *.sh或locate *.shfind 与locate的区别:locate 配合数据库查看文件位置 find 实际搜寻硬盘查询文件名称
- sh 测试网段在线主机
yum install nmap nmap -sP 192.168.21.1/24 查看网段在线主机 grep -vwf file1 file2 文件内容比较 #!/bin/bash # day=` ...
- Maven打包生成可运行bat/sh脚本文件
利用Maven的appassembler-maven-plugin插件,就可以实现自动打包可运行的脚本,还可以跨平台. <plugin> <groupId>org ...
- 记一个简单的保护if 的sh脚本
真是坑爹,就下面的sh,竟然也写了很久! if [ `pwd` != '/usr/xx/bin/tomcat' ] then echo "rstall is not allowed in c ...
- 主机巡检脚本:OSWatcher.sh
主机巡检脚本:OSWatcher.sh 2016-09-26更新,目前该脚本只支持Linux操作系统,后续有需求可以继续完善. 注意: 经测试,普通用户执行脚本可以顺利执行前9项检查: 第10项,普通 ...
- Oracle巡检脚本:ORAWatcher.sh
Oracle巡检脚本:ORAWatcher.sh #!/usr/bin/ksh echo "" echo "ORAWatcher Version:1.0.1" ...
- 解决:/bin/sh: 1: /home/**/custom_app.sh: Permission denied错误
出现如下错误,一般是执行权限不够. /bin/sh: : /home/custom_app.sh: Permission denied 解决方法是:cd 到此文件目录,对提示的文件赋予可执行权限或读写 ...
- SH Script Grammar
http://linux.about.com/library/cmd/blcmdl1_sh.htm http://pubs.opengroup.org/onlinepubs/9699919799/ut ...
随机推荐
- debain 8安装为知笔记(how to install wiznote in debain 8)
刚装了debain8后想安装为知笔记,百度之后发现为知笔记原来是开源软件.代码托管在github上:https://github.com/WizTeam/WizQTClient 但是上面只有Ubunt ...
- 对C语言的知识与能力予以自评
看到一个问卷不错,拟作为第三次作业的部分内容. 你对自己的未来有什么规划?做了哪些准备?我准备在将来成为一名合格的软件工作人员,我已经在平时有空的时间里着手代码的练习. 你认为什么是学习?学习有什么用 ...
- 此博客主人已搬家访问新家地址:http://write.blog.csdn.net/postlist
此博客主人已搬家访问新家地址:http://write.blog.csdn.net/postlist
- Github账户注册的过程
首先我通过冯老师的博客园帖子中的链接进入了注册地址,填写了用户名,邮箱,和密码.然后我进入我的邮箱验证了Github网站给我发送的验证信息,至此,我的GITHUB账户便注册完成了.
- 关于redis扩展安装及使用
11月23日,预留 http://blog.sina.com.cn/s/blog_68431a3b0102v6dz.html http://blog.csdn.net/rachel_luo/artic ...
- Apache常用配置项
301是永久重定向 302是临时重定向 编辑虚拟主机的配置文件需要用到apache的rewrite模块 所以要用要先检查apache是否安装了rewrite模块 # ./bin/apachectl - ...
- linux 并发 RCU
What is RCU, Fundamentally? https://lwn.net/Articles/262464/ If you can fill the unforgiving secondw ...
- SQLSERVER系统视图,系统表,sys.sql_modules视图
SQLServer中提供了相当丰富的系统视图,能够从宏观到微观,从静态到动态反应数据库对象的存储结果.系统性能.系统等待事件等等.同时 也保留了与早期版本兼容性的视图,主要差别在于SQLServer2 ...
- 042. asp.net使用缓存来提高母版页的访问性能
Asp.Net缓存技术是一项非常重要的技术, 当一个页面被频繁的访问, 如果不使用缓存技术, 那么每访问一次就要回发一次服务器, 显然这样对服务器造成很大的负担, 所以, 可以在被频繁访问的页面中设置 ...
- FP-tree推荐算法
推荐算法大致分为: 基于物品和用户本身 基于关联规则 基于模型的推荐 基于物品和用户本身 基于物品和用户本身的,这种推荐引擎将每个用户和每个物品都当作独立的实体,预测每个用户对于每个物品的喜好程度,这 ...