/***********
*전역변수
***********/
sem_t bin_sem;
pid_t pid[임의의 수];
listen(serverfd)
for (i = 0; i < 임의의 수; i++)
{
pid[i] = fork();
if (pid[i] == 0)
{
sem_post( &bin_sem );
processloop(serverfd);
sem_wait( &bin_sem );
exit(0);
}
}
if( pid[i] > 0 )
{
exit( 0 );
}
child_proc(serverfd)
{
...
while (1)
{
nready = select();
if (FD_ISSET(listenfd, &rset))
{
newfd = accept();
}
for (i = 0; i < 1024; i ++ )
{
if (FD_ISSET(sockfd, &rset))
{
client_sock(sockfd, &allset, maxi, client);
}
if(FD_ISSET( client->m_sock, &write_set ))
{
sendbuff(................);
}
}
}
...
}
대략 이런식으로 코드를 짰는데...프로세스끼리 동기화가 이루어지지 않습니다.
하나의 클라이언트가 들어오면.. 모든 프로세스가 깨어납니다. 그래서 나름대로
세마포어로 프로세스를 관리 해보려고 했는데.. 잘안됩니다. 언뜻 보기에도 세마포어를
잘못쓰는것 같은데...???? 세마포어를 어떻게 설정해서 써야하나요..
자세한 설명 부탁드리겠습니다.
찾기는 조금 힘들듯 싶구요. 책을 찾아보시는 것이 좋겠네요.
유닉스 네트웍 프로그래밍이란 책이 있는데, 여러 상황에 대한 처리가 잘 나와 있더군요. 다만 번역이 매끄럽지 않아서
- 아니 차라리 용어에 대한 번역은 안하는게 더 나을 정도 - 이해하는데 걸림돌이 있긴 합니다. 또한 보통은 fork에 비해서
스레드로 처리하는 경우가 많기 때문에 이 것도 같이 공부하시는 것이 이해에 도움이 될 듯 합니다.