LoginSignup
23
9

More than 3 years have passed since last update.

GoをMacでビルドしたらエラーになったのでコンテナの中でビルドして解決した

Last updated at Posted at 2020-01-27

状況

  • GoによるでAPI開発をMac上で行っていた。
  • ローカルではdocker-composeでコンテナの中でgo runを実行して開発を行っていた。
  • そこで実環境では以下のような手法でデプロイしようと試みた
    • ①Mac上でgo buildしてバイナリ作成
    • ②バイナリを実行するdocker imageを作成
    • ③ECRにpush
    • ④ECS(Fargate)上で動かす
  • そこで②のdocker imageの作成まで行い、先ずローカルで試しにdocker runしたところ以下のようなエラーが発生して起動に失敗した。
standard_init_linux.go:211: exec user process caused "exec format error"

原因

  • ググりまくったところMacとLinuxでアーキテクチャが異なり、ビルド対象が違うことがわかった。
  • 試しにEC2でAmazon linuxを立てて①~④を実行したところ問題なく動いた!

    • 上記のアーキテクチャの違いが原因であると推定し、linux上でgoをビルドすれば動くことが分かった
  • 当時の悲鳴

    対処①

  • 原因のところにも書いたようにEC2でビルドしてpushすればとりあえず動く。

  • しかしながら以下のような問題がある。

    • ビルドのためだけにインスタンスを立てるのは微妙
    • ECRにpushするための接続情報をインスタンス上に置いておきたくない
  • したがって廃案!

対処②

  • Mac上にLinuxのコンテナを立ててビルドすればLinux向けにビルドしてくれるのではないかと考えた。
    • 以下のようなdocker-compose-build.ymlを作成した
      • ローカルの$GOPATH/src/hogeが作成していたapiのディレクトリだとする
      • golangの公式イメージを使用
      • コンテナの中の$GOPATH/goだったのでその配下にローカルの$GOPATHをマウントさせる。
      • この場合hogeが作成していたapiのディレクトリなのでマウントした/go/src/hogeworking_dirに指定してgo build -o bin/hogeを実行して$GOPATH/src/hoge/bin/hogeにバイナリを出力
version: '3'
services:
  go:
    image: golang
    container_name: golang_build
    volumes:
      - $GOPATH:/go
    working_dir: /go/src/hoge
    command: bash -c "go build -o bin/hoge"
    environment:
      - TZ=Asia/Tokyo
      - ENV_GO=development
  • これをdocker-compose -f docker-compose-build.yml upで実行したところデプロイまで成功!
  • この対処②を採用した!

その他や感想など

  • 本題と逸れるので記載しないが実際にはdocker-compose -f docker-compose-build.yml up,docker-compose -f docker-compose-build.yml down,docker build ~をコマンド一発で行うMakefileを作成して対応した。
  • 本当はこの手のビルド周りはCIに任せたいが稟議に出すのが面倒だったのでローカルで完結させた。
    • 同じような悩みを抱えてCIを使えない方は参考になるのではないでしょうか!
23
9
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
23
9