【openeuler/go容器镜像使用简介】

在这里插入图片描述

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.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值