Sponsored Content
Top Forums Shell Programming and Scripting Help with a rotate log script Post 302697247 by newbie_01 on Thursday 6th of September 2012 09:49:36 AM
Old 09-06-2012
Help with a rotate log script

Hi all,

Am trying to write my own log rotate script. Curremtly, what I have is as below:

Code:
 
#!/bin/ksh
file_to_rotate=${1}
x=${2}
while [[ ${x} -ge 1 ]]
do
   let curr=${x}
   let prev=${x}-1
   if [[ $x -eq 1 ]] ; then
      #echo "cp -p ${file_to_rotate} ${file_to_rotate}.${curr}"
      cp -p ${file_to_rotate} ${file_to_rotate}.${curr}
      let x=${x}-1
   else
      if [[ ! -f ${file_to_rotate}.${prev} ]] ; then
         let x=${x}-1
      else
         #echo "cp -p ${file_to_rotate}.${prev} ${file_to_rotate}.${curr}"
         cp -p ${file_to_rotate}.${prev} ${file_to_rotate}.${curr}
         let x=${x}-1
      fi
   fi
done

I run the script as ./x.ksh x.log 10 and it works like how I want it to. Unfortunately, sometimes, I have some files missing like and my number of rotated log files turns out as below:

Code:
[tmp]$ ls -ltr
total 36
-rw-r--r-- 1 oracle oinstall 198 Sep  7 00:38 x.log.9
-rw-r--r-- 1 oracle oinstall 198 Sep  7 00:38 x.log.8
-rw-r--r-- 1 oracle oinstall 198 Sep  7 00:38 x.log.7
-rw-r--r-- 1 oracle oinstall 198 Sep  7 00:38 x.log.6
-rw-r--r-- 1 oracle oinstall 198 Sep  7 00:38 x.log.2
-rw-r--r-- 1 oracle oinstall 198 Sep  7 00:38 x.log.10
-rw-r--r-- 1 oracle oinstall 198 Sep  7 00:38 x.log.1
-rw-r--r-- 1 oracle oinstall 198 Sep  7 00:38 x.log
-rwxr--r-- 1 oracle oinstall 549 Sep  7 01:38 x.ksh


Note that I have x.log.5, x.log.4, x.log.3 missing. Can anyone suggest how I can include some sort of re-ordering/renaming loop so that after I run the rotate script, I will end up with the rotated logs renamed as below:

Code:
 
-rw-r--r-- 1 oracle oinstall 198 Sep  7 00:38 x.log.9
-rw-r--r-- 1 oracle oinstall 198 Sep  7 00:38 x.log.8
-rw-r--r-- 1 oracle oinstall 198 Sep  7 00:38 x.log.7
-rw-r--r-- 1 oracle oinstall 198 Sep  7 00:38 x.log.6
-rw-r--r-- 1 oracle oinstall 198 Sep  7 00:38 x.log.2
-rw-r--r-- 1 oracle oinstall 198 Sep  7 00:38 x.log.10
-rw-r--r-- 1 oracle oinstall 198 Sep  7 00:38 x.log.1

x.log.10 should be x.log.7
x.log.9 should be x.log.6
x.log.8 should be x.log.5
x.log.7 should be x.log.4
x.log.6 should be x.log.3
x.log.2 should be x.log.2
x.log.1 should be x.log.1

Help much appreciated. Thanks in advance.
 

10 More Discussions You Might Find Interesting

1. HP-UX

Check size and rotate log script.

Hi Can you suggest some perl script. My OS is HP-UX 11.11 I want to it into a cron job. Every night it will backup the file with that day's date and open a dummy file. Thanks Ash (3 Replies)
Discussion started by: ashishT
3 Replies

2. Shell Programming and Scripting

how to rotate log files

hi friends i need a shell script to rotate the logs in a directory, dated n days back. can anybody of help. appreciate.. (0 Replies)
Discussion started by: satya_skm
0 Replies

3. UNIX for Advanced & Expert Users

log rotate

hi , what is the meaning of log rotate? how do i rotate /var/adm/wtmps log and gzip it? (6 Replies)
Discussion started by: cromohawk
6 Replies

4. Shell Programming and Scripting

Script for Log Rotate

Hello, I only know the basic for shell programing. I need help for this, I thinks this is a basic for anyone who know a litle of shell scripting. I need creat a script for a rotatate logs, when a filesystem is full. I have a filesystem. The rotate consist in zip the current log (copy) and... (1 Reply)
Discussion started by: El Rengo
1 Replies

5. Shell Programming and Scripting

cron script to rotate log files

I have a mac server. I have been having problems with my logs. My hard disk became full, when i researched into why it was full it was due to massive log files. There was barley any log rotation policies in place on the server. I tired to use logrotate. This doesn't work on my server. It is a MAC... (19 Replies)
Discussion started by: timgolding
19 Replies

6. Shell Programming and Scripting

Rotate log files

I have a big log,separated by the character:, one of the fields is the date in the format "day / month / year" and I need to remove the lines prior to 30 days. Can help me? (7 Replies)
Discussion started by: msanbrug
7 Replies

7. Shell Programming and Scripting

Rotate log everyday on existing script

quick question: I have a current script that will put the output on a log file. See snapshot of the code below. I wanted this to be rotated everyday based on date. So if anyone execute the script today there will be a filecreated such as sys.log.(datetoday), if tomorrow it would be... (1 Reply)
Discussion started by: lhareigh890
1 Replies

8. Shell Programming and Scripting

"Customized" log rotate script - some advice please

Hi, Am trying to write my own version of a log rotate scripts 'coz I don't have the logrotate for other flavors of *nix servers. Probably should try and download the source and re-compile but our SA don't want to do so. Anyway, just want to know if there is any way to improve on the code... (0 Replies)
Discussion started by: newbie_01
0 Replies

9. Shell Programming and Scripting

Script to rotate file log

Hi Experts, I have script on crontab and give output quite large. I would like to know how to create rotate log when the size of log maximum 50MB if the test.log is 50MB then create test.0 Thanks Edy (2 Replies)
Discussion started by: edydsuranta
2 Replies

10. Shell Programming and Scripting

Log rotate

Hi, I have below script in logrotate.d to rotate logs. logs are not rotating after the file grow to 1k, do you have any idea? Is it because of it just only 1K? Please let me know if the below syntax is in correct. # more trotate /sourcepath/*/servers/*/logs/*log... (2 Replies)
Discussion started by: lpprasad321
2 Replies
IPROP-LOG(8)						    BSD System Manager's Manual 					      IPROP-LOG(8)

NAME
iprop-log -- maintain the iprop log file SYNOPSIS
iprop-log [--version] [-h | --help] command iprop-log truncate [-c file | --config-file=file] [-r string | --realm=string] [-h | --help] iprop-log dump [-c file | --config-file=file] [-r string | --realm=string] [-h | --help] iprop-log replay [--start-version=version-number] [--end-version=version-number] [-c file | --config-file=file] [-r string | --realm=string] [-h | --help] DESCRIPTION
Supported options: --version -h, --help command can be one of the following: truncate -c file, --config-file=file configuration file -r string, --realm=string realm Truncates the log. Sets the new logs version number for the to the last entry of the old log. If the log is truncted by emptying the file, the log will start over at the first version (0). dump -c file, --config-file=file configuration file -r string, --realm=string realm Print out all entries in the log to standard output. replay --start-version=version-number start replay with this version --end-version=version-number end replay with this version -c file, --config-file=file configuration file -r string, --realm=string realm Replay the changes from specified entries (or all if none is specified) in the transaction log to the database. last-version -c file, --config-file=file configuration file -r string, --realm=string realm prints the version of the last log entry. SEE ALSO
iprop(8) Heimdal February 18, 2007 Heimdal
All times are GMT -4. The time now is 08:55 PM.
Unix & Linux Forums Content Copyright 1993-2022. All Rights Reserved.
Privacy Policy