03-20-2007
There are two flavors of message queues... the old System V version (msgsend(), msgget(), etc) and the newer Posix version (mq_send(), mq_recieve(), etc). The Posix version is newer and more efficient.
Someone must be listening to a socket or you can't use it. A message queue stores the data until some process reads it. This could be minutes or hours later. Also you could have several processes take turns reading a message queue...like the tellers at a bank taking the next customer from a common queue. If the queue gets too long, add another teller at the bank or another instance of a server process on your system.
This User Gave Thanks to Perderabo For This Post:
10 More Discussions You Might Find Interesting
1. Programming
Hi all,
I've been trying for hours to figure out how to turn my 2-program (one to send and one to receive) "chat system" using message queues, into a single program where each concurrent component (entity) will both send and receive messages. PLEASE give me a hand with this, I'm starting to... (9 Replies)
Discussion started by: mgchato
9 Replies
2. UNIX for Dummies Questions & Answers
let 3 processes a, b and c are sharing msgs using msg queues.process 'a' sending msg to 'c' and in turn 'c' send sthat msg to 'b'.if something happens to c how can 'a' and 'b' know that 'c' is not available?????? (2 Replies)
Discussion started by: sukaam
2 Replies
3. Solaris
We have message queues created from our ERP system to our tax system via an application api written by the ERP software vendor.
Occasionally when a user does not gracefully exit the ERP application, the message queue hangs. After a few months, this becomes a problem as the queues are all used... (2 Replies)
Discussion started by: MizzGail
2 Replies
4. Linux
how to check the maximun number of message queues in current linux enviornment? is there any command ? (4 Replies)
Discussion started by: princelinux
4 Replies
5. Programming
Hi,
According to my understanding..
When message queues are used, when a process post a message in the queue and if another process reads it from the queue then the queue will be empty unlike shared memory where n number of processess can access the shared memory and still the contents remain... (2 Replies)
Discussion started by: rvan
2 Replies
6. UNIX for Advanced & Expert Users
#include <sys/ipc.h>
#include <sys/msg.h>
int main()
{
int qid;
int t;
struct msgbuf mesg;
qid=msgget(IPC_PRIVATE,IPC_CREAT);
mesg.mtype=1L;
mesg.mtext=1;
t=msgsnd(qid,&mesg,1,0);
printf("%d",t);
}
the program prints -1 as the result of msgsnd ,which means that msgsnd doesn't... (1 Reply)
Discussion started by: tolkki
1 Replies
7. UNIX for Dummies Questions & Answers
can any body provide a tutorial that explains the concept of message queues in UNIX in great detail (1 Reply)
Discussion started by: asalman.qazi
1 Replies
8. Programming
Hi,
I have searched the forums and could not find a relavant thread discussing my use case, hence the new post.
Basically am trying to pass on work to dummy worker instances from controller which will pass on work to workers (client)
To make use of host capacity, am planning to serialize... (2 Replies)
Discussion started by: matrixmadhan
2 Replies
9. Shell Programming and Scripting
i have an application installed on AIX 5.3 and i have made a script that shutdown a proccesses that exceeded 10000kb of memory usage but i have a problem with cleaning the message queues of these proccesses after shutting them down. Is there any way to clean the message queues for this particular... (8 Replies)
Discussion started by: Portabello
8 Replies
10. UNIX for Advanced & Expert Users
i have a program(C++ Code) that sends/receives information through queue's (Uses MQ)
Is there any UNIX/LINUX tool that calculates the load and performance time for the same.
If not how do i design the program that calculates the performance time.
i know that time.h can be used but it gives... (2 Replies)
Discussion started by: vkca
2 Replies
LEARN ABOUT HPUX
mq_receive
mq_receive(2) System Calls Manual mq_receive(2)
NAME
mq_receive - receive a message from a message queue
SYNOPSIS
DESCRIPTION
The system call receives the oldest of the highest priority message from the message queue specified by mqdes. The selected message is
removed from the queue and copied to the buffer pointed to by the msg_ptr argument. The argument, msg_len, specifies the size of the buffer
in bytes. The value of msg_len should be greater than or equal to the mq_msgsize attribute of the message queue, or will fail.
If the argument msg_prio is not NULL, the priority of the message removed from the queue is stored in the location pointed to by msg_prio.
If the specified message queue is empty and the flag is not set in the message queue blocking status associated with mqdes, will block in
priority order, until it can receive a message from the queue, or until is interrupted by a signal. If the specified message queue is empty
and the flag is set in the message queue blocking status associated with mqdes, will not wait for a message to arrive on the queue and
will return with an error.
To use this function, link in the realtime library by specifying on the compiler or linker command line.
RETURN VALUE
returns the following values:
n Successful completion. n is the size of the selected message in bytes and the message is removed from the queue.
Failure.
is set to indicate the error and no message is removed from the queue.
ERRORS
If fails, is set to one of the following values:
[EAGAIN] The flag is set in the message queue blocking status associated with mqdes, and the message queue is empty.
[EBADF] mqdes is not a valid message queue descriptor open for reading.
[EINTR] A signal interrupted the call to
[EINVAL] msg_ptr points to an invalid address.
[EMSGSIZE] The specified message buffer size, msg_len, is less than the message size attribute of the message queue.
[ENOSYS] is not supported by the implementation.
SEE ALSO
mq_send(2).
STANDARDS CONFORMANCE
mq_receive(2)