ETA application crashed in ripc10IntFlushSess
The application uses ETA to send over 10,000 messages per second. Recently, the application crashed with a segmentation fault in ripc10IntFlushSess. Two threads crashed in the same function, a few microseconds apart.
Program terminated with signal 11
#0 0x00000000004282a0 in ripc10IntFlushSess ()
Missing separate debuginfos, use: debuginfo-install
glibc-2.12-1.80.el6.x86_64 libgcc-4.4.6-4.el6.x86_64 libstdc++-4.4.6-4.el6.x86_64
(gdb) bt
#0 0x00000000004282a0 in ripc10IntFlushSess ()
#1 0x0000000000428cb8 in ripc10FlushSess ()
#2 0x0000000000420c60 in rsslSocketFlush ()
#3 0x000000000041362d in rsslFlush ()
Could you please help?
Best Answer
-
From the problem description, the application uses ETA with
multiple threads and two threads can call rsslFlush function on the same
channel concurrently. In this scenario, the application must use RSSL_LOCK_GLOBAL_AND_CHANNEL
instead of RSSL_LOCK_NONE when calling rsslInitialize or rsslInitializeEx
function. This setting allows for accessing the same channel from multiple
threads.RsslInitializeExOpts initOpts = RSSL_INIT_INITIALIZE_EX_OPTS;
RsslError error;
initOpts.rsslLocking = RSSL_LOCK_GLOBAL_AND_CHANNEL;
if (rsslInitializeEx(&initOpts, &error) != RSSL_RET_SUCCESS)
{
…
}Note that writing messages from multiple threads can result
in ordering issues and it is not recommended to write related messages across
different threads.1
Categories
- All Categories
- 6 AHS
- 39 Alpha
- 161 App Studio
- 4 Block Chain
- 4 Bot Platform
- 16 Connected Risk APIs
- 47 Data Fusion
- 30 Data Model Discovery
- 608 Datastream
- 1.3K DSS
- 577 Eikon COM
- 4.9K Eikon Data APIs
- 7 Electronic Trading
- Generic FIX
- 7 Local Bank Node API
- Trading API
- 2.7K Elektron
- 1.3K EMA
- 236 ETA
- 519 WebSocket API
- 33 FX Venues
- 10 FX Market Data
- 1 FX Post Trade
- 1 FX Trading - Matching
- 12 FX Trading – RFQ Maker
- 5 Intelligent Tagging
- 2 Legal One
- 20 Messenger Bot
- 2 Messenger Side by Side
- 9 ONESOURCE
- 7 Indirect Tax
- 59 Open Calais
- 264 Open PermID
- 39 Entity Search
- 2 Org ID
- PAM
- PAM - Logging
- 8.4K Private Comments
- 6 Product Insight
- Project Tracking
- ProView
- ProView Internal
- 20 RDMS
- 1.4K Refinitiv Data Platform
- 367 Refinitiv Data Platform Libraries
- 3 Refinitiv Due Diligence
- LSEG Due Diligence Portal API
- 3 Refinitiv Due Dilligence Centre
- Rose's Space
- 1.1K Screening
- 18 Qual-ID API
- 13 Screening Deployed
- 23 Screening Online
- 10 World-Check Customer Risk Screener
- 990 World-Check One
- 44 World-Check One Zero Footprint
- 45 Side by Side Integration API
- Test Space
- 3 Thomson One Smart
- 1.2K TR Internal
- Global Hackathon 2015
- 2 Specialists Who Code
- 10 TR Knowledge Graph
- 150 Transactions
- 142 REDI API
- 1.7K TREP APIs
- 4 CAT
- 21 DACS Station
- 117 Open DACS
- 1.1K RFA
- 103 UPA
- 172 TREP Infrastructure
- 224 TRKD
- 886 TRTH
- 5 Velocity Analytics
- 5 Wealth Management Web Services
- 60 Workspace SDK
- 9 Element Framework
- 5 Grid
- 13 World-Check Data File
- Yield Book Analytics
- 46 中文论坛