Giter Site home page Giter Site logo

proxmox-encrypted-remote-backup's People

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar

proxmox-encrypted-remote-backup's Issues

Not working within Proxmox 7 - KeyError: 'TARFILE'

Upgraded to Proxmox 7 and backup is failing with an error: INFO: KeyError: 'TARFILE'

Reason: "Hookscript: The TARFILE environment variable was deprecated in Proxmox VE 6, in favor of TARGET. In Proxmox VE 7, it has been removed entirely and thus, it is not exported to the hookscript anymore." (https://pve.proxmox.com/wiki/Roadmap)

Solution: Change ProxmoxEventHandler.py line #153 from tarfile = os.environ["TARFILE"] to tarfile = os.environ["TARGET"]

Now its working again

Script stopped working due to changed phase name

Reference: https://forum.proxmox.com/threads/info-backup-exit-code-255-vzdump-mit-hook-script.107163/#post-460678

A new backup phase 'job-init' was added to pve-manager and causes the Encrypted-Remote-Backup to stop with an error due to the new unkown phase. It worked again after adding the new phase and changing the phase 'job-start' in ProxmoxEventHandler.py. DUMPDIR is not defined in phase 'job-init' except when --dumpdir is used directly

if self.args.phase == 'job-init':

            storeid = os.environ["STOREID"]

            self.jobinfo[self.args.phase].append(
                {
                    'storeid': storeid
                }
            )

            logging.debug("Environment Variables:" + str(self.jobinfo[self.args.phase]))

            if os.path.isfile(self.jobFilePath):
                logging.error("Existing job file found: " + self.jobFilePath)
                sys.exit(1)

            with open(self.jobFilePath, 'w') as outfile:
                logging.info("Creating new job file:" + self.jobFilePath)
                json.dump(self.jobinfo, outfile)

            return self.args.phase

        elif self.args.phase == 'job-start':

            dumpdir = os.environ["DUMPDIR"]
            storeid = os.environ["STOREID"]

            logging.debug("Environment Variables:" + str(self.jobinfo[self.args.phase]))

            if os.path.isfile(self.jobFilePath) is False:
                logging.error("Existing job file not found: " + self.jobFilePath)
                sys.exit(1)

            with open(self.jobFilePath) as json_file:
                logging.info("Parsing existing job file:" + self.jobFilePath)
                self.jobinfo = json.load(json_file)


            self.jobinfo[self.args.phase] = {
                    'dumpdir': dumpdir,
                    'storeid': storeid
                }


            logging.debug("Environment Variables:" + str(self.jobinfo[self.args.phase]))

            with open(self.jobFilePath, 'w') as outfile:
                logging.info("Updating existing job file:" + self.jobFilePath)
                json.dump(self.jobinfo, outfile)

            return self.args.phase

TypeError: 'NoneType' object is not subscriptable

When I start the backup it will show the following error:

INFO: Traceback (most recent call last):
INFO:   File "/opt/scripting/encryptedRemoteBackup/ProxmoxEncryptedBackup.py", line 118, in <module>
INFO:     outputFilename = re.search("vzdump-qemu-(.*)\.\w*?$", index["tarfile"])[1]
INFO: TypeError: 'NoneType' object is not subscriptable

How do I solve the problem?

Full Log:

INFO: starting new backup job: vzdump 104 --compress lzo --script /opt/scripting/encryptedRemoteBackup/ProxmoxEncryptedBackup.py --quiet 1 --storage LocalBackup --all 0 --mailnotification failure --mode snapshot --node homerserver
INFO: CryptBackup - INFO - Encrypted BackupScript called
INFO: CryptBackup - INFO - Job File:/opt/scripting/encryptedRemoteBackup/jobs/31315.job
INFO: CryptBackup - INFO - Phase:job-start
INFO: CryptBackup - INFO - Creating new job file:/opt/scripting/encryptedRemoteBackup/jobs/31315.job
INFO: Starting Backup of VM 104 (lxc)
INFO: Backup started at 2020-04-25 22:43:46
INFO: status = running
INFO: CT Name: Pihole
INFO: backup mode: snapshot
INFO: ionice priority: 7
INFO: CryptBackup - INFO - Encrypted BackupScript called
INFO: CryptBackup - INFO - Job File:/opt/scripting/encryptedRemoteBackup/jobs/31315.job
INFO: CryptBackup - INFO - Phase:backup-start
INFO: CryptBackup - INFO - Parsing existing job file:/opt/scripting/encryptedRemoteBackup/jobs/31315.job
INFO: CryptBackup - INFO - Updating existing job file:/opt/scripting/encryptedRemoteBackup/jobs/31315.job
INFO: CryptBackup - INFO - Encrypted BackupScript called
INFO: CryptBackup - INFO - Job File:/opt/scripting/encryptedRemoteBackup/jobs/31315.job
INFO: CryptBackup - INFO - Phase:pre-stop
INFO: CryptBackup - INFO - Parsing existing job file:/opt/scripting/encryptedRemoteBackup/jobs/31315.job
INFO: CryptBackup - INFO - Updating existing job file:/opt/scripting/encryptedRemoteBackup/jobs/31315.job
INFO: create storage snapshot 'vzdump'
  Logical volume "snap_vm-104-disk-0_vzdump" created.
INFO: CryptBackup - INFO - Encrypted BackupScript called
INFO: CryptBackup - INFO - Job File:/opt/scripting/encryptedRemoteBackup/jobs/31315.job
INFO: CryptBackup - INFO - Phase:pre-restart
INFO: CryptBackup - INFO - Parsing existing job file:/opt/scripting/encryptedRemoteBackup/jobs/31315.job
INFO: CryptBackup - INFO - Updating existing job file:/opt/scripting/encryptedRemoteBackup/jobs/31315.job
INFO: CryptBackup - INFO - Encrypted BackupScript called
INFO: CryptBackup - INFO - Job File:/opt/scripting/encryptedRemoteBackup/jobs/31315.job
INFO: CryptBackup - INFO - Phase:post-restart
INFO: CryptBackup - INFO - Parsing existing job file:/opt/scripting/encryptedRemoteBackup/jobs/31315.job
INFO: CryptBackup - INFO - Updating existing job file:/opt/scripting/encryptedRemoteBackup/jobs/31315.job
INFO: creating archive '/mnt/pve/LocalBackup/dump/vzdump-lxc-104-2020_04_25-22_43_46.tar.lzo'
INFO: Total bytes written: 1659904000 (1.6GiB, 140MiB/s)
INFO: archive file size: 638MB
INFO: delete old backup '/mnt/pve/LocalBackup/dump/vzdump-lxc-104-2020_04_25-22_42_30.tar.lzo'
INFO: CryptBackup - INFO - Encrypted BackupScript called
INFO: CryptBackup - INFO - Job File:/opt/scripting/encryptedRemoteBackup/jobs/31315.job
INFO: CryptBackup - INFO - Phase:backup-end
INFO: CryptBackup - INFO - Parsing existing job file:/opt/scripting/encryptedRemoteBackup/jobs/31315.job
INFO: CryptBackup - INFO - Updating existing job file:/opt/scripting/encryptedRemoteBackup/jobs/31315.job
INFO: remove vzdump snapshot
  Logical volume "snap_vm-104-disk-0_vzdump" successfully removed
INFO: Finished Backup of VM 104 (00:00:13)
INFO: Backup finished at 2020-04-25 22:43:59
INFO: CryptBackup - INFO - Encrypted BackupScript called
INFO: CryptBackup - INFO - Job File:/opt/scripting/encryptedRemoteBackup/jobs/31315.job
INFO: CryptBackup - INFO - Phase:log-end
INFO: CryptBackup - INFO - Parsing existing job file:/opt/scripting/encryptedRemoteBackup/jobs/31315.job
INFO: CryptBackup - INFO - Updating existing job file:/opt/scripting/encryptedRemoteBackup/jobs/31315.job
INFO: CryptBackup - INFO - Encrypted BackupScript called
INFO: CryptBackup - INFO - Job File:/opt/scripting/encryptedRemoteBackup/jobs/31315.job
INFO: CryptBackup - INFO - Phase:job-end
INFO: CryptBackup - INFO - Parsing existing job file:/opt/scripting/encryptedRemoteBackup/jobs/31315.job
INFO: CryptBackup - INFO - Updating existing job file:/opt/scripting/encryptedRemoteBackup/jobs/31315.job
INFO: CryptBackup - INFO - The backup job has ended successfully, will prepare to encrypt
INFO: Traceback (most recent call last):
INFO:   File "/opt/scripting/encryptedRemoteBackup/ProxmoxEncryptedBackup.py", line 118, in <module>
INFO:     outputFilename = re.search("vzdump-qemu-(.*)\.\w*?$", index["tarfile"])[1]
INFO: TypeError: 'NoneType' object is not subscriptable
INFO: CryptBackup - INFO - Encrypted BackupScript called
INFO: CryptBackup - INFO - Job File:/opt/scripting/encryptedRemoteBackup/jobs/31315.job
INFO: CryptBackup - INFO - Phase:job-abort
INFO: CryptBackup - INFO - Parsing existing job file:/opt/scripting/encryptedRemoteBackup/jobs/31315.job
INFO: CryptBackup - INFO - Updating job file:/opt/scripting/encryptedRemoteBackup/jobs/31315.job
ERROR: Backup job failed - command '/opt/scripting/encryptedRemoteBackup/ProxmoxEncryptedBackup.py job-end' failed: exit code 1
TASK ERROR: command '/opt/scripting/encryptedRemoteBackup/ProxmoxEncryptedBackup.py job-end' failed: exit code 1

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.