PowerShell script exchange
Post Reply
AlexL
Service Provider
Posts: 117
Liked: 9 times
Joined: Aug 24, 2010 8:55 am
Full Name: Alex
Contact:

clone job or create new and copy settings

Post by AlexL »

I need a duplicate of a job with ALL it's specific settings and I want this duplicate to get a specific name. This could possible be done in a few ways:

#1 copy-vbrjob and with some parameter set the new name
#2 copy-vbrjob and rename the _clone1 job afterwards
#3 create a new job with the name I want and somehow duplicate all the settings of one job to the new job.
#4 ?

#1 and #2 do not seem possible, so perhaps the way to go is #3. How would I do this exactly?

Any help would be much appreciated.

Regards,
Alex
veremin
Product Manager
Posts: 20736
Liked: 2403 times
Joined: Oct 26, 2012 3:28 pm
Full Name: Vladimir Eremin
Contact:

Re: clone job or create new and copy settings

Post by veremin »

Just a quick question - what product version are you currently at? v7 or v8? Thanks.
AlexL
Service Provider
Posts: 117
Liked: 9 times
Joined: Aug 24, 2010 8:55 am
Full Name: Alex
Contact:

Re: clone job or create new and copy settings

Post by AlexL »

v8
veremin
Product Manager
Posts: 20736
Liked: 2403 times
Joined: Oct 26, 2012 3:28 pm
Full Name: Vladimir Eremin
Contact:

Re: clone job or create new and copy settings

Post by veremin »

Ok, then, option 3 seems to be the way to go. What particular setting you're willing to copy? Just general job settings, such as repository, retention, etc.? Or settings such as source objects to backup, application aware VM specific logic and so, should be copied, as well?
RubinCompServ
Service Provider
Posts: 400
Liked: 125 times
Joined: Mar 16, 2015 4:00 pm
Full Name: David Rubin
Contact:

Re: clone job or create new and copy settings

Post by RubinCompServ » 1 person likes this post

I've written a "down-and-dirty" script that I use to clone jobs to a new datastore. It looks at all the jobs on an existing datastore, disables them, renames them, then creates a clone of each with the original name but pointing at the new datastore. It does not move the data (although that shouldn't be difficult to add in, if desired). Note that the "$NewName" variable determines the new name for the original job; the way this script is written, it actually renames the old job and creates the new job with the original name, but it doesn't have to be that way:

Code: Select all

Add-PSSnapin VeeamPSSnapin
$Jobs = Get-VBRJob
$OldRepo = 'OLD REPOSITORY' # The repository that will be replaced
$NewRepo = 'NEW REPOSITORY' # The new repository for the cloned jobs

Foreach($Job in $Jobs)
{

    $RepoTarget = $Job.FindTargetRepository() # Scan all jobs on the server and check each one to see if it's on the old repo
    If ($RepoTarget.Name -eq $OldRepo)
    {
        $Job.Name
        $OldName = $Job.info.CommonInfo.Name
        $NewName = $OldName + ' (old)' # Append to the end of the original job

        $Test = Get-VBRJob -Name $NewName  # Check to see if a job already exists with the proposed new name

        If ($Test.Name -ne $null) 
        {
            Write-Host "Job already exists!"
            } else {
            $Job.info.CommonInfo.Name = $NewName
            $Job.Update() # Commit the change

            Copy-VBRJob $Job -Name $OldName -Repository $NewRepo # Clone the job with the original name and the new repo
            Disable-VBRJob -Job $Job # Disable the original job
    
            $ClonedJob = Get-VBRJob -Name $OldName
            Enable-VBRJob -Job $ClonedJob # Enable the cloned job

        }
        
    }
    
}
Post Reply

Who is online

Users browsing this forum: No registered users and 10 guests