catalogue
- π² preface π²
- I β Host level β οΈ
- II π« Database level π«
- 1, π View database instances and listen
- 2, π Database tablespace usage
- 3, π’ Check RMAN backup
- 4, π‘ Check control file redundancy
- 5, π Check parameter file
- 6, π¬ Are archiving and flashback enabled
- 7, π Check the online log and switching frequency
- 8, π View database character set
- 9, π― Check for invalid objects
- 10, π Check partition table object
- III βοΈ Reporting level βοΈ
- β‘ Write at the end β‘ οΈ
π² preface π²
If you are given a new Oracle stand-alone database environment, what do you need to pay attention to as a DBA? This article only discusses Linux hosts~
π’ First of all, it is not a standard answer, but some personal opinions. Welcome ππ» We need to improve~
First, of course, confirm whether it is a stand-alone or cluster database! This article mainly explains stand-alone database.
I β Host level β οΈ
1, π Host version and Oracle version
Host version:
cat /etc/system-release cat /etc/redhat-release
data:image/s3,"s3://crabby-images/5839b/5839bb6b14a7859cb2b5e8cbb6189ec352e3dcdd" alt=""
Oracle version and patch version:
sqlplus -version opatch lspatches
data:image/s3,"s3://crabby-images/ea3b0/ea3b03762d5887e01e21e35571cdaf03b062af55" alt=""
2, π» Host hardware resources
Including CPU load, physical memory and disk usage.
CPU load and memory:
top free -m
data:image/s3,"s3://crabby-images/4c31c/4c31c8f6376a8f428e624727170fee21295726e0" alt=""
data:image/s3,"s3://crabby-images/56168/56168105ce30bb546391791ed89b58177b0667c4" alt=""
β οΈ Pay attention to whether the CPU load and physical memory usage of the host are abnormal, and whether Swap is used too much.
Disk usage:
lsblk fdisk -l df -Th
data:image/s3,"s3://crabby-images/17fb1/17fb1be5d66d43b71b883c24bd46e48e3653110e" alt=""
β οΈ Obviously, we need to pay attention to the disk usage and whether the utilization rate is too high.
3, π Schedule task crontab
Some backup strategies or archive deletion strategies will be arranged for general planning tasks. We can view them through crontab:
crontab -l
data:image/s3,"s3://crabby-images/69451/6945124fc08c8a6180c419ba5e64dbbbf35a549f" alt=""
4, πΏ Check the Hosts file and network configuration
cat /etc/hosts ip addr nmcli connection show
data:image/s3,"s3://crabby-images/3afbd/3afbdda5423384823e398bf6954b974589e5a075" alt=""
data:image/s3,"s3://crabby-images/22a24/22a243e282f7d86791c271d5e5f025515c02dd7e" alt=""
5, π Check the system parameter file
cat /etc/sysctl.conf
data:image/s3,"s3://crabby-images/2ad40/2ad40999d3fbc1c15a046aee8e6236a8b1ac114d" alt=""
β οΈ Pay attention to whether unconventional parameters are set.
6, π» Check RC Local file
rc. The local file is used to configure the startup self startup script. Generally, it will be set to close the transparent large page or the startup self startup of Oracle database.
cat /etc/rc.local
data:image/s3,"s3://crabby-images/a4b5a/a4b5a7fcd0d09c844c6888a1e9ed7432a8cc706b" alt=""
7, π Environment variable configuration
View the environment variable configuration to get more familiar with the environment.
cat ~/.bash_profile cat /home/oracle/.bash_profile
data:image/s3,"s3://crabby-images/7443b/7443b249af9570ca8c79810e248d9798994e8edf" alt=""
data:image/s3,"s3://crabby-images/dd768/dd76815820fd52f3b295e07d5f33e2bab72b4811" alt=""
8, π΅ Check system service
systemctl status firewalld.service getenforce cat /proc/cmdline cat /etc/sysconfig/network
data:image/s3,"s3://crabby-images/de68b/de68b37feb6629a4e902a53483dae06465743718" alt=""
II π« Database level π«
1, π View database instances and listen
ps -ef|grep smon su - oracle lsnrctl status
data:image/s3,"s3://crabby-images/8381a/8381a2071f7b93eaf27bbab928b4752f3b321a9f" alt=""
data:image/s3,"s3://crabby-images/83422/834224d703af1f40d61577ceab84f35c06d56beb" alt=""
2, π Database tablespace usage
sqlplus / as sysdba col TABLESPACE_NAME for a20 select tbs_used_info.tablespace_name, tbs_used_info.alloc_mb, tbs_used_info.used_mb, tbs_used_info.max_mb, tbs_used_info.free_of_max_mb, tbs_used_info.used_of_max || '%' used_of_max_pct from (select a.tablespace_name, round(a.bytes_alloc / 1024 / 1024) alloc_mb, round((a.bytes_alloc - nvl(b.bytes_free, 0)) / 1024 / 1024) used_mb, round((a.bytes_alloc - nvl(b.bytes_free, 0)) * 100 / a.maxbytes) used_of_max, round((a.maxbytes - a.bytes_alloc + nvl(b.bytes_free, 0)) / 1048576) free_of_max_mb, round(a.maxbytes / 1048576) max_mb from (select f.tablespace_name, sum(f.bytes) bytes_alloc, sum(decode(f.autoextensible, 'YES', f.maxbytes, 'NO', f.bytes)) maxbytes from dba_data_files f group by tablespace_name) a, (select f.tablespace_name, sum(f.bytes) bytes_free from dba_free_space f group by tablespace_name) b where a.tablespace_name = b.tablespace_name(+)) tbs_used_info order by tbs_used_info.used_of_max desc;
data:image/s3,"s3://crabby-images/3fedc/3fedc0faad9151908394c1ce2fc5c6e83c8d4e25" alt=""
3, π’ Check RMAN backup
rman target / list backup; sqlplus / as sysdba col status for a10 col input_type for a20 col INPUT_BYTES_DISPLAY for a10 col OUTPUT_BYTES_DISPLAY for a10 col TIME_TAKEN_DISPLAY for a10 select input_type, status, to_char(start_time, 'yyyy-mm-dd hh24:mi:ss'), to_char(end_time, 'yyyy-mm-dd hh24:mi:ss'), input_bytes_display, output_bytes_display, time_taken_display, COMPRESSION_RATIO from v$rman_backup_job_details where start_time > date '2021-07-01' order by 3 desc;
data:image/s3,"s3://crabby-images/b7f49/b7f49836d9db629eeccaf0145603cbb66d9742c2" alt=""
4, π‘ Check control file redundancy
Check the number and location of control files and whether they are in multiple redundancy status.
sqlplus / as sysdba show parameter control_files select name from v$controlfile;
data:image/s3,"s3://crabby-images/d7252/d7252d7a494daddf20467b4f84bb4b51c58b1ba1" alt=""
data:image/s3,"s3://crabby-images/e1e78/e1e782e711c3b8b26fedba9b0191089fe75fd734" alt=""
5, π Check parameter file
View the database parameter file and check whether the parameters are used normally.
sqlplus / as sysdba show parameter spfile create pfile='/home/oracle/pfile.ora' from spfile; strings /home/oracle/pfile.ora
data:image/s3,"s3://crabby-images/be8de/be8de8148967690dd93d01175f236fe45c3d613b" alt=""
data:image/s3,"s3://crabby-images/0b0fd/0b0fd796d9e7e07e97919c1a14b31ba57a507d5f" alt=""
6, π¬ Are archiving and flashback enabled
sqlplus / as sysdba archive log list select open_mode,log_mode,flashback_on,force_logging from v$database;
data:image/s3,"s3://crabby-images/4171b/4171bf1068149f2f08ff05e0eb35be1ff9a34c6c" alt=""
7, π Check the online log and switching frequency
View online log size:
set line222 col member for a100 select f.group#,f.member,l.sequence#,l.bytes/1024/1024,l.archived,l.status,l.first_time from v$logfile f,v$log l where f.group# = l.group# order by f.group#,f.member;
data:image/s3,"s3://crabby-images/4c868/4c868444c55da26dcdee5e14fc28c0a5c3961fc9" alt=""
View online log switching frequency:
col day for a30 SELECT SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH:MI:SS'),1,5) DAY, SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'00',1,0)) H00, SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'01',1,0)) H01, SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'02',1,0)) H02, SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'03',1,0)) H03, SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'04',1,0)) H04, SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'05',1,0)) H05, SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'06',1,0)) H06, SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'07',1,0)) H07, SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'08',1,0)) H08, SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'09',1,0)) H09, SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'10',1,0)) H10, SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'11',1,0)) H11, SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'12',1,0)) H12, SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'13',1,0)) H13, SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'14',1,0)) H14, SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'15',1,0)) H15, SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'16',1,0)) H16, SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'17',1,0)) H17, SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'18',1,0)) H18, SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'19',1,0)) H19, SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'20',1,0)) H20, SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'21',1,0)) H21, SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'22',1,0)) H22, SUM(DECODE(SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH24:MI:SS'),10,2),'23',1,0)) H23, COUNT(*) TOTAL FROM v$log_history a where SYSDATE - first_time < 35 GROUP BY SUBSTR(TO_CHAR(first_time, 'MM/DD/RR HH:MI:SS'),1,5) order by 1;
8, π View database character set
select * from nls_database_parameters;
data:image/s3,"s3://crabby-images/78ad0/78ad06b69ecbb629bf4d7d1c61d7a46c75fe9f28" alt=""
9, π― Check for invalid objects
SELECT owner,object_name,object_type,status FROM dba_objects WHERE status <> 'VALID' ORDER BY owner,object_name;
data:image/s3,"s3://crabby-images/e3da1/e3da10320c6ac3697c974df64ac909b0a2815f12" alt=""
10, π Check partition table object
set line222 col high_value for a100 select t2.TABLE_OWNER,t1.table_name, t1.max_partition_name, t2.high_value from (select table_name, max(partition_name) as max_partition_name from dba_tab_partitions group by table_name) t1, (select TABLE_OWNER,table_name, partition_name, high_value from dba_tab_partitions where tablespace_name not in ('SYSAUX', 'SYSTEM')) t2 where t1.table_name = t2.table_name and t1.max_partition_name = t2.partition_name order by 1,2;
data:image/s3,"s3://crabby-images/83eaa/83eaaba936e1b4efb50430906631df242aaa8955" alt=""
Pay attention to the maximum expansion of the partition. It is recommended to expand the partition in advance to avoid splitting.
III βοΈ Reporting level βοΈ
Through the awr, ash, awrsqrpt and other reports provided by Oracle, you can clearly understand the current database situation.
1, π awr Report
AWR contains the detailed information collection of database operation, which is often used to analyze and collect performance problems.
sqlplus / as sysdba @?/rdbms/admin/awrrpt.sql
The above command can generate AWR report, and you need to fill in the report type, grab time and how to use it. You can also check your official account of the AWR Hawkeye free video tutorial.
data:image/s3,"s3://crabby-images/45f49/45f496e5786010ee84fa5ba76536601b5b280fde" alt=""
2, π ash Report
ash can capture more detailed information than AWR report, which can be accurate to minutes, and it is also commonly used.
sqlplus / as sysdba @?/rdbms/admin/ashrpt.sql
The above is the generation method, optional time period, and the default is to obtain the report from the current time to 15 minutes ago.
3, π awrsqrpt Report
It is used to analyze the report when a single SQL has performance problems. You need to know the SQL_ID.
sqlplus / as sysdba @?/rdbms/admin/awrsqrpt.sql
You need to fill in the time period and sql_id to get the relevant sql report.
4, π sqltrpt Report
It is usually used together with awrsqrpt report to obtain sql optimization suggestions provided by Oracle. Generally speaking, it is recommended to create more indexes and profile s, which is suitable for novices to optimize sql.
sqlplus / as sysdba @?/rdbms/admin/sqltrpt.sql
Only SQL is required_ ID is enough.
5, π addmrpt Report
addmrpt is a report generated by oracle through automatic diagnosis of awr reports.
sqlplus / as sysdba @?/rdbms/admin/addmrpt.sql
For reference only, real help is not of great significance. The process requires a time period to be entered.
6, π½ Health examination report
This kind of health examination report is generally a report generated by individual script execution. The examination results usually contain the above required information according to individual definition. Of course, the Oracle official also provides the report generation method of the complete database. There is no too much introduction here. If you need it, you can contact me for it.
β‘ Write at the end β‘ οΈ
Through the above inspections, I believe you have a general understanding of the database system you are new to. Next, you just need to make a slow and in-depth analysis, and then formulate a set of operation and maintenance specifications in line with the actual situation.
γΎ(βΒ°βΒ°β)οΎοΎ