A way to skip Automatic Starting of VMs and Containers during server boot.

vcp_ai

Renowned Member
Jul 28, 2010
177
5
83
Valencia -Spain-
There are times, mainly on tests servers, that you do not want to automatic start VMs and containers at the last part of boot.
Instead of disable automatic start on every machine, a global solution, was wanted.
Looking at the way PVE starts, got to /etc/rc2.d/S20pve-manager script (link to /etc/init.d/pve-manager) that was the responsible for starting VMs.

The following code inserted on the start section of pve-manager script , makes what I wanted.
It lets you, at the end of boot sequence, to press key s to SKIP starting VMs and containers. If you do not press this key, in 3 seconds boot continues as before, so not interfering with usual boot requirements.

Code:
.............
[FONT=lucida console]case "$1" in
   start)
       echo "Pres  s  to skip automatic starting of VMs and containers"             ######Start of code inserted
       stty -icanon min 0 time 30                                                               
            read  ENTRADA
       stty   sane
       if  [ -n "$ENTRADA" ] && [ $ENTRADA = "s" ] ; then
            echo  "SKIPPING ......"
            exit 0
       fi                                                                           #######End of code inserted
       echo "Starting VMs and Containers"
       pvesh --nooutput create /nodes/localhost/startall
       ;;[/FONT]
..........
Can this 'feature' or similar be implemented in next releases ?

Note: A better way to detect key s press would be desirable. I only know basics about shell programming.
This way fails if you get a 'stuck key' pressed on the keyboard . It never ends in that case.

Regards
 
Well, usually brand server do a lot of check before starting, and take more than 1 minute just to end autotest (included raid controller firmware check etc) and start booting, so adding 3 seconds seems not that bad to me.
Just usually I test server through ssh, would love to have ALSO a global setting for that, like I would love to have one for disable backup without the need of delete it and re-create.
Best regards
 
I'm with the same mind as dietmar. Who is testing Proxmox on servers - like you - mostly have enough experience with Shell scripting or with using Google, to do it themself. Else there are thousands of Linux/Bash boards in the WorldWideWeb, to ask for help there. Or someone uses the board-search to find this thread :)
 
How about a maintenance mode?
put host on maintenance mode disable all automations, cluster availabilities, etc.
 
I think this is a great idea, and a 3-second delay is a small price to pay for the feature.. if you don't touch the keyboard, it boots like normal.

Love it.. please include it in the next release of PMX, or perhaps a 'global' checkbox in the GUI to enable/disable this feature.
 
I think this is a great idea, and a 3-second delay is a small price to pay for the feature.. if you don't touch the keyboard, it boots like normal.

Love it.. please include it in the next release of PMX, or perhaps a 'global' checkbox in the GUI to enable/disable this feature.

I don't like the boot delay option or the keyboard intervention.
My stuff is in the basement at home for my personal setup and at work we have 2 datacenter and one is remote (15 minutes car ride).
Having to run across the local datacenter or across the city for a maintenance mode is counter productive.

Best way to do this IMO is an option to put the host in maintenance mode until it is told to get back online.
A simple right click on the node of the datacenter tree should do.

That also raise the question of what to do with the running VM on the host you put in maintenance mode.
- Auto failover vm that are HA protected and force shutdown all others vm?
- No go until all vm are either offline (not paused) or migrated to another host?
 
My $0.02.
Proxmox is designed with Production Cluster in mind. Meaning HA enabled and everything setup for maximum uptime. When HA enabled, during server restart i believe the node will migrate all VMs to 2nd node and restart the machine with no VMs to auto restart. When in manual mode, an an administrator will simply migrate all VMs to 2nd node so no server goes offline and then restart the physical node, migrate all VMs back to the node. In a setup environment there really no need of dozens of VMs unless doing a stress test in which case it really does not matter if all the VMs starts or not. Its just matter of few clicks to disable all VMs auto reboot option in the GUI, so the VMs will never restart. For purely test environment this makes sense.
Adding an option to restart all VMs or not during node reboot is a waste of resource in my opinion.
 
Super old thread.

But beeing able to enable/disable boot globally, for testing purposes where you reboot often, would be great xD
 
Maintenance mode or something like it is sorely needed! Thanks to the OP for the workaround!
 
If its just a single node it would be easy to write a script to set/unset the "start at boot" for all guests with a single line.
 
If its just a single node it would be easy to write a script to set/unset the "start at boot" for all guests with a single line.
You're right of course... But the same could be said for any of a thousand things/features that are well represented in the GUI. It would also be easy to put a button/check-box on the dashboard that ran a built-in function to do the same. Diffrent strokes... :)
 
If its just a single node it would be easy to write a script to set/unset the "start at boot" for all guests with a single line.
I've a lot of VM that are "dormient" that have not autorun, or copies of the production one or a lot of other stuff that is NOT set to autorun. So a script to "mass deactivate/activate" all VM at startup is not the case, and that's why I need a "global" switch when I have to just experiment with server setups that requires reboot without having to manually switch off that parameter of 8 VM out of 20 and then remember to do the opposite without missing one.
Also the addiction of a boot process that checks if a specific key (i.e. "n" or "b" or whatever) is pressed and if so skips only for that boot the autorun could be a nice addition when you have to start a server and want to check something (i.e. is some storage working? Network?) before the VM starts.
 
  • Like
Reactions: AndreKW
I will cast another vote for this feature! I also have a mixture of VMs and CTs, some of which autostart to support regular production usage and others which are used for testing or experimentation and only started when needed. For server maintenance or hardware replacement/upgrades having a simple way to temporarily bypass autostarts on the next reboot would be very convenient!