XCP-ng
    • Categories
    • Recent
    • Tags
    • Popular
    • Users
    • Groups
    • Register
    • Login

    Error mirroring full backups to backblaze b2

    Scheduled Pinned Locked Moved Backup
    11 Posts 3 Posters 232 Views 3 Watching
    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.
    • poddingueP Online
      poddingue Vates 🪐 @pedro_udifar
      last edited by

      Thanks for the detailed write-up, Pedro.
      I'm not a backup expert, far from it. but you might be right that https://github.com/vatesfr/xen-orchestra/pull/9396 only fixed the size estimation for direct full backups, not the mirror path. 🤔
      Your error is the same as the maximum size allowed one, just twelve bytes over 209715200000. Before this turns into a GitHub issue, it would help to know whether it reproduces on a fresh mirror job and whether bumping minPartSize actually cleared it, so we can be sure it's the mirror code and not the B2 remote settings.
      The object storage docs list Backblaze B2 as supported (https://docs.xen-orchestra.com/xo5/object-storage-support#supported-storage-providers) but don't say much about part-size tuning.
      If it's awkward to test in isolation, a mention to @Team-XO-Backend is probably the quickest route, since they own the backup job code.
      The XVA checksum warnings in your second screenshot look like a separate non-blocking clean VM directory step rather than the cause.
      I hope that points somewhere useful! 🤞

      fbeauchamp opened this pull request in vatesfr/xen-orchestra

      closed fix(backups): size estimation of full backups #9396

      florentF 1 Reply Last reply Reply Quote 2
      • florentF Online
        florent Vates 🪐 XO Team @poddingue
        last edited by

        @poddingue said:

        Thanks for the detailed write-up, Pedro.
        I'm not a backup expert, far from it. but you might be right that https://github.com/vatesfr/xen-orchestra/pull/9396 only fixed the size estimation for direct full backups, not the mirror path. 🤔
        Your error is the same as the maximum size allowed one, just twelve bytes over 209715200000. Before this turns into a GitHub issue, it would help to know whether it reproduces on a fresh mirror job and whether bumping minPartSize actually cleared it, so we can be sure it's the mirror code and not the B2 remote settings.
        The object storage docs list Backblaze B2 as supported (https://docs.xen-orchestra.com/xo5/object-storage-support#supported-storage-providers) but don't say much about part-size tuning.
        If it's awkward to test in isolation, a mention to @Team-XO-Backend is probably the quickest route, since they own the backup job code.
        The XVA checksum warnings in your second screenshot look like a separate non-blocking clean VM directory step rather than the cause.
        I hope that points somewhere useful! 🤞

        nice catch
        and the mirror path is easier to fix . Thaks @pedro_udifar and @poddingue we will fix it asap

        will it be possible to test a potential fix @pedro_udifar , since it's often specific to a provider ( and need huge VM to work )?

        florentF 1 Reply Last reply Reply Quote 2
        • florentF Online
          florent Vates 🪐 XO Team @florent
          last edited by

          now that I am in front of the source code , it is already getting the real size, so it should compute the right size

          are the source or destination encrypted ?

          florentF 1 Reply Last reply Reply Quote 0
          • florentF Online
            florent Vates 🪐 XO Team @florent
            last edited by

            @pedro_udifar we have found a clue , if the destination is encrypted and the source is not

            can you test this branch ? https://github.com/vatesfr/xen-orchestra/pull/10061
            if you are using a xoa, we can deploy the fix if you open a support tunnel

            fbeauchamp opened this pull request in vatesfr/xen-orchestra

            open fix(fs): compute the output stream precisely when encrypted #10061

            1 Reply Last reply Reply Quote 2
            • P Offline
              pedro_udifar
              last edited by

              Hello Poddingue and Florent,

              I started duplicating "default" minPartSize but the larger VMs we're still failing to mirror. After that, I found that Bacblaze has a recommended chunk size of minPartSize=100000000 and, with this setting, all my VMs completed without that specific error.
              (My largest VM compressed backup is about 450 GB)

              31fe31fc-9b8e-4b7d-b960-1b1f711a4901-image.jpeg
              https://www.backblaze.com/docs/cloud-storage-large-files
              In my case, the recommendPartSize returned was 100000000.

              Since I was also getting the other warnings "Issue checking XVA" and "XVA might be broken", most o f the times I would wipe de backblaze bucket and start with a new job no XO (so that I could be sure it was not about the retention settings of this mirror job).

              Replication source is on a local NFS Ztsd compressed, not encripted.
              Replication destinations is Backblaze with encription. Object lock is turned off (XO can delete and change the files without restrictions)

              I'm still getting the XVA warnings and my next step was to run a test turning encription on, on the local 1st tier nfs remote.

              The sizes reported locally and on backblaze have very different sizes, which I guess is to be expected on this scenario.

              Local:
              839a2c6d-3f6c-44fe-8319-d0a54ed9188d-image.jpeg

              Backblaze:
              11eecec4-7d90-4216-b891-7f881c8421c8-image.jpeg

              In my planned backup pipeline, I am planning to turn on object lock on backblaze, making sure it's aligned with mirror retention settings on XO thoug I'm not sure this will work nice with metadata json files. What do you guys think?

              I'll gladly test the fix when it's ready. Is already commited?

              Thank you for your help,
              Pedro

              florentF 1 Reply Last reply Reply Quote 0
              • florentF Online
                florent Vates 🪐 XO Team @pedro_udifar
                last edited by

                @pedro_udifar object lock works quite well with xo
                it is automatically detected if the s3 user has enough privilege to see if object lock is enabled

                the main point is that it won't create "cache.json.gz" files since theses files must be updated, so the backup listing is a little slower

                note that XO retention should be at least 1 more than object lock . At worst you will have error , saying that XO coudn't delete an old backup

                The fix is on a separated branch : fix_s3_nonencrypted_to_encrypted_xva ( PR : https://github.com/vatesfr/xen-orchestra/pull/10061 )

                fbeauchamp opened this pull request in vatesfr/xen-orchestra

                open fix(fs): compute the output stream precisely when encrypted #10061

                1 Reply Last reply Reply Quote 0
                • P Offline
                  pedro_udifar
                  last edited by

                  @florent said:

                  fix_s3_nonencrypted_to_encrypted_xva

                  Hello Florent,

                  Branch built and testing
                  Test procedure: removed the minPartSize=100000000 from remote definition, deleted the b2 backup and restarted the mirror backup. There are some other VMs that will also be uploaded to B2 so it will take a while. Expect feedback tomorrow.

                  Thank you,
                  Pedro

                  1 Reply Last reply Reply Quote 2
                  • P Offline
                    pedro_udifar
                    last edited by

                    Still getting these warnings, on the VMs that don't need to be uploaded. Thought this might go away also.

                    838c12d7-315d-4e4d-bc76-acb4dd9e74d9-image.jpeg

                    1 Reply Last reply Reply Quote 0
                    • P Offline
                      pedro_udifar
                      last edited by

                      Hello Florent,

                      The new code is still failing...

                      a7b27068-0bbb-4ea6-b0e7-74f8058775f3-image.jpeg

                      	```
                      	{
                      		"id": "0mr3li2kt-c10ifxuuw68",
                      		"start": 1783002246797,
                      		"status": "failure",
                      		"tasks": [
                      			{
                      				"id": "0mr3li2ud-r1vgn4rnv5d",
                      				"start": 1783002247141,
                      				"status": "failure",
                      				"tasks": [
                      					{
                      						"id": "0mr3li30l-6n1cr5a6o7v",
                      						"start": 1783002247365,
                      						"status": "failure",
                      						"end": 1783004124397,
                      						"result": {
                      							"message": "read 52428800012 bytes, maximum size allowed  is 52428800000 ",
                      							"name": "Error",
                      							"stack": "Error: read 52428800012 bytes, maximum size allowed  is 52428800000 \n    at Transform.transform [as _transform] (/opt/xo/xo-builds/xen-orchestra-202607021439/@xen-orchestra/fs/dist/s3.js:214:20)\n    at Transform._write (node:internal/streams/transform:171:8)\n    at writeOrBuffer (node:internal/streams/writable:570:12)\n    at _write (node:internal/streams/writable:499:10)\n    at Writable.write (node:internal/streams/writable:508:10)\n    at PassThrough.ondata (node:internal/streams/readable:1012:24)\n    at PassThrough.emit (node:events:509:28)\n    at PassThrough.patchedEmit [as emit] (/opt/xo/xo-builds/xen-orchestra-202607021439/@xen-orchestra/log/configure.js:52:17)\n    at addChunk (node:internal/streams/readable:563:12)\n    at readableAddChunkPushObjectMode (node:internal/streams/readable:540:3)"
                      						},
                      						"message": "transfer",
                      						"data": {
                      							"progress": 0
                      						}
                      					}
                      				],
                      				"end": 1783004124397,
                      				"result": {
                      					"message": "read 52428800012 bytes, maximum size allowed  is 52428800000 ",
                      					"name": "Error",
                      					"stack": "Error: read 52428800012 bytes, maximum size allowed  is 52428800000 \n    at Transform.transform [as _transform] (/opt/xo/xo-builds/xen-orchestra-202607021439/@xen-orchestra/fs/dist/s3.js:214:20)\n    at Transform._write (node:internal/streams/transform:171:8)\n    at writeOrBuffer (node:internal/streams/writable:570:12)\n    at _write (node:internal/streams/writable:499:10)\n    at Writable.write (node:internal/streams/writable:508:10)\n    at PassThrough.ondata (node:internal/streams/readable:1012:24)\n    at PassThrough.emit (node:events:509:28)\n    at PassThrough.patchedEmit [as emit] (/opt/xo/xo-builds/xen-orchestra-202607021439/@xen-orchestra/log/configure.js:52:17)\n    at addChunk (node:internal/streams/readable:563:12)\n    at readableAddChunkPushObjectMode (node:internal/streams/readable:540:3)"
                      				},
                      				"message": "export",
                      				"data": {
                      					"id": "14b59f44-4517-411e-9e39-4eb7136928d0",
                      					"type": "remote",
                      					"isFull": true
                      				}
                      			},
                      			{
                      				"id": "0mr3mmbcf-yc4lpd0z5p",
                      				"start": 1783004124399,
                      				"status": "success",
                      				"warnings": [
                      					{
                      						"data": {
                      							"path": "xo-vm-backups/1c842f34-f7f8-d3cd-ba24-ffe51d6ae075/cache.json.gz",
                      							"actual": 0,
                      							"expected": 1
                      						},
                      						"message": "unexpected number of entries in backup cache"
                      					},
                      					{
                      						"data": {
                      							"error": {
                      								"generatedMessage": false,
                      								"code": "ERR_ASSERTION",
                      								"actual": true,
                      								"expected": false,
                      								"operator": "strictEqual",
                      								"diff": "simple"
                      							}
                      						},
                      						"message": "Issue while checking XVA"
                      					},
                      					{
                      						"data": {
                      							"error": {
                      								"generatedMessage": false,
                      								"code": "ERR_ASSERTION",
                      								"actual": true,
                      								"expected": false,
                      								"operator": "strictEqual",
                      								"diff": "simple"
                      							}
                      						},
                      						"message": "Checksum file not valid, not blocking"
                      					},
                      					{
                      						"data": {
                      							"path": "/xo-vm-backups/1c842f34-f7f8-d3cd-ba24-ffe51d6ae075/20260624T231818Z.xva"
                      						},
                      						"message": "XVA might be broken"
                      					},
                      					{
                      						"data": {
                      							"files": [
                      								"20260624T231818Z.json",
                      								"20260624T231818Z.xva",
                      								"20260624T231818Z.xva.checksum"
                      							]
                      						},
                      						"message": "This files may be corrupted but not yet to be removed"
                      					}
                      				],
                      				"end": 1783004124983,
                      				"result": {
                      					"merge": false,
                      					"size": 0
                      				},
                      				"message": "clean-vm"
                      			}
                      		],
                      		"end": 1783004124983,
                      		"result": {
                      			"message": "read 52428800012 bytes, maximum size allowed  is 52428800000 ",
                      			"name": "Error",
                      			"stack": "Error: read 52428800012 bytes, maximum size allowed  is 52428800000 \n    at Transform.transform [as _transform] (/opt/xo/xo-builds/xen-orchestra-202607021439/@xen-orchestra/fs/dist/s3.js:214:20)\n    at Transform._write (node:internal/streams/transform:171:8)\n    at writeOrBuffer (node:internal/streams/writable:570:12)\n    at _write (node:internal/streams/writable:499:10)\n    at Writable.write (node:internal/streams/writable:508:10)\n    at PassThrough.ondata (node:internal/streams/readable:1012:24)\n    at PassThrough.emit (node:events:509:28)\n    at PassThrough.patchedEmit [as emit] (/opt/xo/xo-builds/xen-orchestra-202607021439/@xen-orchestra/log/configure.js:52:17)\n    at addChunk (node:internal/streams/readable:563:12)\n    at readableAddChunkPushObjectMode (node:internal/streams/readable:540:3)"
                      		},
                      		"message": "backup VM",
                      		"data": {
                      			"id": "1c842f34-f7f8-d3cd-ba24-ffe51d6ae075",
                      			"type": "VM",
                      			"progress": 0
                      		}
                      	},
                      

                      Best regards,
                      Pedro

                      florentF 1 Reply Last reply Reply Quote 0
                      • florentF Online
                        florent Vates 🪐 XO Team @pedro_udifar
                        last edited by

                        @pedro_udifar that is strange that we have exactly the same error, even though we should have added 28 bytes

                        I pushed a little debug that will log additional lines in journalctl

                        'will output stream ', 'stream is encrypted' and 'stream is updated '

                        Can you update your branch, rebuild, rerun the transfer and post the log ( with the attached values ) ?

                        regards

                        1 Reply Last reply Reply Quote 0

                        Hello! It looks like you're interested in this conversation, but you don't have an account yet.

                        Getting fed up of having to scroll through the same posts each visit? When you register for an account, you'll always come back to exactly where you were before, and choose to be notified of new replies (either via email, or push notification). You'll also be able to save bookmarks and upvote posts to show your appreciation to other community members.

                        With your input, this post could be even better 💗

                        Register Login
                        • First post
                          Last post