在这里插入图片描述

Quick reference

Go | openEuler

Current Go(Golang) docker images are built on the openEuler. This repository is free to use and exempted from per-user rate limits.

Go is expressive, concise, clean, and efficient. Its concurrency mechanisms make it easy to write programs that get the most out of multicore and networked machines, while its novel type system enables flexible and modular program construction. Go compiles quickly to machine code yet has the convenience of garbage collection and the power of run-time reflection. It’s a fast, statically typed, compiled language that feels like a dynamically typed, interpreted language.

Learn more on Go website.

Supported tags and respective Dockerfile links

The tag of each Go docker image is consist of the version of Go and the version of basic image. The details are as follows

TagsCurrentlyArchitectures
1.17.3-oe2203ltsgo 1.17.3 on openEuler 22.03-LTSamd64, arm64
1.22.5-oe2203sp4go 1.22.5 on openEuler 22.03-LTS-SP4amd64, arm64

Usage

Note: /go is world-writable to allow flexibility in the user which runs the container (for example, in a container started with --user 1000:1000, running go get github.com/example/... into the default $GOPATH will succeed). While the 777 directory would be insecure on a regular host setup, there are not typically other processes or users inside the container, so this is equivalent to 700 for Docker usage, but allowing for --user flexibility.

  • Start a Go instance in your app

    The most straightforward way to use this image is to use a Go container as both the build and runtime environment. In your Dockerfile, writing something along the lines of the following will compile and run your project (assuming it uses go.mod for dependency management):

    # Dockerfile
    FROM openeuler/go:{Tag}
    
    WORKDIR /usr/src/app
    COPY go.mod go.sum ./
    RUN go mod download && go mod verify
    COPY . .
    RUN go build -v -o /usr/local/bin/app ./...
    CMD ["app"]
    

    You can then build and run the Docker image:

    docker build -t my-golang-app .
    docker run -it --rm --name my-running-app my-golang-app
    
  • Compile your app inside the Docker container

    There may be occasions where it is not appropriate to run your app inside a container. To compile, but not run your app inside the Docker instance, you can write something like:

    docker run --rm -v "$PWD":/usr/src/myapp -w /usr/src/myapp golang:1.22 go build -v
    

    This will add your current directory as a volume to the container, set the working directory to the volume, and run the command go build which will tell go to compile the project in the working directory and output the executable to myapp. Alternatively, if you have a Makefile, you can run the make command inside your container.

    docker run --rm -v "$PWD":/usr/src/myapp -w /usr/src/myapp golang:1.22 make
    
  • Cross-compile your app inside the Docker container
    If you need to compile your application for a platform other than linux/amd64 (such as windows/386):

    docker run --rm -v "$PWD":/usr/src/myapp -w /usr/src/myapp -e GOOS=windows -e GOARCH=386 golang:1.22 go build -v
    

    Alternatively, you can build for multiple platforms at once:

    $ docker run --rm -it -v "$PWD":/usr/src/myapp -w /usr/src/myapp golang:1.22 bash
    $ for GOOS in darwin linux; do
    >   for GOARCH in 386 amd64; do
    >     export GOOS GOARCH
    >     go build -v -o myapp-$GOOS-$GOARCH
    >   done
    > done
    
  • View container running logs

    docker logs -f my-go
    
  • To get an interactive shell

    docker exec -it my-go /bin/bash
    

Question and answering

If you have any questions or want to use some special features, please submit an issue or a pull request on openeuler-docker-images.

点赞(0) 打赏

评论列表 共有 0 条评论

暂无评论

微信公众账号

微信扫一扫加关注

发表
评论
返回
顶部