Exécuter le fichier de commandes via le planificateur Windows 7 pour renommer le dossier sur le lecteur réseau


2

J'essaie de faire ce que je croyais être très simple: avoir un .bat fichier qui renomme deux dossiers sur un lecteur réseau. Le script fonctionne correctement lorsqu'il est exécuté à partir de l'invite, mais pas à partir du planificateur. Des idées pourquoi?

Installer

Lecteur réseau \\NAS\Backup cartographié comme B:

Dossiers en Backup cela devrait être renommé: Current et Previous

  • \\ NAS \ Backup \ Current
  • \\ NAS \ Backup \ Précédent

Tâche XML

<?xml version="1.0" encoding="UTF-16"?>
<Task version="1.3" xmlns="http://schemas.microsoft.com/windows/2004/02/mit/task">
  <RegistrationInfo>
    <Date>2013-12-12T16:01:26.5634611</Date>
    <Author>nivis-server\nivis</Author>
  </RegistrationInfo>
  <Triggers>
    <CalendarTrigger>
      <StartBoundary>2013-12-12T00:00:05</StartBoundary>
      <Enabled>true</Enabled>
      <ScheduleByWeek>
        <DaysOfWeek>
          <Saturday />
        </DaysOfWeek>
        <WeeksInterval>1</WeeksInterval>
      </ScheduleByWeek>
    </CalendarTrigger>
  </Triggers>
  <Principals>
    <Principal id="Author">
      <UserId>nivis</UserId>
      <LogonType>Password</LogonType>
      <RunLevel>HighestAvailable</RunLevel>
    </Principal>
  </Principals>
  <Settings>
    <MultipleInstancesPolicy>IgnoreNew</MultipleInstancesPolicy>
    <DisallowStartIfOnBatteries>true</DisallowStartIfOnBatteries>
    <StopIfGoingOnBatteries>true</StopIfGoingOnBatteries>
    <AllowHardTerminate>true</AllowHardTerminate>
    <StartWhenAvailable>false</StartWhenAvailable>
    <RunOnlyIfNetworkAvailable>false</RunOnlyIfNetworkAvailable>
    <IdleSettings>
      <StopOnIdleEnd>true</StopOnIdleEnd>
      <RestartOnIdle>false</RestartOnIdle>
    </IdleSettings>
    <AllowStartOnDemand>true</AllowStartOnDemand>
    <Enabled>true</Enabled>
    <Hidden>false</Hidden>
    <RunOnlyIfIdle>false</RunOnlyIfIdle>
    <DisallowStartOnRemoteAppSession>false</DisallowStartOnRemoteAppSession>
    <UseUnifiedSchedulingEngine>false</UseUnifiedSchedulingEngine>
    <WakeToRun>false</WakeToRun>
    <ExecutionTimeLimit>P3D</ExecutionTimeLimit>
    <Priority>7</Priority>
  </Settings>
  <Actions Context="Author">
    <Exec>
      <Command>C:\script\SwitchNivisCurrent.bat</Command>
      <Arguments>&gt; execution.log</Arguments>
      <WorkingDirectory>C:\script</WorkingDirectory>
    </Exec>
  </Actions>
</Task>

Scénario

Situé dans c:\script

rename B:\Current tmp
rename B:\Previous Current
rename B:\tmp Previous



========== MISE À JOUR: Solution - gracieuseté de techie007 ==========

techie007 a fourni la solution et le script se présente désormais comme suit:

net use x: \\10.22.0.105\nivis-nas ****PWD**** /user:nivis

x:

rename Current tmp
rename Previous Current
rename tmp Previous

net use x: /d

Réponses:


2

Quelques choses à considérer:

  1. Il peut s’exécuter dans un contexte utilisateur ("nivis") qui n’a pas accès à cet emplacement réseau.
  2. Les cartes de lecteur sont centrées sur l'utilisateur et la session. La carte B: peut ne pas exister pour l'utilisateur / la session dans laquelle la tâche est exécutée.

Pour 1: Assurez-vous que l'utilisateur en cours d'exécution dispose d'un accès en écriture / modification au partage et aux dossiers / fichiers sous-jacents que vous souhaitez modifier.

Pour 2: modifiez le fichier de commandes pour mapper B: vers l'emplacement réseau ( net use ) au début, puis décompressez-le à la fin. Vous pouvez également référencer le partage réseau par UNC ( \\servername\sharename ) au lieu d'utiliser un lecteur mappé.


# 2 ici est important. Un bon exemple de ceci serait le mappage d'un lecteur dans l'Explorateur, puis le démarrage d'une invite de commande administrateur - notez que les mappages de lecteur n'existent pas dans ce contexte.
ernie

1
J'ai essayé votre deuxième proposition et cela a fonctionné. Merci!
nivis
En utilisant notre site, vous reconnaissez avoir lu et compris notre politique liée aux cookies et notre politique de confidentialité.
Licensed under cc by-sa 3.0 with attribution required.