You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
After some investigation, I understand that it's no longer encouraged for extensions to load waagent. I.e. this coding pattern is now discouraged, if I understand correctly:
from Utils.WAAgentUtil import waagent
I believe it's function was, once upon a time, to offer a level of convenience so that the extensions could call helper functions in waagent.
But now, I think there are three problems with it:
If you do it without shipping your own copy of waagent, I believe it will fail. I believe this because, if I understand the code correctly, this code in the latest WALinuxAgent repo will refuse to be loaded as waagent, if the VM runs Python 3. https://github.com/Azure/WALinuxAgent/blob/master/bin/waagent. I that code explicitly deprecates this coding pattern, and in fact makes it impossible in most cases.
Therefore, the only way to make this coding pattern work is to ship your own file name waagent. That requires you to use a very old copy of wwagent that is quite a few years old.
The above leads to a really confusing code pattern, when extensions ship complete but very old copies of waagent, simply so they can call a small number of it's helper methods. All the rest of the code those old copies of waagent is unused.
In fact, it's even more confusing than that, because the first thing that runs is the "built in" agent (the one that's part of every Azure VM). That one then loads our extension... and with the above coding pattern our extension then loads its own bundled agent implementation just so that it can call some helper methods. It's really confusing having "new agent" -> extension -> "old agent" as the chain of calls. So not only is the bundled agent implementation old (as described in the previous point) but it's also invoked in a pretty confusing way.
There have recently been changes to WAAgentUtil with the aim of making it compatible with Python 3.12. However, I don't actually think that continued use of this pattern is the best option. I believe the better option is to deprecate this pattern and stop loading waagent from within the extensions.
As far as I can tell, the best solution is the one used in this PR #1097. I.e. drop all dynamic loading of any kind of wagent file. Instead, use the new handlerutil2.py and logger.py which provide equivalent functionality without any dynamic loading of waagent. Not that the referenced pull request doesn't just include a simple replacement of WAAgentUtil and the waagent file. It also includes things that are specific to the particular extension for which that PR was done. So that makes the PR a little harder to read.
Can you please confirm whether the above is corrrect, and if it is,
(a) update the SampleExtension to stop using WAAgentUtil.py (your PR here can show folks clearly how to convert from the old approach to the new. I.e. it will be like a slimmed down versio of #1097, not introducing any new files, but just converting the SampleExtension over to call the files that were introduced in that RP). and
(b) please add comments into WAAgentUtil explaining that it is deprecated, and why it is deprecated.
The text was updated successfully, but these errors were encountered:
After some investigation, I understand that it's no longer encouraged for extensions to load
waagent
. I.e. this coding pattern is now discouraged, if I understand correctly:I believe it's function was, once upon a time, to offer a level of convenience so that the extensions could call helper functions in waagent.
But now, I think there are three problems with it:
As far as I can tell, the best solution is the one used in this PR #1097. I.e. drop all dynamic loading of any kind of wagent file. Instead, use the new
handlerutil2.py
andlogger.py
which provide equivalent functionality without any dynamic loading of waagent. Not that the referenced pull request doesn't just include a simple replacement of WAAgentUtil and the waagent file. It also includes things that are specific to the particular extension for which that PR was done. So that makes the PR a little harder to read.Can you please confirm whether the above is corrrect, and if it is,
(a) update the SampleExtension to stop using WAAgentUtil.py (your PR here can show folks clearly how to convert from the old approach to the new. I.e. it will be like a slimmed down versio of #1097, not introducing any new files, but just converting the SampleExtension over to call the files that were introduced in that RP). and
(b) please add comments into WAAgentUtil explaining that it is deprecated, and why it is deprecated.
The text was updated successfully, but these errors were encountered: