Allow support to compile multi platform architecture
This commit is contained in:
parent
26f5f80811
commit
ace523e058
|
@ -0,0 +1,21 @@
|
||||||
|
name: cloudflared
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
paths:
|
||||||
|
- '!**/*.md'
|
||||||
|
pull_request:
|
||||||
|
paths:
|
||||||
|
- '!**/*.md'
|
||||||
|
branches:
|
||||||
|
- master
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v1
|
||||||
|
- name: Build Container Image
|
||||||
|
run: |
|
||||||
|
TARGET_GOARCH=arm make container
|
11
Dockerfile
11
Dockerfile
|
@ -1,8 +1,11 @@
|
||||||
# use a builder image for building cloudflare
|
# use a builder image for building cloudflare
|
||||||
|
ARG TARGET_GOOS=linux
|
||||||
|
ARG TARGET_GOARCH=arm
|
||||||
FROM golang:1.13.3 as builder
|
FROM golang:1.13.3 as builder
|
||||||
ENV GO111MODULE=on
|
ENV GO111MODULE=on \
|
||||||
ENV CGO_ENABLED=0
|
CGO_ENABLED=0 \
|
||||||
ENV GOOS=linux
|
GOOS=${TARGET_GOOS} \
|
||||||
|
GOARCH=${TARGET_GOARCH}
|
||||||
|
|
||||||
WORKDIR /go/src/github.com/cloudflare/cloudflared/
|
WORKDIR /go/src/github.com/cloudflare/cloudflared/
|
||||||
|
|
||||||
|
@ -12,8 +15,6 @@ COPY . .
|
||||||
# compile cloudflared
|
# compile cloudflared
|
||||||
RUN make cloudflared
|
RUN make cloudflared
|
||||||
|
|
||||||
# ---
|
|
||||||
|
|
||||||
# use a distroless base image with glibc
|
# use a distroless base image with glibc
|
||||||
FROM gcr.io/distroless/base-debian10:nonroot
|
FROM gcr.io/distroless/base-debian10:nonroot
|
||||||
|
|
||||||
|
|
30
Makefile
30
Makefile
|
@ -1,4 +1,4 @@
|
||||||
VERSION := $(shell git describe --tags --always --dirty="-dev")
|
VERSION := $(shell git rev-parse HEAD)
|
||||||
DATE := $(shell date -u '+%Y-%m-%d-%H%M UTC')
|
DATE := $(shell date -u '+%Y-%m-%d-%H%M UTC')
|
||||||
VERSION_FLAGS := -ldflags='-X "main.Version=$(VERSION)" -X "main.BuildTime=$(DATE)"'
|
VERSION_FLAGS := -ldflags='-X "main.Version=$(VERSION)" -X "main.BuildTime=$(DATE)"'
|
||||||
|
|
||||||
|
@ -16,8 +16,26 @@ ifeq ($(EQUINOX_IS_DRAFT), true)
|
||||||
EQUINOX_FLAGS := --draft $(EQUINOX_FLAGS)
|
EQUINOX_FLAGS := --draft $(EQUINOX_FLAGS)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifeq ($(GOARCH),)
|
LOCAL_ARCH ?= $(shell uname -m)
|
||||||
GOARCH := amd64
|
ifeq ($(LOCAL_ARCH),x86_64)
|
||||||
|
TARGET_GOARCH ?= amd64
|
||||||
|
else ifeq ($(shell echo $(LOCAL_ARCH) | head -c 5),armv8)
|
||||||
|
TARGET_GOARCH ?= arm64
|
||||||
|
else ifeq ($(LOCAL_ARCH),aarch64)
|
||||||
|
TARGET_GOARCH ?= arm64
|
||||||
|
else ifeq ($(shell echo $(LOCAL_ARCH) | head -c 4),armv)
|
||||||
|
TARGET_GOARCH ?= arm
|
||||||
|
else
|
||||||
|
$(error This system's architecture $(LOCAL_ARCH) isn't supported)
|
||||||
|
endif
|
||||||
|
|
||||||
|
LOCAL_OS ?= $(shell uname)
|
||||||
|
ifeq ($(LOCAL_OS),Linux)
|
||||||
|
TARGET_OS ?= linux
|
||||||
|
else ifeq ($(LOCAL_OS),Darwin)
|
||||||
|
TARGET_OS ?= darwin
|
||||||
|
else
|
||||||
|
$(error This system's OS $(LOCAL_OS) isn't supported)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
.PHONY: all
|
.PHONY: all
|
||||||
|
@ -29,11 +47,11 @@ clean:
|
||||||
|
|
||||||
.PHONY: cloudflared
|
.PHONY: cloudflared
|
||||||
cloudflared: tunnel-deps
|
cloudflared: tunnel-deps
|
||||||
go build -v -mod=vendor $(VERSION_FLAGS) $(IMPORT_PATH)/cmd/cloudflared
|
GOOS=$(TARGET_OS) GOARCH=$(TARGET_GOARCH) go build -v -mod=vendor $(VERSION_FLAGS) $(IMPORT_PATH)/cmd/cloudflared
|
||||||
|
|
||||||
.PHONY: container
|
.PHONY: container
|
||||||
container:
|
container:
|
||||||
docker build -t cloudflare/cloudflared:"$(VERSION)" .
|
docker build -t cloudflare/cloudflared-$(TARGET_GOARCH):$(VERSION) .
|
||||||
|
|
||||||
.PHONY: test
|
.PHONY: test
|
||||||
test: vet
|
test: vet
|
||||||
|
@ -48,7 +66,7 @@ cloudflared-deb: cloudflared
|
||||||
mkdir -p $(PACKAGE_DIR)
|
mkdir -p $(PACKAGE_DIR)
|
||||||
cp cloudflared $(PACKAGE_DIR)/cloudflared
|
cp cloudflared $(PACKAGE_DIR)/cloudflared
|
||||||
fakeroot fpm -C $(PACKAGE_DIR) -s dir -t deb --deb-compression bzip2 \
|
fakeroot fpm -C $(PACKAGE_DIR) -s dir -t deb --deb-compression bzip2 \
|
||||||
-a $(GOARCH) -v $(VERSION) -n cloudflared cloudflared=/usr/local/bin/
|
-a $(TARGET_OS) -v $(VERSION) -n cloudflared cloudflared=/usr/local/bin/
|
||||||
|
|
||||||
.PHONY: cloudflared-darwin-amd64.tgz
|
.PHONY: cloudflared-darwin-amd64.tgz
|
||||||
cloudflared-darwin-amd64.tgz: cloudflared
|
cloudflared-darwin-amd64.tgz: cloudflared
|
||||||
|
|
Loading…
Reference in New Issue