ML
    • Recent
    • Categories
    • Tags
    • Popular
    • Users
    • Groups
    • Register
    • Login

    Anacron Jobs on a CentOS 7 Server

    IT Discussion
    centos centos 7 cron crontab anacron scheduling linux rhel rhel 7
    4
    28
    6.9k
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • matteo nunziatiM
      matteo nunziati @scottalanmiller
      last edited by

      @scottalanmiller that's ok, but this doesn't answer the question: where -by jove- anacron+systemd hide the exact execution day for a weekly job?!

      travisdh1T 1 Reply Last reply Reply Quote 0
      • travisdh1T
        travisdh1 @matteo nunziati
        last edited by

        @matteo-nunziati said in Anacron Jobs on a CentOS 7 Server:

        @scottalanmiller that's ok, but this doesn't answer the question: where -by jove- anacron+systemd hide the exact execution day for a weekly job?!

        I assume you've found nothing in the config files under /etc/cron and/or /etc/anacron? Do the man pages say anything about a setting you can add in a config file?

        1 Reply Last reply Reply Quote 0
        • matteo nunziatiM
          matteo nunziati
          last edited by

          the cron file is empty by default.
          anacron conf file to not declare when the week finish/start! even the anacron man page to not declare anything!
          Again, on debian cron explicitly raises an anacron job on sunday, not here on centos. weird.

          1 Reply Last reply Reply Quote 0
          • scottalanmillerS
            scottalanmiller
            last edited by

            It's all in the anacron config file:

            # /etc/anacrontab: configuration file for anacron
            
            # See anacron(8) and anacrontab(5) for details.
            
            SHELL=/bin/sh
            PATH=/sbin:/bin:/usr/sbin:/usr/bin
            MAILTO=root
            # the maximal random delay added to the base delay of the jobs
            RANDOM_DELAY=45
            # the jobs will be started during the following hours only
            START_HOURS_RANGE=3-22
            
            #period in days   delay in minutes   job-identifier   command
            1       5       cron.daily              nice run-parts /etc/cron.daily
            7       25      cron.weekly             nice run-parts /etc/cron.weekly
            @monthly 45     cron.monthly            nice run-parts /etc/cron.monthly
            
            matteo nunziatiM 1 Reply Last reply Reply Quote 1
            • matteo nunziatiM
              matteo nunziati
              last edited by

              the anacron man page says:

              quote:
              For each job, Anacron checks whether this job has been executed in the last n days, where n is the period specified for that job. If not, Anacron runs the job's shell command, after waiting for the number of minutes specified as the delay parameter.

              After the command exits, Anacron records the date in a special timestamp file for that job, so it can know when to execute it again. Only the date is used for the time calculations. The hour is not used.

              1 Reply Last reply Reply Quote 0
              • scottalanmillerS
                scottalanmiller
                last edited by

                It's partially random, and partial a "delay by days." It would vary based on factors such as "when the server was built."

                matteo nunziatiM 1 Reply Last reply Reply Quote 0
                • matteo nunziatiM
                  matteo nunziati @scottalanmiller
                  last edited by

                  @scottalanmiller it is not 🙂 it says anacron runs every 7 days. but which is the 7th day???? why friday not saturday?

                  scottalanmillerS 1 Reply Last reply Reply Quote 0
                  • matteo nunziatiM
                    matteo nunziati @scottalanmiller
                    last edited by

                    @scottalanmiller so I've built that server on a friday maybe... don't remember...

                    scottalanmillerS 1 Reply Last reply Reply Quote 0
                    • scottalanmillerS
                      scottalanmiller @matteo nunziati
                      last edited by

                      @matteo-nunziati said in Anacron Jobs on a CentOS 7 Server:

                      @scottalanmiller it is not 🙂 it says anacron runs every 7 days. but which is the 7th day???? why friday not saturday?

                      Seven days after the process first kicks off 🙂

                      1 Reply Last reply Reply Quote 0
                      • scottalanmillerS
                        scottalanmiller @matteo nunziati
                        last edited by

                        @matteo-nunziati said in Anacron Jobs on a CentOS 7 Server:

                        @scottalanmiller so I've built that server on a friday maybe... don't remember...

                        That's likely the case.

                        matteo nunziatiM 1 Reply Last reply Reply Quote 1
                        • matteo nunziatiM
                          matteo nunziati @scottalanmiller
                          last edited by

                          @scottalanmiller I can't imagine there is no way to force a proper restart an a given day-of-week. again: weird.

                          scottalanmillerS 1 Reply Last reply Reply Quote 0
                          • matteo nunziatiM
                            matteo nunziati
                            last edited by

                            from the man page:
                            /var/spool/anacron
                            This directory is used by Anacron for storing timestamp files.

                            let's check those files 😉

                            1 Reply Last reply Reply Quote 1
                            • scottalanmillerS
                              scottalanmiller @matteo nunziati
                              last edited by

                              @matteo-nunziati said in Anacron Jobs on a CentOS 7 Server:

                              @scottalanmiller I can't imagine there is no way to force a proper restart an a given day-of-week. again: weird.

                              Probably just the wrong tool for the job. There is already a tool specifically for that.

                              1 Reply Last reply Reply Quote 1
                              • matteo nunziatiM
                                matteo nunziati
                                last edited by

                                well yes, simply it sounds weird to me that an enterprise distro per default uses what is basically a fuzzy job scheduler.
                                forcing jobs via cron is trivial, but I was courious about the default behavior and the rational behind it. this is simply not the case on debian based distros.
                                Next time I will check on Suse.

                                scottalanmillerS 1 Reply Last reply Reply Quote 0
                                • scottalanmillerS
                                  scottalanmiller @matteo nunziati
                                  last edited by

                                  @matteo-nunziati said in Anacron Jobs on a CentOS 7 Server:

                                  well yes, simply it sounds weird to me that an enterprise distro per default uses what is basically a fuzzy job scheduler.

                                  What makes it "by default?" When I use it "by default" it doesn't do that for me 🙂 It uses a strict scheduler. I have to go into the lesser known intentionally fuzzy scheduler to get the fuzzy system.

                                  matteo nunziatiM 1 Reply Last reply Reply Quote 1
                                  • scottalanmillerS
                                    scottalanmiller
                                    last edited by

                                    AFAIK, the purpose behind the daily, weekly, monthly tabs is specifically to be fuzzy. It would make no sense to me otherwise since we have a strict scheduler already. It would make efforts duplicated without benefit if it wasn't fuzzy. And it would then require additional configuration to get the functionality that it currently gets by de fault.

                                    1 Reply Last reply Reply Quote 1
                                    • matteo nunziatiM
                                      matteo nunziati @scottalanmiller
                                      last edited by matteo nunziati

                                      @scottalanmiller it is default because in the default install the crontab is empty and cron.daily, cron.weekly etc.. are all delegated to anacron. And these folders are already populated with distro "native" jobs, which run basically at random days, depending on when you have installed the machine.

                                      It is counter intuitive to me: they can run, they are scheduled to run, but you can not control exactly in which day. weird.
                                      In ubuntu I put scripts in daily/weekly and so and then I know when the trigger starts (ok neglect the fuzzification of delays) because anacron is declared in the crontab.

                                      This is not the case with centos.

                                      I find the folders really useful to collect scripts I want to run at given time deltas (e.g. backups...) I'm not used to set a crontab line for each job, as I tend to collect jobs on daily or weekly intervals.
                                      It is a non issue but still a strange default.

                                      scottalanmillerS 2 Replies Last reply Reply Quote 0
                                      • scottalanmillerS
                                        scottalanmiller @matteo nunziati
                                        last edited by

                                        @matteo-nunziati said in Anacron Jobs on a CentOS 7 Server:

                                        @scottalanmiller it is default because in the default install the crontab is empty and cron.daily, cron.weekly etc.. are all delegated to anacron. And these folders are already populated with distro "native" jobs, which run basically at random days, depending on when you have installed the machine.

                                        I don't agree that that makes one default and one not. When you as a user run the crontab command, it does not give you those. Those are relegated for manual administration work. That they are prepopulated fuzzy tasks is because those tasks are supposed to be fuzzy by default. If they were specific, they'd have to choose specific times for them which would be unnecessarily odd. For putting in your own jobs, the user crontab is definitely considered the default or standard path for that. It is empty because the system does not do "specifically timed maintenance" because it wouldn't know when to do it.

                                        1 Reply Last reply Reply Quote 0
                                        • scottalanmillerS
                                          scottalanmiller @matteo nunziati
                                          last edited by

                                          @matteo-nunziati said in Anacron Jobs on a CentOS 7 Server:

                                          I find the folders really useful to collect script I want to run at given time deltas (e.g. backups...) I'm not used to set a crontab line for each job, as I tend to collect jobs on daily or weekly intervals.
                                          It is a non issue but still a strange default.

                                          I feel the opposite, Ubuntu seems strange to have two systems that overlap. Why would they do that? Seems very silly. You already have places for things, why have two of them?

                                          1 Reply Last reply Reply Quote 0
                                          • matteo nunziatiM
                                            matteo nunziati
                                            last edited by

                                            sorry I've badly worded it.
                                            In ubuntu/debian they per default schedule cron.{daily,weekly,monthly} in crontab and they run at specific days/weeks.
                                            anacron is not there. you have to install it. it is not the default, and jumps in only if you install it!

                                            utente@debian:/etc$ cat crontab
                                            #/etc/crontab: system-wide crontab
                                            #Unlike any other crontab you don't have to run the `crontab'
                                            #command to install the new version when you edit this file
                                            #and files in /etc/cron.d. These files also have username fields,
                                            #that none of the other crontabs do.

                                            SHELL=/bin/sh
                                            PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin

                                            #m h dom mon dow user command
                                            17 * * * * root cd / && run-parts --report /etc/cron.hourly
                                            25 6 * * * root test -x /usr/sbin/anacron || ( cd / && run-parts --report /etc/cron.daily )
                                            47 6 * * 7 root test -x /usr/sbin/anacron || ( cd / && run-parts --report /etc/cron.weekly )
                                            52 6 1 * * root test -x /usr/sbin/anacron || ( cd / && run-parts --report /etc/cron.monthly )

                                            by default debian is deterministic while centos is fuzzy. while in either case the distro default makes your scripts run, their approach is different.

                                            1 Reply Last reply Reply Quote 0
                                            • 1
                                            • 2
                                            • 1 / 2
                                            • First post
                                              Last post