Getting EAGAIN error while sending


 
Thread Tools Search this Thread
Special Forums IP Networking Getting EAGAIN error while sending
# 1  
Old 10-25-2010
Getting EAGAIN error while sending

Hi Guys

I am using one non blocking socket to send message to the servers.I am using Solaris OS .I am using default buffer size for the socket.The message I am sending roughly size is 20 bytes.I am sending such 18 messages.But I am getting EAGAIN error very occasionally while sending those messages .I observed when I am rebooting the system and send those 18 messages I am getting that EGAIN error .But if Again I am sending those messages afterwards its not giving me any error .Is there any specific reason why its happening after re-boot.

Moreover I want to know when its giving EGAIN its there any way to know how much send buffer is occupied.I dnt have acess to the code of server.So can it be problem of receiving buffer?
# 2  
Old 10-25-2010
You have to delay the send with a timer in a loop, say retry 10 times, then throw a fatal error or just log an error and go on to the next send();
Code:
         struct timespec tsp={0, 200};  // note you may well sleep longer than the interval....
         int rc=0;
         int i=0;
         fprintf(stderr, "%s: OSS port blocking a send\n", now());
         for(i=0; i< 10; i++)
            {
                 nanosleep(&tsp, NULL);
                 if( (rc=send(s, p, len, 0)>0) )
                 {
                          fprintf(stdout, "%s: OSS port send completed\n");
                          break;
                 }
          }

you have to handle the problem in your code;
# 3  
Old 10-25-2010
i think it's not related buffer size..this is probably read (like uncompleted read) on socket problem for some reasons (slow network or high load )..
for this in your code you can set timeout (probably already ) or increase a bit

Code:
 ..........
 
struct timeval {
        int wait_time.tv_sec;   
        int wait_time.tv_usec; 
    }; 
............
 
wait_time.tv_sec  = 30; /* "wait_time.tv_sec  = 1 * 60; " change try to one minute  */
wait_time.tv_usec = 0;
.....
 
select(max_descriptor+1, &read_flags,&write_flags,(fd_set*)0,&wait_time);
......

This User Gave Thanks to ygemici For This Post:
# 4  
Old 10-26-2010
Thanks for your response
Is there any way to identify how much buffer is available for the socket ?
# 5  
Old 10-26-2010
hi

firstly did you try @jim mcnamara and my advices and what is happen?

secondly i m not sure but probably check buff size like below if is already predefined
Code:
getconf -a |grep SOCK_MAXBUF

and set and get send/rec buff size
maybe try like below

for setsocketpacket
Code:
 
#include <sys/types.h>
#include <sys/socket.h> 
..........
..........
int newMaxBuffset = 8192;
int err = setsockopt(socketfd, SOL_SOCKET, SO_SNDBUF, (char *)&newMaxBuffset, (int)sizeof(newMaxBuffset));

or
Code:
int err = setsockopt(socketfd, SOL_SOCKET, SO_RCVBUF, (char *)&newMaxBuffset, (int)sizeof(newMaxBuffset));

and for getsocketpacket
Code:
int type, size;
size = sizeof(int);
if(getsockopt(socketfd, SOL_SOCKET, SO_SNDBUF, (char*)&type,&size)<0){
...
....
}
 
if(getsockopt(socketfd, SOL_SOCKET, SO_RCVBUF, (char*)&type,&size)<0){
....
.....
}

# 6  
Old 10-27-2010
Thanks for your Reply.I am getting max buffer size for sending as 65525.Which is not so less I guess.

We are sending 12 messages of size 20Bytes .And we are doing it localserver only.



---------- Post updated 10-27-10 at 01:49 AM ---------- Previous update was 10-26-10 at 05:32 AM ----------




Hi
I am trying use flush(socket) to clean up the buffer.But flush is blocking the blow .its stuck there only.Any reason that flush is not supported in Non blocking call .Please Clarify
Login or Register to Ask a Question

Previous Thread | Next Thread

10 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

"Execution problem". Getting error without sending e-mail

Hi, This is the end of the script. When i try to execute the script, i am getting the error. Please help me as to what is wrong with this script.? elif echo 'Load Failed -- Return Code =' $rc subject="Consent table load failed" ( echo "The log file is attached to... (1 Reply)
Discussion started by: msrahman
1 Replies

2. Shell Programming and Scripting

Getting error while sending mail via smtp

Hi All, I used before a simple routine code in tcl to send mail. package require smtp package require mime package require Tcl proc send_simple_message {recipient email_server subject body} { set token mime::setheader $token Subject $subject smtp::sendmessage $token \ ... (0 Replies)
Discussion started by: zivsegal
0 Replies

3. High Performance Computing

MPI - Error on sending argv

Hi all, I write a simple MPI program to send a text message to another process. The code is below. (test.c) #include "mpi.h" #include <stdio.h> #include <stdlib.h> #include <string.h> int main(int argc, char* argv) { int dest, noProcesses, processId; MPI_Status status; ... (0 Replies)
Discussion started by: awiles
0 Replies

4. Shell Programming and Scripting

Error while sending email from solaris

Dears, I have tried to send email, but i have following error. 051 mydomain.net: Name server timeout i have add following line to /etc/resolv.conf domain mydomain.net But didn't work, i didn't configure anything else .. Do i need to configure anything else ???? root#xxx@mydomain.net...... (0 Replies)
Discussion started by: Danish Shakil
0 Replies

5. Shell Programming and Scripting

error while sending mails through MKS

#!/bin/ksh email0="dummy@company.com" emails() { # mail Generation echo "Hi" | /mapimail -s "-(Test Mail)From Production- `date`" $email0; } emails i receive the following error IDispatch::new MSMAPI.MAPISession failed: 800401f3 at... (0 Replies)
Discussion started by: Vrgurav
0 Replies

6. Shell Programming and Scripting

sending mail error.. help

help i get this error when i sending a mail send-mail: fatal: open /etc/postfix/main.cf: No such file or directory Can't send mail: sendmail process failed this is my coding echo "$PRONAME is being restart" | mailxs "Subject:Process" "sally@$THISHOST" i wish to send this mail to my... (2 Replies)
Discussion started by: kkc
2 Replies

7. Shell Programming and Scripting

unix - c program sending error from DB to email

hi, i have a database table that automatically logs the errors in the database every 5 mins. what i want to happen is to come up with a program using unix-c that gets all the information from the log table, i have a flag initially set to zero which means that the error is not yet sent, the... (2 Replies)
Discussion started by: chino_52284
2 Replies

8. UNIX for Dummies Questions & Answers

Sending email

I have an Solaris 8 machine running a managment application. One of the features of this application is to configure alarm forwarding to an email undress. When i configured the application to do that, it asked me only about the recipient email address. Quesiton: how to configure my Solaris 8... (7 Replies)
Discussion started by: bcheaib
7 Replies

9. HP-UX

Sending Error msg from HP-UX to E-mail address

Sometimes, for any reason, the UX System sends messages to /var/mail/root and/or to Error Log of the guardian. I'll appreciating if you help me to configure so that those messages are also sent to the System Administrator's e-mail address. Regards Gege (1 Reply)
Discussion started by: cgege
1 Replies

10. UNIX for Dummies Questions & Answers

Error when sending mail attachment

I have been sending an email attachment from my unix box, but keep getting an error? All though the recipient still receives the email and attachment. Will this error cause problems in the future and how to I cure it? $ uuencode PReSvPRINTER.txt file | mailx -s "File" me@world.com uuencode:... (1 Reply)
Discussion started by: dbrundrett
1 Replies
Login or Register to Ask a Question