프로세스간 struct 주고받기+socket

hbsnow의 이미지

fork(){ // 1번프로세스
while(1){
해당 작업수행으로 링크드리스트 생성
만들어진 링크드리스트를 2번프로세스에게 보냄
sleep(300); //5분마다 수행
}
}

fork(){ // 2번프로세스
1. 1번에서 만든 링크드리스트를 받음
2. 새로운 링크드리스트 생성
3. UI요청시마다 링크드리스트 내용을 Socket으로 보내줌

}

1번 프로세스에서 2번 프로세스로 1번프로세스가 작업한 링크드리스트를 5분마다 2번프로세스에게 넘겨주어야 합니다.
먼저 어떤 IPC를 사용하는게 가장 효율적일까요?

그리고 2번프로세스는 UI에서 오는 요청에 대해 항상 응답을 해주어야 합니다.
그 응답은 1번에서 보내준 링크드리스트정보를 다시 가공해서 알려주는 것입니다.

결국 2번프로세스는 IPC와 Socket에 관련된 작업을 각각 동기적으로 작업을 시켜야 하는데 방법을 찾기가 힘드네요

고수님들에 조언을 부탁드립니다. 작은 의견이라도.....

june8th의 이미지

작은 의견입니다. ;-)

1번 process와 2번 process가 다른 시스템에 있지 않다면
(IPC를 사용하신다기에..)
File을 쓰면 어떨까요?

1번 process는 file에 주기적으로 쓰고
2번 process는 file을 주기적으로 읽고..

고도리의 이미지

unix domain socket에 한표 던집니다.

제가 원래 System V IPC(msg q, semaphore, shared memory)를
별루 신뢰를 안하는 편이라서...^^;

큰 어려움 없을 것 같은데요....

서명.....음, 서명이라...

아싸!!! Three Go!

wizcat의 이미지

pipe나 message queue가 무난할듯..

file을 동시에 read, write하는것은 좀 문제의 소지가..

jemiro의 이미지

공유할 데이터가 많다면,
쓰레드 모델도 고려해볼만 하다고 봅니다.

hbsnow의 이미지

모든 분들이 IPC를 어떨걸 쓰면 좋을까?에 대한 답변을 해주고 계시는데요
더 궁극적인 문제는 두번째꺼 입니다.

하나의 프로세스에서
1. IPC로 링크드리스트 받는거
2. 다른 컴퓨터로부터 socket요청을 받는거

이두가지를 어떻게 동기화를 시킬꺼냐 그겁니다.

둘다 수행 시점은 랜덤하기에 말입니다.

그럼...

sysadmin의 이미지

select()나 poll() 함수로 양쪽을 다 감시하면 되지 않을까요?
제가 알기로는 socket이나 IPC들은
위의 함수를 이용해서 감시가 되는 걸로 알고 있는데..

choissi의 이미지

한쪽을 기준으로 작업을 하는게 좋을것 같네요
전, 소켓을 기준으로 작업을 하겠습니다.

ui요청일 올라오는 fd에 select를 걸어주고
데이터가 오는 시점이 300초 이니 적당하게 select 타임아웃을
설정해주어서 메모리를 갱신 해주는 거죠..

ui 갱신용 데이터를 좀 더 실시간 이 필요 하다면

fd모니터링을 할때 udp를 같이 걸어서
ipc로 데이터를 다 쓴 다음 udp로 통지를 주는것도 괜찮겠죠.
(시그널도 좋구요)

울랄라~ 호기심 천국~!!
http://www.ezdoum.com

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.