build_packages.yaml 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290
  1. name: Build packages
  2. on:
  3. pull_request:
  4. release:
  5. types:
  6. - published
  7. jobs:
  8. build:
  9. runs-on: ubuntu-latest
  10. steps:
  11. - uses: actions/checkout@v1
  12. - name: install docker
  13. run: |
  14. sudo apt-get remove docker docker-engine docker.io containerd runc
  15. sudo apt-get update
  16. sudo apt-get install apt-transport-https ca-certificates curl gnupg-agent software-properties-common
  17. curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
  18. sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable"
  19. sudo apt-get update
  20. sudo apt-get install docker-ce docker-ce-cli containerd.io
  21. - name: prepare docker
  22. run: |
  23. mkdir -p $HOME/.docker
  24. echo '{ "experimental": "enabled" }' | tee $HOME/.docker/config.json
  25. echo '{ "experimental": true, "storage-driver": "overlay2", "max-concurrent-downloads": 50, "max-concurrent-uploads": 50, "graph": "/mnt/docker" }' | sudo tee /etc/docker/daemon.json
  26. sudo systemctl restart docker
  27. docker info
  28. docker buildx create --use --name mybuild
  29. - name: build
  30. run: |
  31. make all_pkgs
  32. cd _packages && for var in $(ls); do sudo bash -c "echo $(sha256sum $var | awk '{print $1}') > $var.sha256"; done && cd -
  33. - uses: actions/upload-artifact@v1
  34. with:
  35. name: packages
  36. path: _packages/.
  37. build-on-mac:
  38. runs-on: macos-latest
  39. steps:
  40. - uses: actions/checkout@v1
  41. - uses: actions/setup-go@v1
  42. with:
  43. go-version: '1.14'
  44. - name: prepare
  45. run: |
  46. /usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
  47. brew install curl zip unzip gnu-sed upx pkg-config zmq
  48. echo "/usr/local/bin:$PATH" >> ~/.bashrc
  49. - name: build
  50. run: |
  51. make pkg
  52. cd _packages && for var in $(ls); do openssl dgst -sha256 $var | awk '{print $2}' > $var.sha256; done && cd -
  53. - uses: actions/upload-artifact@v1
  54. with:
  55. name: packages-mac
  56. path: _packages/.
  57. build-docker-images-and-plugins:
  58. runs-on: ubuntu-latest
  59. strategy:
  60. matrix:
  61. plugin:
  62. - sinks/file
  63. - sinks/influxdb
  64. - sinks/taos
  65. - sinks/zmq
  66. - sources/random
  67. - sources/zmq
  68. - functions/accumulateWordCount
  69. - functions/countPlusOne
  70. - functions/echo
  71. steps:
  72. - uses: actions/checkout@v1
  73. - name: install docker
  74. run: |
  75. sudo apt-get remove docker docker-engine docker.io containerd runc
  76. sudo apt-get update
  77. sudo apt-get install apt-transport-https ca-certificates curl gnupg-agent software-properties-common
  78. curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
  79. sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable"
  80. sudo apt-get update
  81. sudo apt-get install docker-ce docker-ce-cli containerd.io
  82. - name: prepare docker
  83. run: |
  84. mkdir -p $HOME/.docker
  85. echo '{ "experimental": "enabled" }' | tee $HOME/.docker/config.json
  86. echo '{ "experimental": true, "storage-driver": "overlay2", "max-concurrent-downloads": 50, "max-concurrent-uploads": 50, "graph": "/mnt/docker" }' | sudo tee /etc/docker/daemon.json
  87. sudo systemctl restart docker
  88. docker version
  89. docker buildx create --use --name mybuild
  90. docker run --rm --privileged multiarch/qemu-user-static --reset -p yes
  91. - name: build docker image
  92. run: make docker -j4
  93. - name: buiild debian plugins
  94. env:
  95. PLUGIN: ${{ matrix.plugin }}
  96. run: make ${PLUGIN}
  97. - name: buiild alpine plugins
  98. env:
  99. PLUGIN: ${{ matrix.plugin }}
  100. run: make alpine/${PLUGIN}
  101. - name: test docker and plugins
  102. env:
  103. PLUGIN: ${{ matrix.plugin }}
  104. run: |
  105. set -e -x -u
  106. plugin_type=$(echo ${PLUGIN%%/*})
  107. plugin_name=$(echo ${PLUGIN##*/})
  108. for image_id in $(docker images emqx/kuiper -q); do
  109. container_id=$(docker run -d -v $(pwd)/_plugins:/var/plugins $image_id)
  110. ip_address=$(docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' $container_id)
  111. os=$(docker exec -i ${container_id} sh -c "sed -n '/^ID=/p' /etc/os-release | sed -r 's/ID=(.*)/\1/g'" )
  112. sleep 5
  113. if ! curl ${ip_address}:9081 >/dev/null 2>&1; then echo "docker image failed"; exit 1; fi
  114. curl ${ip_address}:9081/plugins/${plugin_type} -X POST -d "{\"name\":\"${plugin_name}\", \"file\":\"file:///var/plugins/${os}/${plugin_type}/${plugin_name}_amd64.zip\"}"
  115. [ $plugin_name = $(curl ${ip_address}:9081/plugins/${plugin_type}/${plugin_name} | jq '.name'| sed 's/\"//g' ) ] || exit 1
  116. done
  117. - uses: actions/upload-artifact@v2
  118. with:
  119. name: plugins
  120. path: "_plugins/"
  121. build-docker-manifest-images:
  122. runs-on: ubuntu-latest
  123. needs:
  124. - build-docker-images-and-plugins
  125. strategy:
  126. matrix:
  127. suffix:
  128. - fat
  129. - slim
  130. - alpine
  131. steps:
  132. - uses: actions/checkout@v1
  133. - name: install docker
  134. if: github.event_name == 'release'
  135. run: |
  136. sudo apt-get remove docker docker-engine docker.io containerd runc
  137. sudo apt-get update
  138. sudo apt-get install apt-transport-https ca-certificates curl gnupg-agent software-properties-common
  139. curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
  140. sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable"
  141. sudo apt-get update
  142. sudo apt-get install docker-ce docker-ce-cli containerd.io jq
  143. - name: prepare docker
  144. if: github.event_name == 'release'
  145. run: |
  146. mkdir -p $HOME/.docker
  147. echo '{ "experimental": "enabled" }' | tee $HOME/.docker/config.json
  148. echo '{ "experimental": true, "storage-driver": "overlay2", "max-concurrent-downloads": 50, "max-concurrent-uploads": 50, "graph": "/mnt/docker" }' | sudo tee /etc/docker/daemon.json
  149. sudo systemctl restart docker
  150. docker version
  151. docker buildx create --use --name mybuild
  152. docker run --rm --privileged multiarch/qemu-user-static --reset -p yes
  153. - name: cross build docker images
  154. if: (matrix.suffix == 'fat') && (github.event_name == 'release')
  155. run: |
  156. set -e -u -x
  157. echo ${{ secrets.DockerHubPassword }} | docker login -u ${{ secrets.DockerHubUser }} --password-stdin
  158. docker buildx build --no-cache \
  159. --platform=linux/amd64,linux/arm64,linux/arm/v7,linux/386,linux/ppc64le \
  160. -t emqx/kuiper:$(git describe --tags --always) \
  161. -f deploy/docker/Dockerfile . \
  162. --push
  163. - name: cross build docker images
  164. if: (matrix.suffix != 'fat') && (github.event_name == 'release')
  165. env:
  166. SUFFIX: ${{ matrix.suffix }}
  167. run: |
  168. set -e -u -x
  169. echo ${{ secrets.DockerHubPassword }} | docker login -u ${{ secrets.DockerHubUser }} --password-stdin
  170. docker buildx build --no-cache \
  171. --platform=linux/amd64,linux/arm64,linux/arm/v7,linux/386,linux/ppc64le \
  172. -t emqx/kuiper:$(git describe --tags --always)-$SUFFIX \
  173. -f deploy/docker/Dockerfile-$SUFFIX . \
  174. --push
  175. build-kubernetes-tool:
  176. runs-on: ubuntu-latest
  177. steps:
  178. - uses: actions/checkout@v1
  179. - name: install docker
  180. run: |
  181. sudo apt-get remove docker docker-engine docker.io containerd runc
  182. sudo apt-get update
  183. sudo apt-get install apt-transport-https ca-certificates curl gnupg-agent software-properties-common
  184. curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
  185. sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable"
  186. sudo apt-get update
  187. sudo apt-get install docker-ce docker-ce-cli containerd.io
  188. - name: prepare docker
  189. run: |
  190. mkdir -p $HOME/.docker
  191. echo '{ "experimental": "enabled" }' | tee $HOME/.docker/config.json
  192. echo '{ "experimental": true, "storage-driver": "overlay2", "max-concurrent-downloads": 50, "max-concurrent-uploads": 50, "graph": "/mnt/docker" }' | sudo tee /etc/docker/daemon.json
  193. sudo systemctl restart docker
  194. docker version
  195. docker buildx create --use --name mybuild
  196. docker run --rm --privileged multiarch/qemu-user-static --reset -p yes
  197. - name: build docker image
  198. run: docker build --no-cache -t emqx/kuiper-kubernetes-tool:$(git describe --tags --always) -f deploy/docker/Dockerfile-kubernetes-tool .
  199. - name: test docker image
  200. run: |
  201. set -e -u -x
  202. docker run -d --name kuiper-kubernetes-tool emqx/kuiper-kubernetes-tool:$(git describe --tags --always)
  203. sleep 5
  204. if [ "$(docker logs kuiper-kubernetes-tool)" != "Kuiper kubernetes tool is started successfully!" ]; then exit 1; fi
  205. - name: buildx docker image
  206. if: github.event_name == 'release'
  207. run: |
  208. echo ${{ secrets.DockerHubPassword }} | docker login -u ${{ secrets.DockerHubUser }} --password-stdin
  209. docker buildx build --no-cache \
  210. --platform=linux/amd64,linux/arm64,linux/arm/v7,linux/386 \
  211. -t emqx/kuiper-kubernetes-tool:$(git describe --tags --always) \
  212. -f deploy/docker/Dockerfile-kubernetes-tool . \
  213. -- push
  214. release:
  215. runs-on: ubuntu-latest
  216. needs:
  217. - build
  218. - build-on-mac
  219. - build-docker-images-and-plugins
  220. steps:
  221. - uses: actions/checkout@v1
  222. - uses: actions/download-artifact@v1
  223. with:
  224. name: packages
  225. path: _packages
  226. - uses: actions/download-artifact@v1
  227. with:
  228. name: packages-mac
  229. path: _packages
  230. - uses: actions/download-artifact@v1
  231. with:
  232. name: plugins
  233. path: _plugins
  234. - name: check packages
  235. run: |
  236. cd _packages && for var in $( ls |grep -v sha256); do
  237. echo "$(cat $var.sha256) $var" | sha256sum -c || exit 1
  238. done
  239. - name: update github release
  240. if: github.event_name == 'release'
  241. run: |
  242. version=$(echo ${{ github.ref }} | sed -r "s .*/.*/(.*) \1 g")
  243. for var in $(ls _packages) ; do
  244. .github/workflows/script/upload_github_release_asset.sh owner=emqx repo=kuiper tag=$version filename=_packages/$var github_api_token=$(echo ${{ secrets.AccessToken }})
  245. done
  246. - name: create invalidation for cloudfront
  247. if: github.event_name == 'release'
  248. run: |
  249. version=$(echo ${{ github.ref }} | sed -r "s .*/.*/(.*) \1 g")
  250. curl "https://d1vvhvl2y92vvt.cloudfront.net/awscli-exe-linux-x86_64.zip" -o "awscliv2.zip"
  251. unzip awscliv2.zip
  252. sudo ./aws/install
  253. aws configure set aws_access_key_id ${{ secrets.AwsAccessKeyId }}
  254. aws configure set aws_secret_access_key ${{ secrets.AwsSecretAccessKey }}
  255. aws configure set default.region us-west-2
  256. aws s3 rm --quiet --recursive s3://packages.emqx.io/kuiper/$version
  257. aws s3 cp --quiet --recursive ./_packages s3://packages.emqx.io/kuiper/$version
  258. aws s3 cp --quiet --recursive ./_plugins s3://packages.emqx.io/kuiper-plugins/$version
  259. aws cloudfront create-invalidation --distribution-id E3TYD0WSP4S14P --paths "/kuiper/$version/*,/kuiper-plugins/$version/*"
  260. - name: update emqx.io
  261. if: github.event_name == 'release'
  262. run: |
  263. version=$(echo ${{ github.ref }} | sed -r "s .*/.*/(.*) \1 g")
  264. curl -w %{http_code} --insecure -H ${{ secrets.EmqxHeader }} https://admin.emqx.io/admin_api/v1/kuiper_github_release_callback?tag=$version
  265. - name: update helm packages
  266. if: github.event_name == 'release'
  267. run: |
  268. version=$(echo ${{ github.ref }} | sed -r "s .*/.*/(.*) \1 g")
  269. curl -H "Authorization: token ${{ secrets.AccessToken }}" -H "Accept: application/vnd.github.everest-preview+json" -H "Content-Type: application/json" -X POST -d "{\"event_type\":\"update_repos_for_kuiper\",\"client_payload\":{\"version\": \"$version\"}}" https://api.github.com/repos/emqx/emqx-packages-docker/dispatches