XCP-ng
    • Categories
    • Recent
    • Tags
    • Popular
    • Users
    • Groups
    • Register
    • Login
    1. Home
    2. acebmxer
    A
    Online
    • Profile
    • Following 0
    • Followers 0
    • Topics 36
    • Posts 295
    • Groups 0

    acebmxer

    @acebmxer

    Just a person who loves hardware.

    Home lab setup
    2x AMD Host, 1x Ryzen 7950x, 1x Ryzen 7700x
    64gb ram each
    2x Intel X520-10G-2S
    #Storage
    Truenas
    AMD Ryzen 5900x
    48gb ram
    4x8TB raidz1
    1x 1tb m.2 nvme zlog
    1x1tb m.2 nvme cache drive.
    #Networking
    Unifi UDM-SE - Router
    2x Unifi Agg switch
    Unifi 24 port Enterprise poe switch

    80
    Reputation
    15
    Profile views
    295
    Posts
    0
    Followers
    0
    Following
    Joined
    Last Online
    Location New Jersey, United States

    acebmxer Unfollow Follow

    Best posts made by acebmxer

    • Migration from VMware to XCP-NG complete.

      Finally just finished our migration from VMware to XCP-NG.

      VMs - 34 mix windows server and ubuntu linux.
      Pools - 3
      Host - 6
      Dell R660 - 2
      Dell R640 - 4

      Screenshot_20260218_193945.png

      posted in Share your setup!
      A
      acebmxer
    • RE: XCP-ng 8.3 updates announcements and testing

      @olivierlambert Created new topic.

      posted in News
      A
      acebmxer
    • RE: XCP-ng 8.3 updates announcements and testing

      @rzr

      Updated my to AMD Ryzen host in my home lab. No issues with update will monitor and report back any issues.

      posted in News
      A
      acebmxer
    • Install XO from sources.

      While this project is more for myself it is open to others to use. Please use at your own risk. Double check my script before using in a production environment. I am open to suggestions and please report any issues here - https://github.com/acebmxer/install_xen_orchestra/issues

      With that said I wanted to create my own script to install XOA from sources using the information provided by https://docs.xen-orchestra.com/installation#from-the-sources. It took many tries to get it working just to see the log in screen.

      I have only tested on Ubuntu 24.04.4 as of yet.

      https://github.com/acebmxer/install_xen_orchestra

      # Xen Orchestra Installation Script
      
      Automated installation script for [Xen Orchestra](https://xen-orchestra.com/) from source, based on the [official documentation](https://docs.xen-orchestra.com/installation#from-the-sources).
      
      ## Features
      
      - Installs all required dependencies and prerequisites automatically
      - Uses Node.js 20 LTS (with npm v10)
      - Yarn package manager installed globally
      - Self-signed SSL certificate generation for HTTPS
      - Direct port binding (80 and 443) - no proxy required
      - Systemd service for automatic startup
      - Update functionality with commit comparison
      - Automatic backups before updates (keeps last 5)
      - Interactive restore from any available backup
      - Rebuild functionality — fresh clone + clean build on the current branch, preserves settings
      - Configurable via simple config file
      - **Customizable service user** - run as any username or root, defaults to 'xo'
      - **Automatic swap space management** - creates 2GB swap if needed for builds
      - **NFS mount support** - automatically configures sudo permissions for remote storage
      - **Memory-efficient builds** - prevents out-of-memory errors on low-RAM systems
      
      ## Quick Start
      
      ### 1. Clone this repository
      
      ```bash
      git clone https://github.com/acebmxer/install_xen_orchestra.git
      cd install_xen_orchestra
      

      2. Configure the installation

      Copy the sample configuration file and customize it:

      cp sample-xo-config.cfg xo-config.cfg
      

      Edit xo-config.cfg with your preferred settings:

      nano xo-config.cfg
      

      Note: If xo-config.cfg is not found when running the script, it will automatically be created from sample-xo-config.cfg with default settings.

      3. Run the installation

      Important: Do NOT run this script with sudo. Run as a normal user with sudo privileges - the script will use sudo internally for commands that require elevated permissions.

      ./install-xen-orchestra.sh
      

      Configuration Options

      The xo-config.cfg file supports the following options:

      Option Default Description
      HTTP_PORT 80 HTTP port for web interface
      HTTPS_PORT 443 HTTPS port for web interface
      INSTALL_DIR /opt/xen-orchestra Installation directory
      SSL_CERT_DIR /etc/ssl/xo SSL certificate directory
      SSL_CERT_FILE xo-cert.pem SSL certificate filename
      SSL_KEY_FILE xo-key.pem SSL private key filename
      GIT_BRANCH master Git branch (master, stable, or tag)
      BACKUP_DIR /opt/xo-backups Backup directory for updates
      BACKUP_KEEP 5 Number of backups to retain
      NODE_VERSION 20 Node.js major version
      SERVICE_USER xo Service user (any username, leave empty for root)
      DEBUG_MODE false Enable debug logging

      Updating Xen Orchestra

      To update an existing installation:

      ./install-xen-orchestra.sh --update
      

      The update process will:

      1. Compare the installed commit with the latest from GitHub
      2. Skip if already up to date
      3. Create a backup of the current installation
      4. Pull the latest changes
      5. Rebuild Xen Orchestra
      6. Restart the service

      Backup Management

      • Backups are stored in BACKUP_DIR (default: /opt/xo-backups)
      • Only the last BACKUP_KEEP backups are retained (default: 5)
      • Older backups are automatically purged before each new backup is created
      • Backup folder names are timestamped in UTC; dates and times are displayed converted to the local system timezone
      • When restoring, backups are listed newest first — [1] is the most recent, [5] is the oldest

      Restoring from Backup

      To restore a previous installation:

      ./install-xen-orchestra.sh --restore
      

      The restore process will:

      1. List all available backups newest first (1 = newest, 5 = oldest) with their dates and commit hashes
      2. Prompt you to select which backup to restore
      3. Ask for confirmation before making any changes
      4. Stop the running service
      5. Replace the current installation with the selected backup
      6. Rebuild Xen Orchestra (node_modules are excluded from backups to save space)
      7. Restart the service and report the restored commit hash

      Example output:

      ==============================================
        Available Backups
      ==============================================
      
        [1] xo-backup-20260221_233000  (2026-02-21 06:30:00 PM EST)  commit: a1b2c3d4e5f6 (newest)
        [2] xo-backup-20260221_141500  (2026-02-21 09:15:00 AM EST)  commit: 9f8e7d6c5b4a
        [3] xo-backup-20260220_162000  (2026-02-20 11:20:00 AM EST)  commit: 1a2b3c4d5e6f
        [4] xo-backup-20260219_225200  (2026-02-19 05:52:00 PM EST)  commit: 3c4d5e6f7a8b
        [5] xo-backup-20260219_133000  (2026-02-19 08:30:00 AM EST)  commit: 7d8e9f0a1b2c (oldest)
      
      Enter the number of the backup to restore [1-5], or 'q' to quit:
      

      After a successful restore the confirmed commit is displayed:

      [SUCCESS] Restore completed successfully!
      [INFO]    Restored commit: a1b2c3d4e5f6
      

      Rebuilding Xen Orchestra

      If your installation becomes corrupted or broken, use --rebuild to do a fresh clone and clean build of your current branch without losing any settings:

      ./install-xen-orchestra.sh --rebuild
      

      The rebuild process will:

      1. Detect the currently installed branch
      2. Display a summary and ask for confirmation
      3. Stop the running service
      4. Create a backup of the current installation (same as --update — saved to BACKUP_DIR)
      5. Remove the current INSTALL_DIR and do a fresh git clone of the same branch
      6. Perform a clean build (turbo cache cleared)
      7. Restart the service and report the new commit hash

      Note: Settings stored in /etc/xo-server (config.toml) and /var/lib/xo-server (databases and state) are not touched during a rebuild, so all your connections, users, and configuration are preserved.

      Service Management

      After installation, Xen Orchestra runs as a systemd service:

      # Start the service
      sudo systemctl start xo-server
      
      # Stop the service
      sudo systemctl stop xo-server
      
      # Check status
      sudo systemctl status xo-server
      
      # View logs
      sudo journalctl -u xo-server -f
      

      Accessing Xen Orchestra

      After installation, access the web interface:

      • HTTP: http://your-server-ip
      • HTTPS: https://your-server-ip

      Note: If you changed HTTP_PORT or HTTPS_PORT in xo-config.cfg from the defaults (80/443), append the port to the URL — e.g. http://your-server-ip:8080

      Default Credentials

      • Username: admin@admin.net
      • Password: admin

      Warning: Change the default password immediately after first login!

      Switching Branches

      To switch to a different branch (e.g., from master to stable😞

      1. Edit xo-config.cfg and change GIT_BRANCH
      2. Run the update:
      ./install-xen-orchestra.sh --update
      

      The script will automatically fetch and checkout the new branch during the update process.

      System Requirements

      Minimum Hardware

      • RAM: 2GB minimum (4GB+ recommended for building)
      • Disk: 10GB free space
      • CPU: 1 core minimum (2+ recommended)

      Note: The script automatically creates 2GB swap space if insufficient memory is detected during builds to prevent out-of-memory errors.

      Dependencies

      The script automatically installs all required dependencies:

      Debian/Ubuntu:

      • apt-transport-https, ca-certificates, libcap2-bin, curl, gnupg
      • build-essential, git, patch, sudo
      • Node.js v20 (with npm v10), yarn
      • redis-server
      • python3-minimal, libpng-dev
      • lvm2, cifs-utils, nfs-common, ntfs-3g
      • libvhdi-utils, dmidecode
      • libfuse2t64 (or libfuse2 on older systems)
      • software-properties-common (Ubuntu only)

      RHEL/CentOS/Fedora:

      • redis or valkey (RHEL 10+)
      • Node.js v20 (with npm v10), yarn
      • ca-certificates, gnupg2, curl
      • make, automake, gcc, gcc-c++, patch, sudo
      • git, libpng-devel
      • lvm2, cifs-utils, nfs-utils, ntfs-3g
      • dmidecode, libcap, fuse-libs

      Supported Operating Systems

      • Debian 10/11/12/13 (apt-based)
      • Ubuntu (apt-based, all supported versions)
      • RHEL/CentOS/AlmaLinux/Rocky (dnf/yum-based)
      • Fedora (dnf-based)

      Troubleshooting

      Service fails to start

      Check the service logs:

      sudo journalctl -u xo-server -n 50
      

      Port binding issues

      If running as non-root, the service uses CAP_NET_BIND_SERVICE to bind to privileged ports. Ensure systemd is configured correctly.

      Build failures

      The easiest fix is to use the built-in rebuild command, which takes a backup first:

      ./install-xen-orchestra.sh --rebuild
      

      Or manually (if running as non-root SERVICE_USER):

      cd /opt/xen-orchestra
      rm -rf node_modules
      # Replace 'xo' with your SERVICE_USER if different
      sudo -u xo yarn
      sudo -u xo yarn build
      

      Out of Memory (OOM) during build

      If the build process fails with exit code 137 (killed), your system ran out of memory:

      The script automatically handles this by:

      • Detecting available swap space before building
      • Creating 2GB swap file if insufficient
      • Setting Node.js memory limits (4GB max)

      To manually check/add swap:

      # Check current swap
      free -h
      
      # Create 2GB swap file if needed
      sudo fallocate -l 2G /swapfile
      sudo chmod 600 /swapfile
      sudo mkswap /swapfile
      sudo swapon /swapfile
      echo '/swapfile none swap sw 0 0' | sudo tee -a /etc/fstab
      

      NFS mount errors ("user" NFS mounts not supported)

      If you get an error when adding NFS remote storage:

      mount.nfs: not installed setuid - "user" NFS mounts not supported
      

      The script automatically handles this by configuring sudo permissions for your service user (default: xo) to run mount/umount commands including NFS-specific helpers.

      If you encounter this issue on an existing installation:

      # Update sudoers configuration (replace 'xo' with your SERVICE_USER if different)
      sudo tee /etc/sudoers.d/xo-server-xo > /dev/null << 'EOF'
      # Allow xo-server user to mount/unmount without password
      Defaults:xo !requiretty
      xo ALL=(ALL:ALL) NOPASSWD:SETENV: /bin/mount, /usr/bin/mount, /bin/umount, /usr/bin/umount, /bin/findmnt, /usr/bin/findmnt, /sbin/mount.nfs, /usr/sbin/mount.nfs, /sbin/mount.nfs4, /usr/sbin/mount.nfs4, /sbin/umount.nfs, /usr/sbin/umount.nfs, /sbin/umount.nfs4, /usr/sbin/umount.nfs4
      EOF
      
      sudo chmod 440 /etc/sudoers.d/xo-server-xo
      sudo systemctl restart xo-server
      

      NFS permission denied errors

      If NFS mounts succeed but you get permission errors when writing:

      EACCES: permission denied, open '/run/xo-server/mounts/.keeper_*'
      

      This is a UID/GID mismatch between the xo-server user and your NFS export permissions:

      Option 1: Run as root (recommended for simplicity)

      # Edit config
      nano xo-config.cfg
      # Set: SERVICE_USER=
      # (leave empty to run as root)
      
      # Update service (replace 'xo' with your SERVICE_USER if different)
      sudo sed -i 's/User=xo/User=root/' /etc/systemd/system/xo-server.service
      sudo chown -R root:root /opt/xen-orchestra /var/lib/xo-server /etc/xo-server
      sudo systemctl daemon-reload
      sudo systemctl restart xo-server
      

      Option 2: Configure NFS for your service user's UID
      On your NFS server, adjust exports to allow your service user's UID (check with id <username>), or use appropriate squash settings in your NFS export configuration.

      Redis connection issues

      Ensure Redis is running:

      redis-cli ping
      # Should respond with: PONG
      

      Security Considerations

      • No Root: The script refuses to run as root/sudo and uses sudo internally
      • Service User: Runs as dedicated xo user by default (customizable to any username; leave empty for root)
      • SSL: Self-signed certificate generated automatically for HTTPS
      • Sudo Permissions: Service user configured with minimal sudo access for:
        • NFS/CIFS mount operations (/bin/mount, /usr/bin/mount, /sbin/mount.nfs, etc.)
        • Unmount operations (/bin/umount, /usr/bin/umount, /sbin/umount.nfs, etc.)
        • Mount point discovery (/bin/findmnt, /usr/bin/findmnt)
        • All configured in /etc/sudoers.d/xo-server-<username> with NOPASSWD for specific commands only
      • Automatic Swap: Swap file created with secure permissions (600) if needed for builds

      License

      This installation script is provided as-is. Xen Orchestra itself is licensed under AGPL-3.0.

      Credits

      • Xen Orchestra by Vates
      • Installation Documentation
      posted in Xen Orchestra
      A
      acebmxer
    • RE: Backups not working

      Confirm commit 1a7b5 backups completed successfully.

      posted in Backup
      A
      acebmxer
    • RE: Master, commit a3139 failing backups

      @simonp

      [info] Updating Xen Orchestra from 'cb85e44ae' to 'eed3d72f7'
      

      First log is from automatic schedule before latest update.
      2026-02-17T18_00_00.012Z - backup NG.txt

      latest log after update. Backup completed successfully.
      2026-02-17T18_22_52.199Z - backup NG.txt

      posted in Backup
      A
      acebmxer
    • RE: XCP-ng 8.3 updates announcements and testing

      Updated AMD Ryzen pool at home and update two Intel Dell r660 and r640 pools at work. No issues to report back.

      posted in News
      A
      acebmxer
    • RE: XCP-ng 8.3 updates announcements and testing

      @stormi

      Thanks for the reply back. Update when sucessfull. Windows Server 2025 iso now properly installs.

      At work I was not able to install default certs for UEFI due to one failing to download. Run these updates and I was able to successfully install the certs to the host.

      posted in News
      A
      acebmxer
    • RE: XCP-ng 8.3 updates announcements and testing

      i have applied updates to my 2 amd home lab hosts. Ryzen 7700x and 7950x amd x670e mobo's. No issues to report. Windows vm migrated between hosts no isssues. No issues with windows vm booting with uefi enabled prior to update.

      posted in News
      A
      acebmxer
    • RE: Is v6 preview not available on XO from source?

      @WorkAccount1000

      Reach out to who's script you are using for deploying XO from sources.

      This script - https://github.com/ronivay/XenOrchestraInstallerUpdater there is an option in the config file to enable XOv6. There are concerns with not being fully ready to its disabled by default. I currently have not any issues related to that.

      posted in Xen Orchestra
      A
      acebmxer

    Latest posts made by acebmxer

    • RE: XCP-ng 8.3 updates announcements and testing

      @gduperrey

      Thank you for the reply. Work uses XOA.

      Edit - Support ticket created - Ticket#7755004

      posted in News
      A
      acebmxer
    • RE: XCP-ng 8.3 updates announcements and testing

      @gduperrey

      When applying updates at work. I started with first pool and choose the rolling pool updates and ran into issue after fist host came back up the second host didnt enter maintenance mode and the operation appeared to have just stopped. I then manually put host 2 in maintenance mode and applied updates. Once updates finished it restated the tool stack and took the host out of maintenance mode. I put it back into maintenance mode and rebooted the host. Once it came backup no migration occurred as expected to bring vms back to host2.

      Moved on to pools 2 and 3 and just did everything manually. Each time load balance appears to be broken now just like home lab.

      I have rebooted XOA deleted load balance config. rebuilt using different name and still no load balance.

      Once manually migrated vms back over to second host in all three pools all seems ok.

      posted in News
      A
      acebmxer
    • RE: Trying to enable v2v and difficulty adding nbdinfo on xo 6

      Found issue in my script all seems to be working now for me just no vmware vm to test import on 😞

      posted in Migrate to XCP-ng
      A
      acebmxer
    • RE: Trying to enable v2v and difficulty adding nbdinfo on xo 6

      @edsilber

      Yeah I am not sure. I havent seen heard anyone else having similar issues. I heard of other issues in regards to the actual migration but not the setup.

      Now that you have logs posted maybe someone form Vates will chime in.

      I just tried with my install and i get stuck on first step... Not sure if because of my script or there is an actual issue...

      Screenshot 2026-03-18 164654.png

      Edit - Just booted up XOA on home lab. It looks like i had attempted to setup previously so can test there. Work XOA again was already setup prior for actual migration. See what other say.

      posted in Migrate to XCP-ng
      A
      acebmxer
    • RE: Trying to enable v2v and difficulty adding nbdinfo on xo 6

      @edsilber

      This is from a fresh install of XO from sources...

      this should have walked you through the process to import from vmware.

      Screenshot 2026-03-18 145921.png

      posted in Migrate to XCP-ng
      A
      acebmxer
    • RE: 🛰️ XO 6: dedicated thread for all your feedback!

      @benapetr

      If you are still having issues you can try the script i created to install XO from sources. I would advise not running in production, But i have been using it for a few weeks in my home lab and havent ran into many issues.

      https://github.com/acebmxer/install_xen_orchestra

      posted in Xen Orchestra
      A
      acebmxer
    • RE: Nested virtualization

      @User-cxs

      Assuming you enabled nested virtualization on the xcp-ng host you also need to enabled in the vms bios settings for windows.

      posted in XCP-ng
      A
      acebmxer
    • RE: XCP-ng Windows PV tools announcements

      Install went with out issues on my homelab pc windows 11.

      Screenshot 2026-03-17 093235.png

      I used the installer found in the package folder.

      Screenshot 2026-03-17 093328.png

      posted in News
      A
      acebmxer
    • RE: VHD Check Error

      @Pilow

      While that could be true only 1 vm was shuffled to another SR. But all VMs now being backup with CBT enabled.

      Well... i just check again at backups and after the last scheduled backup at 1am all vms fell back to full backup again.

      posted in Backup
      A
      acebmxer
    • RE: VHD Check Error

      Now delta backups are working again. I tried re-enabling CBT so far so good. Still did a delta backup snapshot was removed no errors.

      Maybe someone with more knowledge could explain why its working now.

      2026-03-12T00_32_16.994Z - backup NG.txt

      posted in Backup
      A
      acebmxer