데이타베이스 디자인을 어떻게 해야 될지 고민입니다.
p2p서버를 짜는 중인데요. p2p 서버는 클라이언트들이 가지고 있는 파일 목록들을 데이타베이스를 이용해서 관리하려고 합니다.
우선 생각한 테이블 디자인은 다음과 같습니다.
첫째로, 접속한 클라이언트들의 목록을 저장하는 테이블을 만듭니다.
이 테이블의 애트리뷰트는 2개로 아이피주소와 소켓번호입니다.(한 컴퓨터내에서 다중접속을 허용하므로, 소켓번호도 포합시켰습니다.)
둘째로, 하나의 접속 클라이언트마다 그 클라이언트가 공유하고 있는 파일목록들을 저장하는 테이블을 만듭니다. 이 테이블의 애트리뷰트는 1개로, 파일이름입니다. 한 row에 파일명 1개씩이 저장됩니다. 그리고 테이블명은 해당 클라이언트의 소켓 번호로 할 생각입니다.
위와 같이 디자인을 해놓고 보면, 우선 클라이언트가 서버에 접속을 해서 파일 목록을 업로드 할때 접속 정보를 테이블에 저장하고, 새로운 파일목록 테이블을 만드는 것에서는 별 무리가 없습니다.그리고 클라이언트가 서버와의 접속을 끊을때에에도 접속 정보를 삭제하고, 해당하는 파일 목록 테이블을 삭제하는 것도 별 무리가 없습니다.
헌데 어떤 클라이언트가 특정 이름으로 된 파일을 검색할 때 약간의 애로 사항이 있습니다. 즉, 어떤 클라이언트가 검색을 해달라고 서버에 요청을 하면, 서버는 현재 자신이 가지고 있는 파일 목록 테이블 모두를 뒤져야 하는데요. 그럴려면, 테이블 이름을 모두 알고 있어야 합니다. 그래서 생각한 방식이 서버 프로그램에서 클라이언트가 접속할 때마다 그 클라이언트의 소켓 번호를 특정 어레이에 차곡차곡 저장을 하는 방식입니다. 그런데 이렇게 하는것 말고, 서버에서는 그 어떤 정보도 저장해 있지 않고 데이타베이스에만 의존해서 검색을 진행하고 싶습니다.
테이블 디자인을 어떻게 하면 이런것이 효율적으로 가능할까요? 이왕이면 검색할 때, 쿼리 한번에 검색이 되었으면 좋겠습니다만... 아니면 위 디자인말고 좀 더 효율적인 디자인이 있으면 한 수 알려주시기 부탁드립니다.
음..
[하나의 접속 클라이언트마다 그 클라이언트가 공유하고 있는 파일목록들을 저장하는 테이블을 만듭니다]
테이블을 따로 만들지 말고.
특정 테이블에
클라이언트 구별 키와 파일 이름을 함께 두어 구분하는 것은 어떨까요?
그런데 왜 파일 목록을 서버가 관리해야 하죠?
(혹시..다른 흑심이..=_=?)
https://nicesj.com
https://blog.nicesj.com
댓글 달기