Microsoft MVP성태의 닷넷 이야기
VC++: 150. Golang - TCP client/server echo 예제 코드 [링크 복사], [링크+제목 복사],
조회: 13712
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일

Golang - TCP client/server echo 예제 코드


서버 측 코드와,

package main

import (
    "io"
    "log"
    "net"
    "strconv"
    "strings"
    "time"
)

func main() {
    sock, err := net.Listen("tcp", ":18080")
    if err != nil {
        log.Fatalf("Failed to bind address: %v", err)
    }
    
    defer sock.Close()
    
    for {
        conn, err := sock.Accept()
        if err != nil {
            log.Printf("Failed to accept: %v", err)
            continue
        }
        
        go ClientHandler(conn)
    }
}

func ClientHandler(conn net.Conn) {
    defer conn.Close()

    recvBuf := make([]byte, 4096)

    for {

        readBytes, err := conn.Read(recvBuf)
        if err != nil {
            if err == io.EOF {
                log.Printf("Client closed the socket: %v", conn.RemoteAddr().String())
                return
            }

            log.Printf("Failed to receive data: %v", err)
            return
        }

        if readBytes > 0 {
            data := recvBuf[:readBytes]

            if number, err := strconv.Atoi(strings.Trim(string(data), string('\n'))); err == nil {
                time.Sleep(time.Duration(number) * time.Second)
            }

            conn.Write(data)

            log.Println(string(data))
        } else {
            log.Println("Can you see me?")
        }

    }
}

클라이언트 측 예제 코드입니다.

package main

import (
    "bufio"
    "fmt"
    "io"
    "log"
    "net"
    "os"
    "strconv"
    "strings"
)

func main() {
    socket, err := net.Dial("tcp", "localhost:18080")
    if err != nil {
        log.Fatalf("Failed to connect to server: %v", err)
        return
    }

    defer socket.Close()
    console := bufio.NewReader(os.Stdin)
    recvBuf := make([]byte, 4096)

    for {
        fmt.Print("socket> ")
        text, _ := console.ReadString('\n')

        if number, err := strconv.Atoi(strings.Trim(string(text), string('\n'))); err == nil {
            fmt.Printf("Echo delayed: %v\n", number)
        }

        if text == "quit\n" {
            break
        }
        socket.Write([] byte(text))

        readBytes, err := socket.Read(recvBuf)
        if err != nil {
            if err == io.EOF {
                fmt.Printf("Server closed the socket: %v", socket.RemoteAddr().String())
                return
            }

            fmt.Printf("Failed to receive data: %v", err)
            return
        }

        if readBytes > 0 {
            data := recvBuf[:readBytes]
            fmt.Println(string(data))
        } else {
            fmt.Println("Can you see me?")
        }
    }
}

실행하면, 서버와 클라이언트의 출력이 각각 다음과 같은 식으로 나옵니다.

[서버 측]
2021/09/03 15:39:10 test

2021/09/03 15:39:12 qwer

2021/09/03 15:39:18 5

2021/09/03 15:39:23 Client closed the socket: [::1]:1264


[클라이언트 측] socket> test test socket> qwer qwer socket> 5 Echo delayed: 5 5 socket> quit Debugger finished with the exit code 0




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 9/6/2021]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 151  152  153  154  155  156  157  158  159  160  161  [162]  163  164  165  ...
NoWriterDateCnt.TitleFile(s)
998정성태2/27/201120200Team Foundation Server: 42. TFS Application-Tier만 재설치
996정성태2/12/201137662디버깅 기술: 35. windbg - 분석 예: 시작하자마자 비정상 종료하는 프로세스 - NullReferenceException
995정성태2/11/201156234.NET Framework: 205. 코드(C#)를 통한 풀 덤프 만드는 방법 [4]
994정성태2/10/201136087디버깅 기술: 34. Windbg - ERROR: Unable to load DLL mscordacwks_x86_x86_2.0.50727.4200.dll, Win32 error 0n2 [1]
993정성태2/10/201128495개발 환경 구성: 107. 하나의 WPF 프로젝트를 WinExe / Library로 빌드하는 방법
992정성태10/15/201129345개발 환경 구성: 106. VSS(Volume Shadow Service)를 이용한 Hyper-V VM 백업/복원 [2]
991정성태2/6/201148767개발 환경 구성: 105. 풀 덤프 파일을 남기는 방법 [4]
990정성태2/2/201133979개발 환경 구성: 104. Visual C++ Custom Build Tool 사용예 [1]파일 다운로드1
989정성태2/1/201130477개발 환경 구성: 103. DOS batch - 동기 방식으로 원격 서비스 제어
988정성태1/30/201126621개발 환경 구성: 102. MSBuild - DefineConstants에 다중 전처리 값 설정
987정성태1/29/201139819디버깅 기술: 33. PDB Symbol 로드 오류 - Cannot find or open the PDB file. [2]
986정성태1/26/201131213.NET Framework: 204. 분리된 ThreadPool 사용 - Smart Thread Pool
985정성태1/25/201127912디버깅 기술: 32. 인증서로 서명된 닷넷 어셈블리의 실행 지연 현상
984정성태1/25/201122565개발 환경 구성: 101. SharePoint 2010 - Form Design
983정성태1/23/201127584제니퍼 .NET: 15. 눈으로 확인하는 maxWorkerThreads, minFreeThreads 설정값 [1]
982정성태1/22/201124893개발 환경 구성: 100. SharePoint 2010 - iPad 친화적인 게시판 만들기 (사용자 지정 목록) [1]
981정성태1/19/201120777개발 환경 구성: 99. SharePoint 2010 - 웹 애플리케이션 생성 시 고려해야 할 점. [1]
980정성태1/19/201132235개발 환경 구성: 98. SharePoint 2010 - Office Web Apps 설치
979정성태1/18/201124977개발 환경 구성: 97. SharePoint 2010 팀 사이트 구성
978정성태1/16/201131909.NET Framework: 203. VPN 자동 연결 및 Router 설정 추가
977정성태1/12/201131284개발 환경 구성: 96. SharePoint 2010 설치 [5]
976정성태1/11/201153873오류 유형: 111. IIS - 500.19 오류 (0x8007000d)
975정성태1/10/201128094.NET Framework: 202. CLR JIT 컴파일러가 생성한 기계어 코드 확인하는 방법 [3]파일 다운로드1
974정성태1/8/201126930.NET Framework: 201. 윈폼 TreeView - Bold 폰트 설정 후 텍스트가 잘리는 문제 [1]파일 다운로드1
973정성태1/7/201126234.NET Framework: 200. IIS Metabase와 ServerManager 개체 활용파일 다운로드1
972정성태1/7/201124257개발 환경 구성: 95. SQL Server 2008 R2 이하 버전 정보 확인
... 151  152  153  154  155  156  157  158  159  160  161  [162]  163  164  165  ...