Skip to content
DataMiner DoJo

More results...

Generic selectors
Exact matches only
Search in title
Search in content
Post Type Selectors
Search in posts
Search in pages
Search in posts
Search in pages
Log in
Menu
  • Blog
  • Questions
  • Learning
    • E-learning Courses
    • Open Classroom Training
    • Certification
      • DataMiner Fundamentals
      • DataMiner Configurator
      • DataMiner Automation
      • Scripts & Connectors Developer: HTTP Basics
      • Scripts & Connectors Developer: SNMP Basics
      • Visual Overview – Level 1
      • Verify a certificate
    • Tutorials
    • Video Library
    • Books We Like
    • >> Go to DataMiner Docs
  • Expert Center
    • Solutions & Use Cases
      • Solutions
      • Use Case Library
    • Markets & Industries
      • Media production
      • Government & defense
      • Content distribution
      • Service providers
      • Partners
      • OSS/BSS
    • DataMiner Insights
      • Security
      • Integration Studio
      • System Architecture
      • DataMiner Releases & Updates
      • DataMiner Apps
    • Agile
      • Agile Webspace
      • Everything Agile
        • The Agile Manifesto
        • Best Practices
        • Retro Recipes
      • Methodologies
        • The Scrum Framework
        • Kanban
        • Extreme Programming
      • Roles
        • The Product Owner
        • The Agile Coach
        • The Quality & UX Coach (QX)
    • DataMiner DevOps Professional Program
  • Downloads
  • More
    • Feature Suggestions
    • Climb the leaderboard!
    • Swag Shop
    • Contact
      • General Inquiries
      • DataMiner DevOps Support
      • Commercial Requests
    • Global Feedback Survey
  • PARTNERS
    • All Partners
    • Technology Partners
    • Strategic Partner Program
    • Deal Registration
  • >> Go to dataminer.services

Interapp Message Limit Implementation?

Solved327 views17th December 2024buffer InterApp QAction Queued SLProtocol
3
Alex Johnson [SLC] [DevOps Advocate]836 16th December 2024 0 Comments

Hi Dojo,

We are implementing an OpenTelemetry Collector that sends logs via interapp to a Receiver sometimes to the tune of ~300 messages  per min (see statistics screenshot).

We've noticed that after a short time, the messages get stuck in the interapp message "stack", where even if we disable them they will continue coming - likely the interapp buffer catching up.

Couple questions:

-Is there a way to tell how many messages an element can handle at once? We'd like to add some thresholds to control and possibly to alarm when too many messages are coming in.

-Is there a way to STOP sending the interapp messages immediately, regardless of how many are in the stack?

Here is our sender code, for reference:

var interAppMessage = new TelemetryMessage
{
MessageType = elementInfo.MessageType,
Message = HelpMethods.CompressString(parsed.ToString()),
ManagerElement = protocol.DataMinerID + "/" + protocol.ElementID,
FilterKey = elementInfo.FilterKey,
};

IInterAppCall command = InterAppCallFactory.CreateNew();
command.Messages.Add(interAppMessage);
command.Source = new Source("OpenTelemetry Collector", protocol.DataMinerID, protocol.ElementID);
command.ReturnAddress = new ReturnAddress(elementInfo.DmaId, elementInfo.ElementId, Constants.InterappReturnPid);
command.Send(protocol.SLNet.RawConnection, elementInfo.DmaId, elementInfo.ElementId, Constants.InterappReceiverPid, Constants.KnownTypes());

Thanks in advance!

Alex Johnson [SLC] [DevOps Advocate] Selected answer as best 17th December 2024

1 Answer

  • Active
  • Voted
  • Newest
  • Oldest
2
Timothy Van Poucke [SLC] [DevOps Enabler]1.16K Posted 17th December 2024 0 Comments

What I expect you are facing is not directly the Interapp "stack" because from what I remember Interapp sets data directly to the element. So what you are actually seeing is probably the element catching up to the sets.

If it's that you can't stop the messages from coming in. I suspect the root cause is actually the processing of the messages, probably this goes to slow.

I faced that before and this is how I handled it:

a message comes in => process it on a different protocol thread

if another message comes in while the processing is being done => put it on a buffer (I keep this buffer and the busy state in memory, FYI  I have failsafes if SLScripting crashes best to keep that in mind)

When the processing is done, trigger the buffer QA to send the buffer and process the next messages in bulk.

That way you can very quickly handle the incoming messages.

Working with a system like this will give you also more flexibility and control of the buffer, you will also be able to print more logging to see what is going on and where the delays are

Just a tip: from the moment you handle Interapp or subscriptions, handle them as quickly as possible and do the processing separately.

One small Note: there is also a possibility to send multiple interapp calls in one go/bulk. No idea if that's applicable in your use-case, but it might be one extra thing for you to consider.

Alex Johnson [SLC] [DevOps Advocate] Selected answer as best 17th December 2024
You are viewing 1 out of 1 answers, click here to view all answers.
Please login to be able to comment or post an answer.

My DevOps rank

DevOps Members get more insights on their profile page.

My user earnings

0 Dojo credits

Spend your credits in our swag shop.

0 Reputation points

Boost your reputation, climb the leaderboard.

Promo banner DataMiner DevOps Professiona Program
DataMiner Integration Studio (DIS)
Empower Katas

Recent questions

Alarm Dashboard PDF/CSV Export 0 Answers | 0 Votes
Is the Microsoft SharePoint Connector Still Usable 0 Answers | 0 Votes
Is the Microsoft SharePoint Connector Still Usable 0 Answers | 0 Votes

Question Tags

adl2099 (115) alarm (62) Alarm Console (82) alarms (100) alarm template (83) Automation (223) automation scipt (111) Automation script (167) backup (71) Cassandra (180) Connector (108) Correlation (68) Cube (150) Dashboard (194) Dashboards (188) database (83) DataMiner Cube (57) DIS (81) DMS (71) DOM (139) driver (65) DVE (55) Elastic (83) Elasticsearch (115) elements (80) Failover (104) GQI (159) HTTP (76) IDP (74) LCA (151) low code app (166) low code apps (93) lowcodeapps (75) MySQL (53) protocol (203) QAction (83) security (88) services (51) SNMP (86) SRM (337) table (54) trending (87) upgrade (62) Visio (539) Visual Overview (345)
Privacy Policy • Terms & Conditions • Contact

© 2025 Skyline Communications. All rights reserved.

DOJO Q&A widget

Can't find what you need?

? Explore the Q&A DataMiner Docs

[ Placeholder content for popup link ] WordPress Download Manager - Best Download Management Plugin