남은 디스크 용량을 뽑아서 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;
}
==========================================================================================================
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2690486 | 문자열과 문자형이요 ~ | 다스리 | 2025-04-05 |
2690344 | 일본어 주석 깨짐 문제 (3) | 연하얀 | 2025-04-04 |
2690314 | 암호문 만들기 -비제네르- | 이퓨리한나 | 2025-04-03 |
2690292 | 왕초보자의 질문!!!!!! 도와주세요 (1) | 하랑 | 2025-04-03 |
2690269 | 정올 문제 인데.. 흠 | 반월 | 2025-04-03 |
2690237 | sizeof에서 short형을 썻는데 왜 4byte가 나올까요? (1) | 바나나 | 2025-04-03 |
2690183 | 문자열과 포인트 비교 (2) | 미즈 | 2025-04-02 |
2690154 | a -48 ? | 희미한눈물 | 2025-04-02 |
2690094 | 테트리스 질문요. | 지후 | 2025-04-01 |
2690066 | 문자열비교!! (1) | 매디 | 2025-04-01 |
2689888 | 좀도와주세요;; ㅠㅠ | 사람 | 2025-03-30 |
2689856 | 메뉴 그리는 거 질문 | 나라빛 | 2025-03-30 |
2689831 | c언어 프로그램 추천 | 하연 | 2025-03-30 |
2689801 | c언어 time.h에서 작동이 중지되었습니다. | 하람 | 2025-03-30 |
2689772 | 2차원 배열의 배열명에 대해서.. | 옆집꼬마야 | 2025-03-29 |
2689740 | 게임 TCP소켓 질문 (2) | 불꾼 | 2025-03-29 |
2689711 | 반복문 모래시계 | 한뎃집 | 2025-03-29 |
2689685 | 경우의 수에 따른 결과 처리 질문드립니다. (2) | 다흰 | 2025-03-29 |
2689655 | .exe에 아이콘 넣는 법좀 알려주세요 | 연하얀 | 2025-03-28 |
2689631 | #define 전처리문에 대해서 (2) | 사랑은아픔 | 2025-03-28 |