Qiita Teams that are logged in
You are not logged in to any team

Log in to Qiita Team
Community
OrganizationAdvent CalendarQiitadon (β)
Service
Qiita JobsQiita ZineQiita Blog
7
Help us understand the problem. What is going on with this article?
@whisky-shusuky

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

More than 1 year has passed since last update.

状況

  • 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を使えない方は参考になるのではないでしょうか!
7
Help us understand the problem. What is going on with this article?
Why not register and get more from Qiita?
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away
whisky-shusuky
一応サーバーサイドエンジニアですが面白そうなことには何でも首を突っ込みます。 Ruby/Rails/golang/gin/Terraform/Unity/GLSL

Comments

No comments
Sign up for free and join this conversation.
Sign Up
If you already have a Qiita account Login
7
Help us understand the problem. What is going on with this article?