I am writing a crossplatform, multiprocess and multithreaded server using the "pre forking model" and the C language. Depending on the mode (multiprocess or multithread), the server just started, creates a set of processes/threads whose task is to process the requests of clients that are accepted by the main server. Because child processes are created before accepting a socket, they obviously do not inherit the accepted socket. In win32 I solved, duplicating the socket. How can I do in C linux?
Use a socket accepted by the parent process, in a child process created before accepting the socket
1k Views Asked by AudioBubble At
1
There are 1 best solutions below
Related Questions in C
- How to do an extension of BonitaBPM?
- Edit Bonita BPM portal
- bonita bpm 7-web form does not open in bonita portal
- Change default database of Bonita 6.5
- Bonita jackson Unrecognized token was expecting ('true', 'false' or 'null')
- Node proxy requests from many users to other rest services
- Bonita BPM could not execute statement
- Implement Confirm/alertbox for Submit button in Bonita 6.3.8
- Uploading a new process to an already existing Bonita Application that runs on Docker
- install mysql in Bonita Studio 7.12
Related Questions in LINUX
- How to do an extension of BonitaBPM?
- Edit Bonita BPM portal
- bonita bpm 7-web form does not open in bonita portal
- Change default database of Bonita 6.5
- Bonita jackson Unrecognized token was expecting ('true', 'false' or 'null')
- Node proxy requests from many users to other rest services
- Bonita BPM could not execute statement
- Implement Confirm/alertbox for Submit button in Bonita 6.3.8
- Uploading a new process to an already existing Bonita Application that runs on Docker
- install mysql in Bonita Studio 7.12
Related Questions in SOCKETS
- How to do an extension of BonitaBPM?
- Edit Bonita BPM portal
- bonita bpm 7-web form does not open in bonita portal
- Change default database of Bonita 6.5
- Bonita jackson Unrecognized token was expecting ('true', 'false' or 'null')
- Node proxy requests from many users to other rest services
- Bonita BPM could not execute statement
- Implement Confirm/alertbox for Submit button in Bonita 6.3.8
- Uploading a new process to an already existing Bonita Application that runs on Docker
- install mysql in Bonita Studio 7.12
Related Questions in CLIENT-SERVER
- How to do an extension of BonitaBPM?
- Edit Bonita BPM portal
- bonita bpm 7-web form does not open in bonita portal
- Change default database of Bonita 6.5
- Bonita jackson Unrecognized token was expecting ('true', 'false' or 'null')
- Node proxy requests from many users to other rest services
- Bonita BPM could not execute statement
- Implement Confirm/alertbox for Submit button in Bonita 6.3.8
- Uploading a new process to an already existing Bonita Application that runs on Docker
- install mysql in Bonita Studio 7.12
Related Questions in PREFORKING
- How to do an extension of BonitaBPM?
- Edit Bonita BPM portal
- bonita bpm 7-web form does not open in bonita portal
- Change default database of Bonita 6.5
- Bonita jackson Unrecognized token was expecting ('true', 'false' or 'null')
- Node proxy requests from many users to other rest services
- Bonita BPM could not execute statement
- Implement Confirm/alertbox for Submit button in Bonita 6.3.8
- Uploading a new process to an already existing Bonita Application that runs on Docker
- install mysql in Bonita Studio 7.12
Trending Questions
- UIImageView Frame Doesn't Reflect Constraints
- Is it possible to use adb commands to click on a view by finding its ID?
- How to create a new web character symbol recognizable by html/javascript?
- Why isn't my CSS3 animation smooth in Google Chrome (but very smooth on other browsers)?
- Heap Gives Page Fault
- Connect ffmpeg to Visual Studio 2008
- Both Object- and ValueAnimator jumps when Duration is set above API LvL 24
- How to avoid default initialization of objects in std::vector?
- second argument of the command line arguments in a format other than char** argv or char* argv[]
- How to improve efficiency of algorithm which generates next lexicographic permutation?
- Navigating to the another actvity app getting crash in android
- How to read the particular message format in android and store in sqlite database?
- Resetting inventory status after order is cancelled
- Efficiently compute powers of X in SSE/AVX
- Insert into an external database using ajax and php : POST 500 (Internal Server Error)
Popular # Hahtags
Popular Questions
- How do I undo the most recent local commits in Git?
- How can I remove a specific item from an array in JavaScript?
- How do I delete a Git branch locally and remotely?
- Find all files containing a specific text (string) on Linux?
- How do I revert a Git repository to a previous commit?
- How do I create an HTML button that acts like a link?
- How do I check out a remote Git branch?
- How do I force "git pull" to overwrite local files?
- How do I list all files of a directory?
- How to check whether a string contains a substring in JavaScript?
- How do I redirect to another webpage?
- How can I iterate over rows in a Pandas DataFrame?
- How do I convert a String to an int in Java?
- Does Python have a string 'contains' substring method?
- How do I check if a string contains a specific word?
Use an Unix domain socket instead of a pipe for any control communication between the parent and the child. Unlike pipes, they are bidirectional. If you use a datagram socket, each
send()
corresponds to onerecv()
and vice versa (ie. message boundaries are retained), which makes passing structures and such easier.The point is, you can pass descriptors between processes using an Unix domain socket. The cmsg man page has example code.
Essentially, before you fork the child processes, you create an Unix domain socket pair, unique for each child process, for control communication between the parent and the child. I recommend using an Unix domain datagram socket.
When the parent process wishes to hand off a connection to a child process, it sends the child a message, with an
SCM_RIGHTS
ancillary message containing the connected socket descriptor. (The kernel will handle the details of copying the descriptor over; just note that the descriptor number may differ in the receiving process.)This approach works not only in Linux, but in BSDs also.