Good day AVEVA SP & OMI community, 
Please could you share some of your tried and trusted methods to obtain the total number of configured IO in Application Server, apart from using the View License Information feature.
Thank you in advance!
Good day AVEVA SP & OMI community, 
Please could you share some of your tried and trusted methods to obtain the total number of configured IO in Application Server, apart from using the View License Information feature.
Thank you in advance!
Hi Drish
Check this out and let me know if this solves your question.
To run a production Galaxy you need a ‘Application Server IO’ license that will cover the configured amount of IO reference. Since there exists a possibility to assign the necessary reference during startup of the runtime environment, using scripting, there isn’t a way to show the configured number of references through the User Interface upfront inside the IDE. This can lead to the situation where a runtime environment has more reference to the field (IO count) than allowed by the installed license. By implementing one of the below solutions you can figure out the exact amount of OI references used in your deployed Galaxy environment.
System Platform Version 2017 or higher.
Objects can only work on the deployed Platform of the Galaxy Repository (GR) node.
We created a simple object that can be implemented in a runtime Galaxy environment to measure the actual used IO count. We first identify all deployed DI-object instances used in your Galaxy. Then we summarize the used Scan Groups / Topics of these deployed DI-object instances. In every Scan Group / Topic we count the item count and summarize this to come to the final IO Count used.
The measuring can be performed by one of these objects deployed on the GR Platform:
Engine Object named: “Engine_Total_Used_IO_Count”
Area Object named: “Area_Total_Used_IO_Count”
Automation Object named: “Total_Used_IO_Count”
“Engine_Total_Used_IO_Count”
If there isn’t an Engine deployed on the GR node this object is preferable. This because you only need to deploy this single object.
“Area_Total_Used_IO_Count”
If there is an Engine deployed on the GR Platform you can use this Area object. You only need to deploy it on one of the already deployed engine(s) on the GR.
“UDO_Total_Used_IO_Count”
If there is an Engine deployed on the GR Platform with a deployed Area on it, you can use this object. Assign it to the deployed Area and deploy this object.
Object packages can be downloaded from here: IO_Count Objects.zip
Select below one of the options that fits best for you.
Unzip the corresponding zip file and place the files in location of your choice.
Open the IDE with the deployed Galaxy selected.
Using the menu go to: Galaxy -> Import -> Object(s)…
Select the unzipped file named: “Engine_Total_Used_IO_Count.aaPKG” and press ‘Open’.
Leave the ‘Import Preferences’ untouched (default) and press ‘OK’.
After importing assign the “Engine_Total_Used_IO_Count” object instance to the GR Platform.
Deploy this Engine instance.
Set the focus on this new deployed Engine -> Right mouse click -> View in Object Viewer.
With ‘Object Viewer’ open. Click on the white space of your “Watch List 1” to set the focus here.
Go to Menu -> File -> Load Watch List.
Select the “Total_Used_IO_Count using Engine Object WatchList” file you unzipped under point 1.
Next attributes will be seen in your ‘Watch List’.
Double click on the 1st Attribute-reference in the Watch List. The popup window: “Modify Boolean Value” appears.
Select the radio button ‘True’ and press the button ‘OK’.
The Galaxy will be scanned, and a result value will be shown for the third Attribute: “Engine_Total_Used_IO_Count.Total_IO_Count_Used”.
This value is your actual used IO-Count of your active Galaxy.
Unzip the corresponding zip file and place the files in location of your choice.
Open the IDE with the deployed Galaxy selected.
Using the menu go to: Galaxy -> Import -> Object(s)…
Select the unzipped file named: “Area_Total_Used_IO_Count.aaPKG” and press ‘Open’.
Leave the ‘Import Preferences’ untouched (default) and press ‘OK’.
After importing assign the “Area_Total_Used_IO_Count” object instance to an engine on the GR Platform.
Deploy this Area instance.
Set the focus on this new deployed Area -> Right mouse click -> View in Object Viewer.
With ‘Object Viewer’ open. Click on the white space of your “Watch List 1” to set the focus here.
Go to Menu -> File -> Load Watch List.
Select the “Total_Used_IO_Count using Area Object WatchList” file you unzipped under point 1.
Next attributes will be seen in your ‘Watch List’.
Double click on the 1st Attribute-reference in the Watch List. The popup window: “Modify Boolean Value” appears.
Select the radio button ‘True’ and press the button ‘OK’.
The Galaxy will be scanned, and a result value will be shown for the third Attribute: “Area_Total_Used_IO_Count.Total_IO_Count_Used”.
This value is your actual used IO-Count of your active Galaxy.
Unzip the corresponding zip file and place the files in location of your choice.
Open the IDE with the deployed Galaxy selected.
Using the menu go to: Galaxy -> Import -> Object(s)…
Select the unzipped file named: “UDO_Total_Used_IO_Count.aaPKG” and press ‘Open’.
Leave the ‘Import Preferences’ untouched (default) and press ‘OK’.
After importing assign the “UDO_Total_Used_IO_Count” object instance to an Area on the GR Platform.
Deploy this UDO instance.
Set the focus on this new deployed UDO -> Right mouse click -> View in Object Viewer.
With ‘Object Viewer’ open. Click on the white space of your “Watch List 1” to set the focus here.
Go to Menu -> File -> Load Watch List.
Select the “Total_Used_IO_Count using UDO Object WatchList” file you unzipped under point 1.
Next attributes will be seen in your ‘Watch List’.
Double click on the 1st Attribute-reference in the Watch List. The popup window: “Modify Boolean Value” appears.
Select the radio button ‘True’ and press the button ‘OK’.
The Galaxy will be scanned, and a result value will be shown for the third Attribute: “UDO_Total_Used_IO_Count.Total_IO_Count_Used”.
This value is your actual used IO-Count of your active Galaxy.
When using a huge number of DI-objects with a large amount of Scan Groups, summarizing of all used IO-counts can take a while. After you have set the “Get_IO_Item_Count” Boolean to true the “DI_Objects_StringArray_List[]” attribute will be filled with all DI references and the summarizing will take place. When this: “DI_Objects_StringArray_List[]” attribute shows back the words: <Default>,<Default>,etc the summarizing is finished with the result in the attribute “Total_IO_count_Used”.
Hi Drish
Check this out and let me know if this solves your question.
To run a production Galaxy you need a ‘Application Server IO’ license that will cover the configured amount of IO reference. Since there exists a possibility to assign the necessary reference during startup of the runtime environment, using scripting, there isn’t a way to show the configured number of references through the User Interface upfront inside the IDE. This can lead to the situation where a runtime environment has more reference to the field (IO count) than allowed by the installed license. By implementing one of the below solutions you can figure out the exact amount of OI references used in your deployed Galaxy environment.
System Platform Version 2017 or higher.
Objects can only work on the deployed Platform of the Galaxy Repository (GR) node.
We created a simple object that can be implemented in a runtime Galaxy environment to measure the actual used IO count. We first identify all deployed DI-object instances used in your Galaxy. Then we summarize the used Scan Groups / Topics of these deployed DI-object instances. In every Scan Group / Topic we count the item count and summarize this to come to the final IO Count used.
The measuring can be performed by one of these objects deployed on the GR Platform:
Engine Object named: “Engine_Total_Used_IO_Count”
Area Object named: “Area_Total_Used_IO_Count”
Automation Object named: “Total_Used_IO_Count”
“Engine_Total_Used_IO_Count”
If there isn’t an Engine deployed on the GR node this object is preferable. This because you only need to deploy this single object.
“Area_Total_Used_IO_Count”
If there is an Engine deployed on the GR Platform you can use this Area object. You only need to deploy it on one of the already deployed engine(s) on the GR.
“UDO_Total_Used_IO_Count”
If there is an Engine deployed on the GR Platform with a deployed Area on it, you can use this object. Assign it to the deployed Area and deploy this object.
Object packages can be downloaded from here: IO_Count Objects.zip
Select below one of the options that fits best for you.
Unzip the corresponding zip file and place the files in location of your choice.
Open the IDE with the deployed Galaxy selected.
Using the menu go to: Galaxy -> Import -> Object(s)…
Select the unzipped file named: “Engine_Total_Used_IO_Count.aaPKG” and press ‘Open’.
Leave the ‘Import Preferences’ untouched (default) and press ‘OK’.
After importing assign the “Engine_Total_Used_IO_Count” object instance to the GR Platform.
Deploy this Engine instance.
Set the focus on this new deployed Engine -> Right mouse click -> View in Object Viewer.
With ‘Object Viewer’ open. Click on the white space of your “Watch List 1” to set the focus here.
Go to Menu -> File -> Load Watch List.
Select the “Total_Used_IO_Count using Engine Object WatchList” file you unzipped under point 1.
Next attributes will be seen in your ‘Watch List’.
Double click on the 1st Attribute-reference in the Watch List. The popup window: “Modify Boolean Value” appears.
Select the radio button ‘True’ and press the button ‘OK’.
The Galaxy will be scanned, and a result value will be shown for the third Attribute: “Engine_Total_Used_IO_Count.Total_IO_Count_Used”.
This value is your actual used IO-Count of your active Galaxy.
Unzip the corresponding zip file and place the files in location of your choice.
Open the IDE with the deployed Galaxy selected.
Using the menu go to: Galaxy -> Import -> Object(s)…
Select the unzipped file named: “Area_Total_Used_IO_Count.aaPKG” and press ‘Open’.
Leave the ‘Import Preferences’ untouched (default) and press ‘OK’.
After importing assign the “Area_Total_Used_IO_Count” object instance to an engine on the GR Platform.
Deploy this Area instance.
Set the focus on this new deployed Area -> Right mouse click -> View in Object Viewer.
With ‘Object Viewer’ open. Click on the white space of your “Watch List 1” to set the focus here.
Go to Menu -> File -> Load Watch List.
Select the “Total_Used_IO_Count using Area Object WatchList” file you unzipped under point 1.
Next attributes will be seen in your ‘Watch List’.
Double click on the 1st Attribute-reference in the Watch List. The popup window: “Modify Boolean Value” appears.
Select the radio button ‘True’ and press the button ‘OK’.
The Galaxy will be scanned, and a result value will be shown for the third Attribute: “Area_Total_Used_IO_Count.Total_IO_Count_Used”.
This value is your actual used IO-Count of your active Galaxy.
Unzip the corresponding zip file and place the files in location of your choice.
Open the IDE with the deployed Galaxy selected.
Using the menu go to: Galaxy -> Import -> Object(s)…
Select the unzipped file named: “UDO_Total_Used_IO_Count.aaPKG” and press ‘Open’.
Leave the ‘Import Preferences’ untouched (default) and press ‘OK’.
After importing assign the “UDO_Total_Used_IO_Count” object instance to an Area on the GR Platform.
Deploy this UDO instance.
Set the focus on this new deployed UDO -> Right mouse click -> View in Object Viewer.
With ‘Object Viewer’ open. Click on the white space of your “Watch List 1” to set the focus here.
Go to Menu -> File -> Load Watch List.
Select the “Total_Used_IO_Count using UDO Object WatchList” file you unzipped under point 1.
Next attributes will be seen in your ‘Watch List’.
Double click on the 1st Attribute-reference in the Watch List. The popup window: “Modify Boolean Value” appears.
Select the radio button ‘True’ and press the button ‘OK’.
The Galaxy will be scanned, and a result value will be shown for the third Attribute: “UDO_Total_Used_IO_Count.Total_IO_Count_Used”.
This value is your actual used IO-Count of your active Galaxy.
When using a huge number of DI-objects with a large amount of Scan Groups, summarizing of all used IO-counts can take a while. After you have set the “Get_IO_Item_Count” Boolean to true the “DI_Objects_StringArray_List[]” attribute will be filled with all DI references and the summarizing will take place. When this: “DI_Objects_StringArray_List[]” attribute shows back the words: <Default>,<Default>,etc the summarizing is finished with the result in the attribute “Total_IO_count_Used”.
Hi Lauran Lint, thank you for the detailed step by step guide and the ObjectExport files. I will test this out and let you know how it goes. 
Once again, thank you for your response, it is much appreciated.
sorry for the lousy formatting of the writing ;)
Hey Lauran,
I would be interested in that Objects too.
Unfortunately It says that they are not available anymore on onedrive. (IO_Count Objects.zip)
Is it still possible to get them? ;)
Thanks in advance!
Best regards
Mario
I have a backup of it here. IO_Count Objects.zip
Perfect, thank you very much!
Hi Mario,
I was out for a few days. I see that Inacio has helped you.
Let me know if it works for you.
Regards,
Lauran
Hi Lauran,
I like the idea of the implementation but I do have an issue with that after some analysis:
There is a license overview in the Galaxy itself regarding the configured count of I/O points which matches the stored procedure "dbo.internal_get_io_point_count" result.
It counts all the configured IO references, static or via autobinding but not the scripting ones.
If I add "---" in an input source it's not counted as far as I can tell.
But as you mentioned, that's all configuration.
Now with scripting I/O references you do get all the current runtime and valid I/O references in the Device Integration Objects listed with "ItemCnt" BUT you do not get the runtime invalid I/O references like "---".
Problem is, these "---" count for the license check meaning there is a mismatch.
From my point of view there is a background task which counts all the attributes.input sources and keeps this number to check against an app server license.
I've tested this with a 100 I/O app server license.
Discussion open if I missed anything.
Peter