[Haskell-cafe] Multicast receiver thread fails to receive last few messages

Kyle Marek-Spartz kyle.marek.spartz at gmail.com
Tue Sep 23 15:46:16 UTC 2014


I would try forking your sending thread, too, rather than using the main thread for sending. Alternatively, use the main thread for receiving and fork your sending thread.

–  
Kyle Marek-Spartz
  
  
  
  
  
On Sep 23, 2014, 10:14:09 AM, Ben Gunton <ben.gunton at gmail.com> wrote:  
I am trying to send multicast messages from one thread, and receive them on another. The sending thread reads lines from a file and sends them. However, the receiving thread does not receive all the messages - it seems to miss the last 10 message or so. If I run other programs to listen for the multicast message, they receive them fine. So I think the issue is something to do with receiving, not sending. I keep the program alive with a threadDelay, so it shouldn't be halting prematurely. If I add a small delay after each send, it works fine. And if I make the input file smaller, it works fine.

On the provided data file, on my system (64-bit Ubuntu, GHC 7.8.2), the receiver fails to receive lines 125-140. Compiled with no optimizations.  

Thanks for any help!  

The relevant code snippets are below, and the sample data file and full program are attached.  

    -- Loop to receive all the packets  
    let receiveMulticast = do
            (msg, _) <- recvFrom recvSock 32628
            putStrLn . BS.unpack $ BS.take 100 msg
            receiveMulticast
    _ <- forkIO receiveMulticast

    -- Send every line from a file as multicast message  
    inputFile <- openFile "data" ReadMode
    fileLines <- BS.lines <$> BS.hGetContents inputFile
    let sendMulticast msg = do
            sendTo sendSock msg addr
            -- Receiver FAILS to receive last few messages unless this  
            -- thread delay exists... why?!
            -- threadDelay (1)  
    mapM_ sendMulticast fileLines
    hClose inputFile

    threadDelay (1000*1000*1000) -- Delay for 1000 seconds  
- data, 71 KB
- Main.hs, 2.2 KB
_______________________________________________
Haskell-Cafe mailing list
Haskell-Cafe at haskell.org
http://www.haskell.org/mailman/listinfo/haskell-cafe


-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://www.haskell.org/pipermail/haskell-cafe/attachments/20140923/c850725c/attachment.html>


More information about the Haskell-Cafe mailing list