남은 디스크 용량을 뽑아서 IP와 함께 보내주는 소스인데 컴파일이 되지 않습니다.
가랑비
질문 제목 : 남은 디스크 용량을 뽑아서 IP와 함께 보내주는 소스인데 컴파일이 안되네요. 어디가 문제인지 모르겠습니다.
5대의 서버에서 잔여 용량을 구한 후, 용량이 많은 순서대로 요청한 대상에게 IP와 용량 정보를 전달해주는 것을 만들고 있습니다.
어느정도 된거 같은데, 컴파일이 안되네요...하나를 고치면 다른게 생겨나고, 뭐가 문제인지 어떻게 해야되는지 모르겠습니다.질문 내용 :
2가지의 소스를 올려드립니다. 컴파일이 되지 않는데, 어디가 문제인지 모르겠습니다.
하나를 고치니 또 다른게 생겨나고, 근본적으로 뭐가 잘못된지 모르겠습니다.
리눅스 vi로 코딩 후 gcc로 컴파일하고 있습니다.
기능은 둘째 문제고,컴파일이라도 되었으면 좋겠네요... ㅠㅠ
아래에 소스 적었습니다. 혹시 몰라서 파일로도 첨부합니다.
1) 첫번째 소스 입니다.
/*ManageSvr.c*/
#include stdio.h
#include stdlib.h
#include string.h
#include unistd.h
#include arpa/inet.h
#include sys/types.h
#include sys/socket.h
//------------------------------------------------------------------------------
// 글로벌 변수 정의
char g_StorageIp[],[20] =
{
192.168.0.1,
192.168.0.2,
192.168.0.2,
192.168.0.3,
192,168.0.4
};
int g_StoragePort = 7777;
//------------------------------------------------------------------------------
// 데이터 통신 구조체 정의
struct t_StorageInfo
{
char [20] szIp; // Server IP Address
unsigned long long nTotalSize; // Storage Total Size
unsigned long long nFreeSize; // Storage Free Size
};
//------------------------------------------------------------------------------
// 메인함수
int main(int argc, char **argv)
{
// 전체 스토리지 서버의 갯수
int nCnt = sizeof(g_StorageIp) / sizeof(g_StorageIp[0]);
// 가장 큰 스토리지 서버의 정보
t_StorageInfo stSelStorageInfo;
memset(&stSelStorageInfo, 0, sizeof(stSelStorageInfo));
// 전체 스토리지 서버의 갯수만큼 반복하면 모든 스토리지 서버의 정보를 확인
for(int i = 0; i nCnt; i++)
{
//소캣 생성
int nStorageSock = socket(PF_INET, SOCK_STREAM, 0);
if( nStorageSock 0 )
break; // 소켓 생성안되니까 그만!!
// IP 확인
char szIp[20] = {0};
sprintf(szIp, %s, g_StorageIp[i]);
//서버 소켓 연결 설정값 지정
struct sockaddr_in stStorageSvrAddr;
memset(&stStorageSvrAddr, 0, sizeof(stStorageSvrAddr));
stStorageSvrAddr.sin_family = AF_INET;
stStorageSvrAddr.sin_addr.s_addr = inet_addr(g_StorageIp[i]); // i번째 서버의 IP
stStorageSvrAddr.sin_port = htons(atoi(g_StoragePort)); // 지정된 포트만 사용!!
//서버로 접속
if( connect(nStorageSock, (struct sockaddr*)&stStorageSvrAddr, sizeof(stStorageSvrAddr)) 0 )
{
close(stStorageSvrAddr);
continue;
}
//서버로부터 정보를 읽어드림
t_StorageInfo stInfo;
memset(&stInfo, 0, sizeof(stInfo));
int nRead = recv(nStorageSock, (char *)stInfo, sizeof(stInfo)); br ));
if( nRead = 0 )
{
close(nStorageSock);
continue;
}
// 저장된 값이 없으면..
if( strlen(stSelStorageInfo.szIp) = 0 )
{
// 저장
sprintf(stSelStorageInfo.szIp, %s, g_StorageIp[i]);
stSelStorageInfo.nTotalSize = stInfo.nTotalSize;
stSelStorageInfo.nFreeSize = stInfo.nFreeSize;
}
// 남은 용량을 비교!!
else
{
if( stSelStorageInfo.nFreeSize stInfo.nFreeSize )
{
memset(&stSelStorageInfo, 0, sizeof(stSelStorageInfo));
sprintf(stSelStorageInfo.szIp, %s, g_StorageIp[i]);
stSelStorageInfo.nTotalSize = stInfo.nTotalSize;
stSelStorageInfo.nFreeSize = stInfo.nFreeSize;
}
}
//소켓 닫기
close(nStorageSock);
}
// 클라이언트에 남은 용량이 제일 많은 서버의 IP 주소를 전달
return 0;
}
============================================================================================================
============================================================================================================
2) 2번째 소스 입니다.
/*StorageSvr.c*/
#include stdio.h
#include stdlib.h
#include string.h
#include unistd.h
#include arpa/inet.h
#include sys/types.h
#include sys/socket.h
#include sys/statvfs.h
//------------------------------------------------------------------------------
// 함수 및 변수 정의
int g_StoragePort = 7777;
void error_handling(char *message);
unsigned long long get_capacity(char *dev_path); // Get Storage Total Size (Byte)
unsigned long long get_free_space(char *dev_path); // Get Storage Free Size (Byte)
//------------------------------------------------------------------------------
// 데이터 통신 구조체 정의
struct t_StorageInfo
{
char [20] szIp; // Server IP Address
unsigned long long nTotalSize; // Storage Total Size
unsigned long long nFreeSize; // Storage Free Size
};
//------------------------------------------------------------------------------
// 메인 함수
int main(int argc, char **argv)
{
// 서버 소켓 생성
int iSrvSock = socket(PF_INET, SOCK_STREAM, 0); // TCP 소켓 생성
if( iSrvSock 0 )
{
printf(Server Listen Port is %d\n, g_StoragePort);
exit(1);
}
// 서버 소켓 연결 설정값 셋팅
struct sockaddr_in stSrvAddr;
memset(&stSrvAddr, 0, sizeof(stSrvAddr));
stSrvAddr.sin_family = AF_INET;
stSrvAddr.sin_addr.s_addr = htonl(INADDR_ANY);
stSrvAddr.sin_port = htons(g_StoragePort);
// 서버 소켓 연결 설정
if( bind(stSrvAddr, (struct sockaddr*) &serv_addr, sizeof(serv_addr)) 0 )
{
printf(Server Bind Error\n);
close(iSrvSock);
exit(1);
}
// 서버 소켓 연결 대기
if( listen(stSrvAddr, 5) 0 )
{
printf(Server Listen Error\n);
close(iSrvSock);
exit(1);
}
printf(Start Server\n);
// 종료 명령이 내려질 때 까지.. 계속 동작!!
int bStop = 0;
while( bStop == 0 )
{
// 사용자 입력으로 종료 확인
// 연결된 클라이언트 소켓
struct sockaddr_in stClientAddr;
int nClientAddrSize = sizeof(stClientAddr);
// 새로운 클라이언트 소켓이 연결!!
int iClientSock = accept(stSrvAddr, (struct sockaddr*)&stClientAddr, &nClientAddrSize);
if( iClientSock 0 )
continue;
// 클라이언트 요청을 읽어들임
char szReq[10] = {0};
int nRead = recv(iClientSock, szReq, 10);
// 중지할 지 판단
if( nRead 0 )
{
// 클라이언트에서 중지 요청
if( strcmp(szReq, stop) == 0 )
bStop = 1;
}
// 전송할 데이터 구조체 초기화
t_StorageInfo stInfo;
memset(&stInfo, 0, sizeof(stInfo));
// 현재 서버정보 설정
sprintf(stInfo.szIp, %d.%d.%d.%d,
stClientAddr.sin_addr.s_addr & 0x00FF,
stClientAddr.sin_addr.s_addr 8 & 0x00FF,
stClientAddr.sin_addr.s_addr 16 & 0x00FF,
stClientAddr.sin_addr.s_addr 24 & 0x00FF);
// 현재 서버의 드라이브 크기(전체, 남은용량)을 확인
stInfo.nTotalSize = get_capacity(/);
stInfo.nFreeSize = get_free_space(/);
// 메시지를 연결된 클라이언트로 전송!!
send(iClientSock, (char *)stInfo, sizeof(stInfo);
// 연결된 클라이언트 소켓 닫기
close(iClientSock);
}
printf(Stop Server\n);
return 0;
}
//------------------------------------------------------------------------------
// 스토리지 전체 용량 확인
unsigned long long get_capacity(char *dev_path)
{
unsigned long long result = 0;
int n;
char s_cap[50];
char * ss_cap = N/A;
struct statvfs sfs;
if (statvfs (dev_path, &sfs) !=-1){
result = (unsigned long long)sfs.f_bsize *sfs.f_blocks;
}
return result;
}
//------------------------------------------------------------------------------
// 스토리지 남은 용량 확인
unsigned long long get_free_space(char *dev_path)
{
unsigned long long result = 0;
int n;
char s_cap[50];
char *ss_cap = N/A;
struct statvfs sfs;
if (statvfs (dev_path, &sfs) != -1){
result = (unsigned long long)sfs.f_bsize *sfs.f_bfree;
}
return result;
}
==========================================================================================================
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2694069 | unsigned 질문입니다. | 힘차 | 2025-05-07 |
2694012 | 전공 비전공자 개발자 (10) | 말글 | 2025-05-07 |
2693984 | 오버로딩이 무엇인가요? (2) | 헛매질 | 2025-05-07 |
2693956 | PlaySound재생이 안됩니다!(C에 음악넣기) | 지존 | 2025-05-06 |
2693928 | &와 *의 사용에 관한 명확한 이해 | 제나 | 2025-05-06 |
2693903 | 반복문 설명좀요 ㅠㅠ (2) | 란새 | 2025-05-06 |
2693869 | stdio.h 는 왜 쓰는건가요? (1) | 큰꽃들 | 2025-05-06 |
2693842 | 포인터 변수의 주소값끼리 더하는 것에 대해서 질문드립니다. (1) | 진솔 | 2025-05-05 |
2693811 | 소수 출력;;;; | 화이트캣 | 2025-05-05 |
2693788 | 이런 함수는 없나요? (3) | 앤드류 | 2025-05-05 |
2693758 | txt파일 불러와서 행렬로 저장 | 큰애 | 2025-05-05 |
2693727 | scanf 오류 문제!! (2) | 큰나래 | 2025-05-04 |
2693704 | 구조체 주소록 문제인데 도와주세요 (2) | 도1도캣 | 2025-05-04 |
2693676 | 열혈강의 c언어 질문입니다 | 하양이 | 2025-05-04 |
2693647 | 12.620000 을요 12.620 으로 어떻게 표현해요? (2) | 파도 | 2025-05-04 |
2693619 | 타이틀 코드.. | 단순드립 | 2025-05-03 |
2693591 | 컴파일 에러에서 질문드립니다 (3) | 게자리 | 2025-05-03 |
2693463 | 동적할당 이용시 fwrite사용을 어떻게 해야하나요..? (10) | 일본어못해요 | 2025-05-02 |
2693387 | 배열문제입니다 수정오류캡쳐했습니다 (6) | 연하얀 | 2025-05-01 |
2693356 | text 입출력 내림차순 질문입니다 ㅠ | 빛글 | 2025-05-01 |