For Powershell monitor, where is "Multiple Statistics Data" historical data in SWQL?

Hi,

My question is related to the following question from the forum that is now closed, hence this new question. Here is the link to the original:

I have a brand new SAM install I built last week, so everything is latest and greatest (2023.2).

One of the solutions in that link provided by @mesverrum and working for @cmarti is (with slight edits by myself):

SELECT
    tolocal(Timestamp) as Timestamp,
    cs.Component.ApplicationID,
    cs.Component.Application.Node.dns as Hostname,
    cs.Component.Application.Name as ApplicationName,
    cs.Component.Name as component,
    cs.ComponentID,
    cs.DynamicEvidence.ColumnLabel as Label,
    cs.DynamicEvidence.StringData as StringData,
    cs.DynamicEvidence.AvgNumericData
FROM Orion.APM.ComponentStatus cs
order by timestamp desc

There is over 15,000 records that covers 5 days. AvgNumericData contains values that make sense. That all makes sense. My issue is StringData is always NULL which is not the expected result.

Am I missing something here? Is my expectation that StringData should contain something other than NULL not correct?
If you have any applications with Windows Powershell Monitor components running, can you run the above query in SWQL Studio and report the contents of StringData?

TIA :-)





Parents
  • Hi All.

    Let me chime in on this thread.

    My shop makes regular use of script monitors.  We pull string and numeric data back into Solarwinds using the Message: and Statistic:  constructs.  This data gets (got) stored in the Orion.APM.DynamicEvidence table in the StringData field.

    We've created consoles for our user community which display the data collected.  Message (string) data retrieved with SWQL queries to APM.DynamicEvidence.

    Last week we upgraded Solarwinds from 2022.x to 2023.3 - and our data widgets stopped working for Message data.

    My best guess at this point about what happened...

    Note this section from the 2023.2 Release Notes:

    --------------------------------------------------------------

    Improved performance of APM DynamicEvidence

    As part of performance improvements, the APM_DynamicEvidence_DetailData table has been removed. The new APM_DynamicEvidence_Current table contains the last value for both numeric and string values including the row and schema id. As a result of this change, scripts referencing the APM_DynamicEvidence_DetailData table will no longer work.

    --------------------------------------------------------------

    Notice the release notes reference changes to the APM_DynamicEvidence_DetailData table.  However... the APM_DynamicEvidence table also has a line through it in SWQL Studio with a note about table has been depreciated.  I did not find any Message string data in the APM_DynamicEvidence_Current table.

    Most likely there was some kind of disconnect in the halls of Solarwinds development where some functionality of the APM_DynamicEvidence table was removed (by mistake?) but not incorporated into other tables.

    I have a ticket in with Solarwinds Support to verify the bug, or at least find out where SW now stores Message data from script monitors.  I will update this thread when I hear something.  Cheers.

  •    - I'm running 2023.4 (currently in RC) and this is what the API is providing me via SWQL Studio:

    Orion.APM.DynamicEvidenceDetailData

    Orion.APM.DynamicEvidence

    From the casual observer (me), it looks like you should stop using Orion.APM.DynamicEvidenceDetailData and instead be using Orion.APM.DynamicEvidenceCurrent and move from Orion.APM.DynamicEvidence  to Orion.APM.DynamicEvidenceChart.

    Note: The above are all from the API (SWQL) and not the database.  You should be using the API as much as possible to insulate you from any underlying database changes.

  • Greetings.

    FYI I opened a ticket with Solarwinds support.  After some dialog and clarification the support agent confirmed that the reported condition is in fact a bug in the program.

    The agent has escalated my ticket to Dev in an effort to get more details / bug report / estimated fix date for the issue.

    It appears that, starting with version 2023.2 or so, if you are capturing string metrics in a script monitor using the 'Message' construct, then that data does not get captured to the database.

    Btw I checked table Orion.APM.DynamicEvidenceChart table and it does not contain any Message (string) data from script monitors.  

    Complete agreement that we should always use SWQL Studio whenever possible rather than SQL tables. 

    I will post new information as it becomes available.  Anyone in the community feel free to question or comment.

    Cheers.

  • Hi,

    For the ticket I submitted 01368039 all I got was when I asked about null in StringData was "I do not know if it is correct or not, but I get the same results in my lab, so two out of two may be right. Unfortunately, SWQL is out of our scope of support and you will need to go to thwack.com if you have questions about SWQL." :-( That is what led to the original post above...

    I would love to have a table with timestamp, StringData and NumericData (or Message and Statistic data). Looking forward to hearing what you hear...

  • The support agent now has asked for a complete diagnostic upload.  In my environment we have to 'sanitize' anything sent to a vendor which basically means change all of the host names and IP addresses.

    I need to ask around my shop to see if we have a script or something to sanitize log/diagnostic output, or if I need to write something myself.

    I'll keep everyone posted as to results. 

  • Hello Robert!

    I hate to ask 'Captain Obvious" questions, but I find if they aren't asked, the answers tend to hide there the longest.

    So my question is, are your PowerShell monitors actually returning String\Message values when you test them in the Solarwinds Application Monitor? I only ask because it was mentioned that there doesn't seem to be any StringData populating into your database tables.

    We recently had the same issue where updating our Solarwinds platform from 2022.X to 2023.X caused a few monitors to break and we had to craft some new PowerShell scripts that return both a Message and a Statistic value. What we found was that there was two tables where the results were being stored; the Orion.APM.DynamicEvidenceCurrent and Orion.APM.MultipleStatisticData. The Orion.APM.MultipleStatisticData tables stores both values in the same row, however, it does not have a TimeStamp column. The Orion.APM.DynamicEvidenceCurrent does have a TimeStamp column, but it stores the Message and Statistic values on separate rows. One row would have either a NumericData value and 'NULL' for StringData; or it would have a StringData value, and a 'NULL' NumericData value.

  • I might be wrong, but if I understand the article  wrote on decreasing JOINs through Navigation Properties correctly, it would seam that you should be able to use the "MultipleStatisticData" Navigation Property on the "Orion.APM.DynamicEvidenceChart" table to join the TimeStamp value there with the Orion.APM.MultipleStatisticData table's StringData and NumericData values. You would need to know the ComponentID for the set of values that you are trying to join together.

Reply
  • I might be wrong, but if I understand the article  wrote on decreasing JOINs through Navigation Properties correctly, it would seam that you should be able to use the "MultipleStatisticData" Navigation Property on the "Orion.APM.DynamicEvidenceChart" table to join the TimeStamp value there with the Orion.APM.MultipleStatisticData table's StringData and NumericData values. You would need to know the ComponentID for the set of values that you are trying to join together.

Children
No Data