edgex0.7.1_1.0.1的X86编译和交叉编译

一. X86编译

1. 安装zeromq库

根据setup script安装:

wget https://github.com/zeromq/libzmq/releases/download/v4.2.2/zeromq-4.2.2.tar.gz
tar xvzf zeromq-4.2.2.tar.gz
cd zeromq-4.2.2
./configure
sudo make install
sudo ldconfig
ldconfig -p | grep zmq
libzmq.so.5 (libc6,x86-64) => /usr/local/lib/libzmq.so.5
libzmq.so (libc6,x86-64) => /usr/local/lib/libzmq.so

export PKG_CONFIG_PATH=/usr/local/lib/pkgconfig/

2. 获取源码

go get github.com/edgexfoundry/edgex-go

3. 安装依赖包

edgex0.7.1采用glide管理go工程

$ glide install
[INFO]    Lock file (glide.lock) does not exist. Performing update.
[INFO]    Downloading dependencies. Please wait...
[INFO]    --> Fetching updates for github.com/BurntSushi/toml
[INFO]    --> Fetching updates for github.com/eclipse/paho.mqtt.golang
[INFO]    --> Fetching updates for github.com/stretchr/testify
[INFO]    --> Fetching updates for github.com/hashicorp/consul
[INFO]    --> Fetching updates for github.com/docker/docker
[INFO]    --> Fetching updates for github.com/gorilla/mux
[INFO]    --> Fetching updates for github.com/docker/go-units
[INFO]    --> Fetching updates for github.com/go-zoo/bone
[INFO]    --> Fetching updates for github.com/docker/go-connections
[INFO]    --> Fetching updates for github.com/mitchellh/consulstructure
[INFO]    --> Fetching updates for github.com/pelletier/go-toml
[INFO]    --> Fetching updates for github.com/pebbe/zmq4
[INFO]    --> Fetching updates for github.com/robfig/cron
[INFO]    --> Fetching updates for gopkg.in/mgo.v2
[INFO]    --> Fetching updates for gopkg.in/yaml.v2
[INFO]    --> Fetching updates for github.com/mattn/go-xmpp
[INFO]    --> Fetching updates for github.com/satori/go.uuid
[INFO]    --> Fetching updates for github.com/magiconair/properties
[INFO]    --> Fetching updates for github.com/docker/distribution
[INFO]    --> Fetching updates for github.com/gomodule/redigo
[INFO]    --> Setting version for github.com/mattn/go-xmpp to e543ad3fcd51155e4b39f7487bdfcb5e3772f1ce.
[INFO]    --> Setting version for github.com/docker/docker to b1116479b23434de7d70710b6454af7cb2484a58.
[INFO]    --> Setting version for github.com/docker/go-connections to 97c2040d34dfae1d1b1275fa3a78dbdd2f41cf7e.
[INFO]    --> Setting version for github.com/docker/go-units to 47565b4f722fb6ceae66b95f853feed578a4a51c.
[INFO]    --> Setting version for github.com/BurntSushi/toml to a368813c5e648fee92e5f6c30e3944ff9d5e8895.
[INFO]    --> Setting version for github.com/mitchellh/consulstructure to b407c521973b7b902db2f09e65dbf5cb10f2dc5f.
[INFO]    --> Setting version for github.com/docker/distribution to 16128bbac47f75050e82f7e91b04df33775e0c23.
[INFO]    --> Setting version for github.com/go-zoo/bone to 9eaad4b99a9a66b85c0cc32cb9691621ccfa4278.
[INFO]    --> Detected semantic version. Setting version for github.com/pelletier/go-toml to v1.2.0
[INFO]    --> Detected semantic version. Setting version for github.com/hashicorp/consul to v1.1.0
[INFO]    --> Detected semantic version. Setting version for github.com/stretchr/testify to v1.2.1
[INFO]    --> Detected semantic version. Setting version for github.com/gorilla/mux to v1.3.0
[INFO]    --> Detected semantic version. Setting version for github.com/pebbe/zmq4 to v1.0.0
[INFO]    --> Detected semantic version. Setting version for github.com/robfig/cron to v1.1.0
[INFO]    --> Detected semantic version. Setting version for github.com/gomodule/redigo to v2.0.0
[INFO]    --> Detected semantic version. Setting version for github.com/magiconair/properties to v1.8.0
[INFO]    --> Detected semantic version. Setting version for github.com/satori/go.uuid to v1.2.0
[INFO]    --> Detected semantic version. Setting version for github.com/eclipse/paho.mqtt.golang to v1.1.1
[INFO]    --> Setting version for gopkg.in/mgo.v2 to 3f83fa5005286a7fe593b055f0d7771a7dce4655.
[INFO]    --> Setting version for gopkg.in/yaml.v2 to eb3733d160e74a9c7e442f435eb3bea458e1d19f.
[INFO]    Resolving imports
[INFO]    --> Fetching updates for github.com/gorilla/context
[INFO]    --> Fetching updates for github.com/davecgh/go-spew
[INFO]    --> Fetching updates for github.com/pmezard/go-difflib
[INFO]    --> Fetching updates for github.com/stretchr/objx
[INFO]    --> Fetching golang.org/x/net/proxy
[WARN]    Unable to checkout golang.org/x/net/proxy
[ERROR]    Error looking for golang.org/x/net/proxy: Cannot detect VCS
[INFO]    --> Fetching golang.org/x/net/websocket
[WARN]    Unable to checkout golang.org/x/net/websocket
[ERROR]    Error looking for golang.org/x/net/websocket: Cannot detect VCS
[INFO]    --> Fetching updates for github.com/influxdata/influxdb
[INFO]    --> Fetching updates for github.com/hashicorp/go-cleanhttp
[INFO]    --> Fetching updates for github.com/hashicorp/go-rootcerts
[INFO]    --> Fetching updates for github.com/hashicorp/serf
[INFO]    --> Fetching updates for github.com/cenkalti/backoff
[INFO]    --> Fetching updates for github.com/mitchellh/copystructure
[INFO]    --> Fetching updates for github.com/mitchellh/mapstructure
[INFO]    --> Fetching updates for github.com/opencontainers/go-digest
[INFO]    --> Fetching updates for github.com/pkg/errors
[INFO]    --> Fetching golang.org/x/net/context/ctxhttp
[WARN]    Unable to checkout golang.org/x/net/context/ctxhttp
[ERROR]    Error looking for golang.org/x/net/context/ctxhttp: Cannot detect VCS
[ERROR]    Error scanning github.com/influxdata/influxdb/client/v2: cannot find package "." in:
    /home/wang/.glide/cache/src/https-github.com-influxdata-influxdb/client/v2
[INFO]    --> Fetching updates for github.com/mitchellh/go-homedir
[INFO]    --> Fetching updates for github.com/armon/go-metrics
[INFO]    --> Fetching updates for github.com/mitchellh/reflectwalk
[INFO]    --> Fetching updates for github.com/opencontainers/image-spec
[INFO]    --> Fetching updates for github.com/Microsoft/go-winio
[WARN]    Unable to set version on golang.org/x/net/proxy to . Err: Cannot detect VCS
[INFO]    --> Fetching updates for github.com/hashicorp/go-immutable-radix
[INFO]    --> Fetching updates for github.com/gogo/protobuf
[INFO]    --> Fetching golang.org/x/sys/windows
[WARN]    Unable to checkout golang.org/x/sys/windows
[ERROR]    Error looking for golang.org/x/sys/windows: Cannot detect VCS
[INFO]    --> Fetching updates for github.com/hashicorp/golang-lru
[WARN]    Unable to set version on golang.org/x/sys/windows to . Err: Cannot detect VCS
[ERROR]    Failed to retrieve a list of dependencies: Error resolving imports

提取如下依赖包错误:

golang.org/x/net/proxy
golang.org/x/net/websocket
golang.org/x/net/context/ctxhttp
golang.org/x/sys/windows

glide搜索到的包应该以git或svn等vcs,但上述proxy、websocket和ctxhttp是net的子包,golang.org/x/net/采用git管理。同样,golang.org/x/sys采用git管理,windows是sys的子目录。此时,可在glide.yaml中指定golang.org/x/net和golang.org/x/sys的子包关系:

- package: golang.org/x/net 
  subpackages:
  - proxy 
  - websocket 
  - context/ctxhttp
- package: golang.org/x/sys
  subpackages:
  - windows

此时,直接设置git管理包的镜像即可,mirror设置:

glide mirror set https://golang.org/x/net https://github.com/golang/net --vcs git
glide mirror set golang.org/x/sys https://github.com/golang/sys --vcs git

此时,glide install成功执行。

注:若安装的依赖包出现错误,可能是包版本不对,需要在glide.yaml中指定软件包的版本(如master中已不包含原来的目录,导致包检索依赖不成功,github.com/influxdata/influxdb/client/v2最新版没有client目录)。

edgex1.0.1采用GO111MODULE管理

首先确保go版本在1.11之上,golang从1.11开始内置module管理功能。

由于golang.org被墙,需要在go.mod中增加替换:

replace (
    bitbucket.org/bertimus9/systemstat => github.com/sigma/systemstat v0.0.0-20180207000608-0eeff89b0690
    golang.org/x/crypto => github.com/golang/crypto v0.0.0-20181029021203-45a5f77698d3
    golang.org/x/net => github.com/golang/net v0.0.0-20181201002055-351d144fa1fc
    golang.org/x/sync => github.com/golang/sync v0.0.0-20181221193216-37e7f081c4d4
    golang.org/x/sys => github.com/golang/sys v0.0.0-20181026203630-95b1ffbd15a5
    golang.org/x/tools => github.com/golang/tools v0.0.0-20181112210238-4b1f3b6b1646
)

4. 编译

make prepare
make build

5. 启动mongodb,然后直接运行make run即可。

在自目录保存数据,如/home/wang/edgex/db 

sudo mongod --dbpath "/home/wang/edgex/db"
mongo init_mongo.js
sudo mongod --dbpath "/home/wang/edgex/db" --shutdown
sudo chown -R mongodb:mongodb "/home/wang/edgex/db"
sudo mongod --dbpath "/home/wang/edgex/db" --auth 
sudo mongod --dbpath "/home/wang/edgex/db" --bind_ip_all ;允许远程访问数据库

make run

若运行报错,可能是mongo权限问题,去除--auth

6.  测试随机数设备

参考4.3.1. Writing a Device Service in Go编译随机数简单设备,运行device-simple可执行文件。

若不报错,且数据一直上报,可通过如下地址查询数据:

http://localhost:48080/api/v1/event/device/RandNum-Device01/100

http://172.61.1.125:48080/api/v1/event
http://172.61.1.125:48071/api/v1/registration
http://172.61.1.125:48080/api/v1/event/count
http://172.61.1.125:48080/api/v1/valuedescriptor
http://172.61.1.125:48081/api/v1/device
http://172.61.1.125:48081/api/v1/deviceservice

可注册mosquitto云平台,上传至云平台:

POST to http://192.168.134.144:48071/api/v1/registration
{"name":"MyMQTTTopic","addressable":{"name":"MyMQTTBroker","protocol":"TCP","address":"192.168.134.144","port":1883,"publisher":"EdgeXExportPublisher","user":"wang","password":"mypass","topic":"a/b/c"},"format":"JSON","enable":true,"destination":"MQTT_TOPIC"}

在主机192.168.134.144上开启mosquitto,并:

$ mosquitto_sub -t a/b/c
{"id":"5cecfb6d902d0f90ade77aca","pushed":0,"device":"RandNum-Device01","created":1559034733008,"modified":0,"origin":1559034733003,"schedule":null,"event":null,"readings":[{"id":"5cecfb6d902d0f90ade77acb","pushed":0,"created":1559034733008,"origin":1559034733002,"modified":0,"device":"RandNum-Device01","name":"Random","value":"58"}]}

二. 交叉编译

Ubuntu16.04上交叉编译edgex 1.0.1,编译后的程序运行于OKMX6DL-S3Cortex-A932位,双核)。

2.1 交叉编译工具链

板卡自带交叉编译工具链应用

. /opt/fsl-imx-x11/4.1.15-2.1.0/environment-setup-cortexa9hf-neon-poky-linux-gnueabi
/opt/fsl-imx-x11/4.1.15-2.1.0/sysroots/x86_64-pokysdk-linux/usr/bin/arm-poky-linux-gnueabi/arm-poky-linux-gnueabi-gcc
/opt/fsl-imx-x11/4.1.15-2.1.0/sysroots/x86_64-pokysdk-linux/usr/bin/arm-poky-linux-gnueabi/arm-poky-linux-gnueabi-g++

通用交叉编译工具链应用

sudo apt-get install g++-5-arm-linux-gnueabihf g++-5-arm-linux-gnueabihf
sudo update-alternatives --install /usr/bin/arm-linux-gnueabihf-gcc arm-linux-gnueabihf-gcc /usr/bin/arm-linux-gnueabihf-gcc-5 100 --slave /usr/bin/arm-linux-gnueabihf-g++ arm-linux-gnueabihf-g++ /usr/bin/arm-linux-gnueabihf-g++-5

注:板卡自带交叉编译工具链编译edgex不成功,随采用通用交叉编译工具链。

2.2 交叉编译zeromq

板卡自带交叉编译工具链应用

./configure --prefix=/home/wang/edgex/edgex_mx6dl/zeromq-4.2.2/winstall --host=arm-poky-linux-gnueabi  CC="/opt/fsl-imx-x11/4.1.15-2.1.0/sysroots/x86_64-pokysdk-linux/usr/bin/arm-poky-linux-gnueabi/arm-poky-linux-gnueabi-gcc --sysroot=$SDKTARGETSYSROOT -mfloat-abi=hard" CXX="/opt/fsl-imx-x11/4.1.15-2.1.0/sysroots/x86_64-pokysdk-linux/usr/bin/arm-poky-linux-gnueabi/arm-poky-linux-gnueabi-g++ --sysroot=$SDKTARGETSYSROOT -mfloat-abi=hard "
make && make install

通用交叉编译工具链应用

./configure --prefix=/home/wang/edgex/edgex_mx6dl/zeromq-4.2.2/winstall --host=arm-poky-linux-gnueabi  CC=arm-linux-gnueabihf-gcc CXX=arm-linux-gnueabihf-g++
make && make install

2.3 交叉编译edgex

采用通用交叉编译器编译edgex,解决包依赖关系后,修改Makefile中编译选项:

GO=GOARCH=arm CGO_ENABLED=0 GO111MODULE=on go
GOCGO=GOARCH=arm CGO_ENABLED=1 CC="arm-linux-gnueabihf-gcc" \
CGO_CFLAGS="-I/home/wang/edgex/edgex_mx6dl/zeromq-4.2.2/winstall/include" CGO_LDFLAGS="-L/home/wang/edgex/edgex_mx6dl/zeromq-4.2.2/winstall/lib -lzmq" \
GO111MODULE=on go

然后执行如下命令编译

make build

将生成的zeromq库文件winstall,edgex生成的bin和cmd,及mongodb编译而成的bin(mongodb自编译有问题,从网上下载2.6.4版本可执行文件)拷贝到板卡并安装。

先启动mongodb,然后执行edgex,同X86上运行顺序,可正确执行并运行。

三. docker镜像制作

生成所有docker可运行命令:

make docker

生成单独docker可运行命令(以docker_export_distro为例):

make docker_export_distro

docker_export_distro:
    docker build \
        -f cmd/export-distro/Dockerfile \
        --label "git_sha=$(GIT_SHA)" \
        -t edgexfoundry/docker-export-distro-go:$(GIT_SHA) \
        -t edgexfoundry/docker-export-distro-go:$(DOCKER_TAG) \
        .

Dockerfile文件如下:

#
# Copyright (c) 2017-2018
# Mainflux
# Cavium
#
# SPDX-License-Identifier: Apache-2.0
#

FROM golang:1.11-alpine AS builder

ENV GO111MODULE=on
WORKDIR /go/src/github.com/edgexfoundry/edgex-go

# The main mirrors are giving us timeout issues on builds periodically.
# So we can try these.

RUN sed -e 's/dl-cdn[.]alpinelinux.org/nl.alpinelinux.org/g' -i~ /etc/apk/repositories

RUN apk update && apk add zeromq-dev libsodium-dev pkgconfig build-base git

COPY go.mod .
#COPY go.sum .

RUN go mod download

COPY . .
RUN make cmd/export-distro/export-distro

FROM alpine

LABEL license='SPDX-License-Identifier: Apache-2.0' \
      copyright='Copyright (c) 2017-2018: Mainflux, Cavium'

# The main mirrors are giving us timeout issues on builds periodically.
# So we can try these.

RUN sed -e 's/dl-cdn[.]alpinelinux.org/nl.alpinelinux.org/g' -i~ /etc/apk/repositories

RUN apk --no-cache add zeromq
COPY --from=builder /go/src/github.com/edgexfoundry/edgex-go/cmd/export-distro/Attribution.txt /
COPY --from=builder /go/src/github.com/edgexfoundry/edgex-go/cmd/export-distro/export-distro /
COPY --from=builder /go/src/github.com/edgexfoundry/edgex-go/cmd/export-distro/res/docker/configuration.toml /res/docker/configuration.toml
ENTRYPOINT ["/export-distro","--registry","--profile=docker","--confdir=/res"]

上述命令生成两个镜像(其中一个在cache中,另一个为实际镜像,两个tag),没有容器产生(docker ps -a不显示,容器被删除):

export-distro容器镜像生成日志:

make docker_export_distro
docker build \
        -f cmd/export-distro/Dockerfile \
        --label "git_sha=48146ead559bd9f27e80af344e3cf787530a1539" \
        -t edgexfoundry/docker-export-distro-go:48146ead559bd9f27e80af344e3cf787530a1539 \
        -t edgexfoundry/docker-export-distro-go:1.0.2-dev \
        .
Sending build context to Docker daemon    161MB
Step 1/18 : FROM golang:1.11-alpine AS builder
 ---> e116d2efa2ab
Step 2/18 : ENV GO111MODULE=on
 ---> Using cache
 ---> 6f17441d1946
Step 3/18 : WORKDIR /go/src/github.com/edgexfoundry/edgex-go
 ---> Using cache
 ---> 1e94eec59dac
Step 4/18 : RUN sed -e 's/dl-cdn[.]alpinelinux.org/nl.alpinelinux.org/g' -i~ /etc/apk/reposi                                                                                                  tories
 ---> Using cache
 ---> 48697136fcca
Step 5/18 : RUN apk update && apk add zeromq-dev libsodium-dev pkgconfig build-base git
 ---> Running in bea28e9e5eb1
fetch http://nl.alpinelinux.org/alpine/v3.10/main/x86_64/APKINDEX.tar.gz
fetch http://nl.alpinelinux.org/alpine/v3.10/community/x86_64/APKINDEX.tar.gz
v3.10.3-17-g2fd4d3cdac [http://nl.alpinelinux.org/alpine/v3.10/main]
v3.10.3-13-g8068beb776 [http://nl.alpinelinux.org/alpine/v3.10/community]
OK: 10340 distinct packages available
(1/28) Installing binutils (2.32-r0)
(2/28) Installing libmagic (5.37-r1)
(3/28) Installing file (5.37-r1)
(4/28) Installing gmp (6.1.2-r1)
(5/28) Installing isl (0.18-r0)
(6/28) Installing libgomp (8.3.0-r0)
(7/28) Installing libatomic (8.3.0-r0)
(8/28) Installing libgcc (8.3.0-r0)
(9/28) Installing mpfr3 (3.1.5-r1)
(10/28) Installing mpc1 (1.1.0-r0)
(11/28) Installing libstdc++ (8.3.0-r0)
(12/28) Installing gcc (8.3.0-r0)
(13/28) Installing musl-dev (1.1.22-r3)
(14/28) Installing libc-dev (0.7.1-r0)
(15/28) Installing g++ (8.3.0-r0)
(16/28) Installing make (4.2.1-r2)
(17/28) Installing fortify-headers (1.1-r0)
(18/28) Installing build-base (0.5-r1)
(19/28) Installing nghttp2-libs (1.39.2-r0)
(20/28) Installing libcurl (7.66.0-r0)
(21/28) Installing expat (2.2.8-r0)
(22/28) Installing pcre2 (10.33-r0)
(23/28) Installing git (2.22.0-r0)
(24/28) Installing libsodium (1.0.18-r0)
(25/28) Installing pkgconf (1.6.1-r1)
(26/28) Installing libsodium-dev (1.0.18-r0)
(27/28) Installing libzmq (4.3.2-r1)
(28/28) Installing zeromq-dev (4.3.2-r1)
Executing busybox-1.30.1-r2.trigger
OK: 182 MiB in 43 packages
Removing intermediate container bea28e9e5eb1
 ---> 650c39be3c34
Step 6/18 : COPY go.mod .
 ---> 3afaf7b13163
Step 7/18 : RUN go mod download
 ---> Running in ca37635ae857
go: finding github.com/stretchr/testify v1.3.0
go: finding github.com/BurntSushi/toml v0.3.1
go: finding github.com/edgexfoundry/go-mod-core-contracts v0.1.0
go: finding github.com/ugorji/go v1.1.4
go: finding github.com/vektra/mockery v0.0.0-20181123154057-e78b021dcbb5
go: finding github.com/imdario/mergo v0.3.6
go: finding github.com/pkg/errors v0.8.1
go: finding github.com/edgexfoundry/go-mod-registry v0.1.0
go: finding github.com/OneOfOne/xxhash v1.2.5
go: finding bitbucket.org/bertimus9/systemstat v0.0.0-20180207000608-0eeff89b0690
go: finding github.com/hashicorp/consul v1.4.2
go: finding github.com/magiconair/properties v1.8.0
go: finding github.com/gorilla/mux v1.7.0
go: finding github.com/go-stack/stack v1.8.0
go: finding github.com/hashicorp/go-cleanhttp v0.5.0
go: finding github.com/gorilla/context v1.1.1
go: finding github.com/robfig/cron v0.0.0-20180505203441-b41be1df6967
go: finding github.com/stretchr/testify v1.2.2
go: finding github.com/mitchellh/go-testing-interface v1.0.0
go: finding github.com/go-kit/kit v0.8.0
go: finding github.com/globalsign/mgo v0.0.0-20181015135952-eeefdecb41b8
go: finding github.com/golang/tools v0.0.0-20181112210238-4b1f3b6b1646
go: finding github.com/gomodule/redigo v2.0.0+incompatible
go: finding github.com/davecgh/go-spew v1.1.1
go: finding github.com/stretchr/objx v0.1.0
go: finding github.com/go-logfmt/logfmt v0.4.0
go: finding github.com/mitchellh/mapstructure v1.1.2
go: finding github.com/edgexfoundry/go-mod-messaging v0.1.8
go: finding github.com/eclipse/paho.mqtt.golang v1.1.1
go: finding github.com/mattn/go-xmpp v0.0.0-20190124093244-6093f50721ed
go: finding github.com/hashicorp/serf v0.8.2
go: finding github.com/cenkalti/backoff v2.1.1+incompatible
go: finding github.com/pebbe/zmq4 v1.0.0
go: finding github.com/hashicorp/go-rootcerts v1.0.0
go: finding gopkg.in/yaml.v2 v2.2.2
go: finding gopkg.in/eapache/queue.v1 v1.1.0
go: finding github.com/davecgh/go-spew v1.1.0
go: finding github.com/mitchellh/copystructure v1.0.0
go: finding github.com/google/uuid v1.1.0
go: finding github.com/pelletier/go-toml v1.2.0
go: finding github.com/mitchellh/go-homedir v1.0.0
go: finding github.com/mitchellh/consulstructure v0.0.0-20190329231841-56fdc4d2da54
go: finding github.com/stretchr/objx v0.1.1
go: finding github.com/kr/logfmt v0.0.0-20140226030751-b84e30acd515
go: finding github.com/pmezard/go-difflib v1.0.0
go: finding github.com/hashicorp/go-syslog v1.0.0
go: finding github.com/hashicorp/memberlist v0.1.3
go: finding github.com/hashicorp/mdns v1.0.0
go: finding github.com/mitchellh/reflectwalk v1.0.0
go: finding github.com/mitchellh/mapstructure v0.0.0-20160808181253-ca63d7c062ee
go: finding github.com/mitchellh/cli v1.0.0
go: finding github.com/armon/go-metrics v0.0.0-20180917152333-f0300d1749da
go: finding github.com/golang/net v0.0.0-20181023162649-9b4f9f5ad519
go: finding github.com/ryanuber/columnize v0.0.0-20160712163229-9b3edd62028f
go: finding github.com/hashicorp/go-msgpack v0.5.3
go: finding github.com/miekg/dns v1.0.14
go: finding github.com/mitchellh/gox v0.4.0
go: finding gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405
go: finding github.com/posener/complete v1.1.1
go: finding github.com/google/btree v0.0.0-20180813153112-4030bb1f1f0c
go: finding github.com/hashicorp/go-immutable-radix v1.0.0
go: finding github.com/hashicorp/go-multierror v1.0.0
go: finding github.com/hashicorp/go-uuid v1.0.1
go: finding github.com/mitchellh/iochan v1.0.0
go: finding github.com/mattn/go-isatty v0.0.3
go: finding github.com/bgentry/speakeasy v0.1.0
go: finding github.com/hashicorp/errwrap v1.0.0
go: finding github.com/hashicorp/go.net v0.0.1
go: finding github.com/armon/go-radix v0.0.0-20180808171621-7fddfc383310
go: finding github.com/hashicorp/go-uuid v1.0.0
go: finding github.com/hashicorp/logutils v1.0.0
go: finding github.com/pascaldekloe/goe v0.0.0-20180627143212-57f6aae5913c
go: finding github.com/mattn/go-colorable v0.0.9
go: finding github.com/hashicorp/golang-lru v0.5.0
go: finding github.com/hashicorp/go-sockaddr v1.0.0
go: finding github.com/sean-/seed v0.0.0-20170313163322-e2103e2c3529
go: finding github.com/golang/sys v0.0.0-20181026203630-95b1ffbd15a5
go: finding github.com/golang/sync v0.0.0-20181221193216-37e7f081c4d4
go: finding github.com/golang/crypto v0.0.0-20181029021203-45a5f77698d3
go: finding github.com/fatih/color v1.7.0
go: finding github.com/armon/circbuf v0.0.0-20150827004946-bbbad097214e
Removing intermediate container ca37635ae857
 ---> 2ea018099509
Step 8/18 : COPY . .
 ---> 84ba3cac05ec
Step 9/18 : RUN make cmd/export-distro/export-distro
 ---> Running in 8a604a3ff538
CGO_ENABLED=1 GO111MODULE=on go build -ldflags "-X github.com/edgexfoundry/edgex-go.Version=1.0.2"                                                                                            -o cmd/export-distro/export-distro ./cmd/export-distro
Removing intermediate container 8a604a3ff538
 ---> baee083043d1
Step 10/18 : FROM alpine
 ---> 965ea09ff2eb
Step 11/18 : LABEL license='SPDX-License-Identifier: Apache-2.0'       copyright='Copyright (c) 201                                                                                           7-2018: Mainflux, Cavium'
 ---> Running in a01ad4abfdfb
Removing intermediate container a01ad4abfdfb
 ---> 62e4c99a09a5
Step 12/18 : RUN sed -e 's/dl-cdn[.]alpinelinux.org/nl.alpinelinux.org/g' -i~ /etc/apk/repositories
 ---> Running in 42ead2d3a8ae
Removing intermediate container 42ead2d3a8ae
 ---> bb1077aa9c15
Step 13/18 : RUN apk --no-cache add zeromq
 ---> Running in aca49fd6b908
fetch http://nl.alpinelinux.org/alpine/v3.10/main/x86_64/APKINDEX.tar.gz
fetch http://nl.alpinelinux.org/alpine/v3.10/community/x86_64/APKINDEX.tar.gz
(1/5) Installing libgcc (8.3.0-r0)
(2/5) Installing libsodium (1.0.18-r0)
(3/5) Installing libstdc++ (8.3.0-r0)
(4/5) Installing libzmq (4.3.2-r1)
(5/5) Installing zeromq (4.3.2-r1)
Executing busybox-1.30.1-r2.trigger
OK: 8 MiB in 19 packages
Removing intermediate container aca49fd6b908
 ---> 87d4d892ce45
Step 14/18 : COPY --from=builder /go/src/github.com/edgexfoundry/edgex-go/cmd/export-distro/Attribu                                                                                           tion.txt /
 ---> fb0838b3634e
Step 15/18 : COPY --from=builder /go/src/github.com/edgexfoundry/edgex-go/cmd/export-distro/export-                                                                                           distro /
 ---> cbc71f92b1a8
Step 16/18 : COPY --from=builder /go/src/github.com/edgexfoundry/edgex-go/cmd/export-distro/res/doc                                                                                           ker/configuration.toml /res/docker/configuration.toml
 ---> 249eb2415b09
Step 17/18 : ENTRYPOINT ["/export-distro","--registry","--profile=docker","--confdir=/res"]
 ---> Running in 3ce321e2bbc9
Removing intermediate container 3ce321e2bbc9
 ---> a9e2f471715a
Step 18/18 : LABEL git_sha=48146ead559bd9f27e80af344e3cf787530a1539
 ---> Running in 4d218e19c2ba
Removing intermediate container 4d218e19c2ba
 ---> 67b4d76a7d45
Successfully built 67b4d76a7d45
Successfully tagged edgexfoundry/docker-export-distro-go:48146ead559bd9f27e80af344e3cf787530a1539
Successfully tagged edgexfoundry/docker-export-distro-go:1.0.2-dev
edinburgh_1.0.2

注:生成其他docker镜像时,都会使用cache中镜像(repository和tag都是<none>),编译一次供多个容器使用。可以通过docker tag保留容器。

docker tag baee083043d1 edgex_mid1:first

 make docker_core_data
docker build \
        -f cmd/core-data/Dockerfile \
        --label "git_sha=48146ead559bd9f27e80af344e3cf787530a1539" \
        -t edgexfoundry/docker-core-data-go:48146ead559bd9f27e80af344e3cf787530a1539 \
        -t edgexfoundry/docker-core-data-go:1.0.2-dev \
        .
Sending build context to Docker daemon    161MB
Step 1/18 : FROM golang:1.11-alpine AS builder
 ---> e116d2efa2ab
Step 2/18 : ENV GO111MODULE=on
 ---> Using cache
 ---> 6f17441d1946
Step 3/18 : WORKDIR /go/src/github.com/edgexfoundry/edgex-go
 ---> Using cache
 ---> 1e94eec59dac
Step 4/18 : RUN sed -e 's/dl-cdn[.]alpinelinux.org/nl.alpinelinux.org/g' -i~ /etc/apk/repositories
 ---> Using cache
 ---> 48697136fcca
Step 5/18 : RUN apk update && apk add zeromq-dev libsodium-dev pkgconfig build-base git
 ---> Using cache
 ---> 650c39be3c34
Step 6/18 : COPY go.mod .
 ---> Using cache
 ---> 3afaf7b13163
Step 7/18 : RUN go mod download
 ---> Using cache
 ---> 2ea018099509
Step 8/18 : COPY . .
 ---> 2f43fc26cea8
Step 9/18 : RUN make cmd/core-data/core-data
 ---> Running in c4f567e254ba
CGO_ENABLED=1 GO111MODULE=on go build -ldflags "-X github.com/edgexfoundry/edgex-go.Version=1.0.2" -o cmd/core-data/core-data ./cmd/core-data
Removing intermediate container c4f567e254ba
 ---> 3f47fb78be86
Step 10/18 : FROM alpine
 ---> 965ea09ff2eb
Step 11/18 : LABEL license='SPDX-License-Identifier: Apache-2.0'       copyright='Copyright (c) 2018: Dell, Cavium'
 ---> Running in 0df73306b0d5
Removing intermediate container 0df73306b0d5
 ---> 2ab515094063
Step 12/18 : RUN sed -e 's/dl-cdn[.]alpinelinux.org/nl.alpinelinux.org/g' -i~ /etc/apk/repositories
 ---> Running in db0db60625d5
Removing intermediate container db0db60625d5
 ---> ccfa3db0f47e
Step 13/18 : RUN apk --no-cache add zeromq
 ---> Running in 236dcf9889df
fetch http://nl.alpinelinux.org/alpine/v3.10/main/x86_64/APKINDEX.tar.gz
fetch http://nl.alpinelinux.org/alpine/v3.10/community/x86_64/APKINDEX.tar.gz
(1/5) Installing libgcc (8.3.0-r0)
(2/5) Installing libsodium (1.0.18-r0)
(3/5) Installing libstdc++ (8.3.0-r0)
(4/5) Installing libzmq (4.3.2-r1)
(5/5) Installing zeromq (4.3.2-r1)
Executing busybox-1.30.1-r2.trigger
OK: 8 MiB in 19 packages
Removing intermediate container 236dcf9889df
 ---> 01425d9e6bf4
Step 14/18 : COPY --from=builder /go/src/github.com/edgexfoundry/edgex-go/cmd/core-data/Attribution.txt /
 ---> 31a9a4020f22
Step 15/18 : COPY --from=builder /go/src/github.com/edgexfoundry/edgex-go/cmd/core-data/core-data /
 ---> 732b0fa69f65
Step 16/18 : COPY --from=builder /go/src/github.com/edgexfoundry/edgex-go/cmd/core-data/res/docker/configuration.toml /res/docker/configuration.toml
 ---> 7ed81604d03f
Step 17/18 : ENTRYPOINT ["/core-data","--registry","--profile=docker","--confdir=/res"]
 ---> Running in dde57cf9df93
Removing intermediate container dde57cf9df93
 ---> 1dbe1e5529bf
Step 18/18 : LABEL git_sha=48146ead559bd9f27e80af344e3cf787530a1539
 ---> Running in f88f03b51cd0
Removing intermediate container f88f03b51cd0
 ---> 3ad0508f7ee4
Successfully built 3ad0508f7ee4
Successfully tagged edgexfoundry/docker-core-data-go:48146ead559bd9f27e80af344e3cf787530a1539
Successfully tagged edgexfoundry/docker-core-data-go:1.0.2-dev
edinburgh_1.0.2_core-data

 

参考:

1.在树莓派3b+上运行edgex

2.  4.2.2.1. Get EdgeX Foundry - Go Developers

3. 4.3.1. Writing a Device Service in Go

4. 4.3.2. Writing a Device Service in C

posted @ 2019-05-24 20:21  yuxi_o  阅读(...)  评论(...编辑  收藏