doujiu1447
doujiu1447
2017-02-26 22:53
浏览 104

golang-使用io.Copy的怪异字符从bufio.Reader复制到STDOUT

I have an application that attaches to a docker container to get its output using the containerAttach() function provided by the docker library. That function returns a HijackedResponse struct with a pointer to a bufio.Reader.

I'm trying to stream text from the bufio.Reader to stdout and getting unexpected characters in the strings written to stdout.

The code:

_, err := io.Copy(os.Stdout, hijackedResponse.Reader)

Expected output:

Refreshing Terraform state in-memory prior to plan...
The refreshed state will be used to calculate this plan, but
will not be persisted to local or remote state storage.

Actual output:

6Refreshing Terraform state in-memory prior to plan...
=The refreshed state will be used to calculate this plan, but
9will not be persisted to local or remote state storage.

I have no idea where the first character in each of those lines has come from. Any help would be much appreciated. If needed I can provide more details around the docker container & attach options I'm using in my code although I'm assuming they're fine as I'm getting the output via the reader.

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

1条回答 默认 最新

  • dongzongxun8491
    dongzongxun8491 2017-02-26 23:45
    已采纳

    I found the problem - my containerConfig needed to specify Tty: true

    点赞 评论

相关推荐