Microsoft MVP성태의 닷넷 이야기
오류 유형: 816. Golang - "short write" 오류 원인 [링크 복사], [링크+제목 복사],
조회: 14408
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

Golang - "short write" 오류 원인

아직 초기라 그런 것인지, 원래 Go 언어 영역의 개발자라면 다 아는 것인지 모르겠지만 ^^; TCP Socket 연결로부터 구성한 bufio.Writer를 통해,

dialer := net.Dialer{Timeout: 5 * time.Second}
conn, err := dialer.Dial("tcp", "127.0.0.1:18000")

my.reader = bufio.NewReader(conn)
my.writer = bufio.NewWriter(conn)

소켓으로 데이터 쓰기를 했는데 불특정한 순간에 오류가 발생합니다.

func (my *MySocket) Write(packet []byte) {

    _, err := my.writer.Write(packet)
    if err != nil {
        panic(fmt.Errorf("failed to send data to data server: %w", err))
    }
}

재미있는 건, 저렇게 해서 출력되는 "err"의 "%w" 포맷 메시지가 단순히 "short write" 두 단어라는 점입니다. ^^; 다행히도, 검색해 보면 답이 나오는데요,

How to solve "short write" error when writing to CSV
; https://stackoverflow.com/questions/66174520/how-to-solve-short-write-error-when-writing-to-csv

그렇습니다, 동기화를 해줘야 하는 것입니다. ^^

// writeLock = new(sync.Mutex)

func (my *MySocket) Write(packet []byte) {
    writeLock.Lock()
    defer writeLock.Unlock()

    _, err := my.writer.Write(packet)
    if err != nil {
        panic(fmt.Errorf("failed to send data to data server: %w", err))
    }
}

기존의 프로그래밍 언어와는 달리 Go 언어의 경우 go routine을 통한 다중 스레드가 보편화되어 있어 thread-safe한 처리가 더 중요하게 되었으니, 사용하려는 개체들에 대한 꼼꼼한 접근 관리를 할 필요가 있습니다.

이런 의미에서 'short write' 단어를 다시 보면 이때의 short가 단락, 합선을 의미하는 뜻인 듯합니다. 동기화 대기를 해야 하는 상황에서 그냥 치고 들어와서 문제가 발생했다는... 뭐 그런 식의... 메시지로 보입니다. ^^




참고로, 위의 bufio.Write의 버퍼링이 워낙 잘 되어 있어서 위와 같이 코드를 작성한 경우 마지막 Write 데이터가 전달되지 않을 수 있습니다. 즉, Write 후 곧바로 전송하고 싶다면 반드시 Flush를 호출해야 합니다.

// writeLock = new(sync.Mutex)

func (my *MySocket) Write(packet []byte) {
    writeLock.Lock()
    defer writeLock.Unlock()

    _, err := my.writer.Write(packet)
    if err != nil {
        panic(fmt.Errorf("failed to send data to data server: %w", err))
    }

    my.writer.Flush()
}




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







[최초 등록일: ]
[최종 수정일: 7/6/2022]

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)
1152정성태10/20/201123796.NET Framework: 251. string.GetHashCode는 hash 값을 cache 할까?
1151정성태10/18/201122708Java: 13. 자바도 64비트에서 (2GB) OutOfMemoryException 예외가 발생할까?
1150정성태10/18/201129943.NET Framework: 250. WPF - ComboBox의 SelectionChagned 이벤트파일 다운로드1
1149정성태10/16/201125603.NET Framework: 249. WPF - d:DesignHeight 값을 구할 수 있을까?
1148정성태10/14/201131588Java: 12. 자바에서 LINQ 사용? [7]
1147정성태10/13/201127530.NET Framework: 248. 닷넷에서 지원되는 문자열 인코딩 이름 목록
1146정성태10/12/201133236.NET Framework: 247. LINQ에서의 Max 기능 구현 [10]파일 다운로드1
1144정성태10/10/201128918.NET Framework: 246. WCF - 서버 측에서의 유효한 Timeout 설정파일 다운로드1
1143정성태10/9/201134485.NET Framework: 245. ASP.NET 서버 측 코드에서 페이스북 계정 연동하는 방법
1142정성태10/8/201134985.NET Framework: 244. 윈도우 폼을 열고 닫는 것만으로 메모리 leak이 발생할까? [2]파일 다운로드1
1141정성태10/7/201133614.NET Framework: 243. DataTable에 대해서 Dispose 메서드를 호출할 필요가 있을까? [4]파일 다운로드1
1140정성태10/6/201126780.NET Framework: 242. 닷넷 개발자 입장에서 이해해 보는 자바의 서블릿, JSP
1138정성태10/1/201144917Java: 11. 웹 로직에서 MS-SQL 서버 연결 [2]
1137정성태9/30/201130006Java: 10. 닷넷 개발자가 설치해 본 Oracle WebLogic Server - 설치 및 기본 도메인 구성
1136정성태9/29/201125419개발 환경 구성: 131. Visual Studio - ASP.NET의 Code-behind처럼 cs 파일을 그룹핑하는 매크로 함수 [2]파일 다운로드1
1135정성태9/29/201122865오류 유형: 138. TF10216: Team Foundation services are currently unavailable
1134정성태9/27/201130308.NET Framework: 241. C# 5.0에 새로 추가된 Caller Info 특성 [5]
1133정성태9/25/201133582VC++: 54. C++로 만든 WinRT 프로그램 [2]
1132정성태9/24/201173062Java: 9. 자바의 keytool.exe 사용법과 Tomcat의 SSL 통신 설정
1131정성태9/23/201129265Java: 8. 닷넷 개발자가 구현해 본 자바 웹 서비스 (2)
1130정성태9/23/201137257Java: 7. 닷넷 개발자가 구현해 본 자바 웹 서비스 (1)파일 다운로드2
1129정성태9/22/201128896개발 환경 구성: 130. Hyper-V에 MS-DOS VM 만드는 방법 - MSDN 구독자 대상 [3]
1128정성태9/20/201129067오류 유형: 137. KB2449742 보안 업데이트로 인한 충돌 문제 해결 - 두 번째 이야기
1127정성태9/19/201133158Java: 6. Java에서 MySQL 사용 [2]
1126정성태9/18/201128270Math: 3. "유클리드 호제법"과 "Bezout's identity" 구현 코드(C#)파일 다운로드1
1125정성태9/17/201126189Windows: 54. Windows 8 개발자 Preview를 사용해 보고... [2]
... 151  152  153  154  155  [156]  157  158  159  160  161  162  163  164  165  ...