Updated Dockerfile and added gitea workflows

This commit is contained in:
Aditya Prima 2024-03-24 06:11:45 +07:00
parent 451da30315
commit eea066385b
9 changed files with 221 additions and 176 deletions

View File

@ -0,0 +1,63 @@
name: Build and Push Alpine PHP 8.3 Image
on:
push:
branches:
- master
jobs:
build:
name: Build and push image
runs-on: ubuntu-latest
container:
image: ghcr.io/catthehacker/ubuntu:act-latest
steps:
- name: Check out repository code
uses: actions/checkout@v3
- name: Login to Docker Winter Access Git Registry
uses: docker/login-action@v3
with:
registry: git.winteraccess.id
username: aditya.prima
password: ${{ secrets.PATOKEN }}
- name: Build and push 14.21.3
uses: docker/build-push-action@v5
with:
context: .
file: Dockerfile.alpine
build-args: |
ALPINE_VERSION=3.14
push: true
tags: |
git.winteraccess.id/${{ gitea.repository }}:14-alpine
- name: Build and push 16.20.2
uses: docker/build-push-action@v5
with:
context: .
file: Dockerfile.alpine
build-args: |
ALPINE_VERSION=3.16
push: true
tags: |
git.winteraccess.id/${{ gitea.repository }}:16-alpine
- name: Build and push 18.19.1
uses: docker/build-push-action@v5
with:
context: .
file: Dockerfile.alpine
build-args: |
ALPINE_VERSION=3.18
push: true
tags: |
git.winteraccess.id/${{ gitea.repository }}:18-alpine
- name: Build and push 20.11.1
uses: docker/build-push-action@v5
with:
context: .
file: Dockerfile.alpine
build-args: |
ALPINE_VERSION=3.19
push: true
tags: |
git.winteraccess.id/${{ gitea.repository }}:20-alpine
git.winteraccess.id/${{ gitea.repository }}:latest-alpine
git.winteraccess.id/${{ gitea.repository }}:alpine

View File

@ -0,0 +1,67 @@
name: Build and Push Ubuntu PHP 8.3 Image
on:
push:
branches:
- master
jobs:
build:
name: Build and push image
runs-on: ubuntu-latest
container:
image: ghcr.io/catthehacker/ubuntu:act-latest
steps:
- name: Check out repository code
uses: actions/checkout@v3
- name: Login to Docker Winter Access Git Registry
uses: docker/login-action@v3
with:
registry: git.winteraccess.id
username: aditya.prima
password: ${{ secrets.PATOKEN }}
- name: Build and push 14.21.3
uses: docker/build-push-action@v5
with:
context: .
file: Dockerfile.ubuntu
build-args: |
NODE_VERSION=14.21.3
push: true
tags: |
git.winteraccess.id/${{ gitea.repository }}:14-ubuntu
git.winteraccess.id/${{ gitea.repository }}:14
- name: Build and push 16.20.2
uses: docker/build-push-action@v5
with:
context: .
file: Dockerfile.ubuntu
build-args: |
NODE_VERSION=16.20.2
push: true
tags: |
git.winteraccess.id/${{ gitea.repository }}:16-ubuntu
git.winteraccess.id/${{ gitea.repository }}:16
- name: Build and push 18.19.1
uses: docker/build-push-action@v5
with:
context: .
file: Dockerfile.ubuntu
build-args: |
NODE_VERSION=18.19.1
push: true
tags: |
git.winteraccess.id/${{ gitea.repository }}:18-ubuntu
git.winteraccess.id/${{ gitea.repository }}:18
- name: Build and push 20.11.1
uses: docker/build-push-action@v5
with:
context: .
file: Dockerfile.ubuntu
build-args: |
NODE_VERSION=20.11.1
push: true
tags: |
git.winteraccess.id/${{ gitea.repository }}:20-ubuntu
git.winteraccess.id/${{ gitea.repository }}:20
git.winteraccess.id/${{ gitea.repository }}:latest-ubuntu
git.winteraccess.id/${{ gitea.repository }}:latest

View File

@ -1,56 +0,0 @@
stages:
- build
.build:
image: docker:20.10.16
services:
- name: docker:20.10.16-dind
alias: docker
variables:
DOCKER_HOST: tcp://docker:2376
DOCKER_TLS_CERTDIR: "/certs"
DOCKER_TLS_VERIFY: 1
DOCKER_CERT_PATH: "/certs/client"
DOCKER_DRIVER: "overlay"
before_script:
- "docker login ${CI_REGISTRY} -u gitlab-ci-token -p ${CI_JOB_TOKEN}"
after_script:
- "docker logout ${CI_REGISTRY}"
build_cifo_20:
stage: build
extends: .build
only:
- master
script:
- DOCKER_BUILDKIT=1 docker image build -f Dockerfile_ubuntu --build-arg="UBUNTU_VERSION=jammy" --build-arg="REGISTRY_URL=registry.cifo.co.id/docker" --build-arg="NODE_VERSION=20.10.0" -t ${CI_REGISTRY}/${CI_PROJECT_PATH}:latest -t ${CI_REGISTRY}/${CI_PROJECT_PATH}:20-ubuntu -t ${CI_REGISTRY}/${CI_PROJECT_PATH}:20 .
- DOCKER_BUILDKIT=1 docker image build -f Dockerfile_alpine --build-arg="ALPINE_VERSION=3.19" --build-arg="REGISTRY_URL=registry.cifo.co.id/docker" -t ${CI_REGISTRY}/${CI_PROJECT_PATH}:20-alpine .
- docker image push ${CI_REGISTRY}/${CI_PROJECT_PATH}:latest
- docker image push ${CI_REGISTRY}/${CI_PROJECT_PATH}:20
- docker image push ${CI_REGISTRY}/${CI_PROJECT_PATH}:20-ubuntu
- docker image push ${CI_REGISTRY}/${CI_PROJECT_PATH}:20-alpine
build_cifo_18:
stage: build
extends: .build
only:
- master
script:
- DOCKER_BUILDKIT=1 docker image build -f Dockerfile_ubuntu --build-arg="UBUNTU_VERSION=jammy" --build-arg="REGISTRY_URL=registry.cifo.co.id/docker" --build-arg="NODE_VERSION=18.19.0" -t ${CI_REGISTRY}/${CI_PROJECT_PATH}:18-ubuntu -t ${CI_REGISTRY}/${CI_PROJECT_PATH}:18 .
- DOCKER_BUILDKIT=1 docker image build -f Dockerfile_alpine --build-arg="ALPINE_VERSION=3.18" --build-arg="REGISTRY_URL=registry.cifo.co.id/docker" -t ${CI_REGISTRY}/${CI_PROJECT_PATH}:18-alpine .
- docker image push ${CI_REGISTRY}/${CI_PROJECT_PATH}:18
- docker image push ${CI_REGISTRY}/${CI_PROJECT_PATH}:18-ubuntu
- docker image push ${CI_REGISTRY}/${CI_PROJECT_PATH}:18-alpine
build_cifo_16:
stage: build
extends: .build
only:
- master
script:
- DOCKER_BUILDKIT=1 docker image build -f Dockerfile_ubuntu --build-arg="UBUNTU_VERSION=jammy" --build-arg="REGISTRY_URL=registry.cifo.co.id/docker" --build-arg="NODE_VERSION=16.20.2" -t ${CI_REGISTRY}/${CI_PROJECT_PATH}:16-ubuntu -t ${CI_REGISTRY}/${CI_PROJECT_PATH}:16 .
- DOCKER_BUILDKIT=1 docker image build -f Dockerfile_alpine --build-arg="ALPINE_VERSION=3.16" --build-arg="REGISTRY_URL=registry.cifo.co.id/docker" -t ${CI_REGISTRY}/${CI_PROJECT_PATH}:16-alpine .
- docker image push ${CI_REGISTRY}/${CI_PROJECT_PATH}:16
- docker image push ${CI_REGISTRY}/${CI_PROJECT_PATH}:16-ubuntu
- docker image push ${CI_REGISTRY}/${CI_PROJECT_PATH}:16-alpine

View File

@ -1,56 +0,0 @@
stages:
- build
.build:
image: docker:20.10.16
services:
- name: docker:20.10.16-dind
alias: docker
variables:
DOCKER_HOST: tcp://docker:2376
DOCKER_TLS_CERTDIR: "/certs"
DOCKER_TLS_VERIFY: 1
DOCKER_CERT_PATH: "/certs/client"
DOCKER_DRIVER: "overlay"
before_script:
- "docker login -u ${HUB_USERNAME} -p ${HUB_TOKEN}"
after_script:
- "docker logout"
build_dockerio_20:
stage: build
extends: .build
only:
- master
script:
- DOCKER_BUILDKIT=1 docker image build -f Dockerfile_ubuntu --build-arg="UBUNTU_VERSION=jammy" --build-arg="NODE_VERSION=20.10.0" -t ${HUB_IMAGE_PATH}:latest -t ${HUB_IMAGE_PATH}:20-ubuntu -t ${HUB_IMAGE_PATH}:20 .
- DOCKER_BUILDKIT=1 docker image build -f Dockerfile_alpine --build-arg="ALPINE_VERSION=3.19" -t ${HUB_IMAGE_PATH}:20-alpine .
- docker image push ${HUB_IMAGE_PATH}:latest
- docker image push ${HUB_IMAGE_PATH}:20
- docker image push ${HUB_IMAGE_PATH}:20-ubuntu
- docker image push ${HUB_IMAGE_PATH}:20-alpine
build_dockerio_18:
stage: build
extends: .build
only:
- master
script:
- DOCKER_BUILDKIT=1 docker image build -f Dockerfile_ubuntu --build-arg="UBUNTU_VERSION=jammy" --build-arg="NODE_VERSION=18.19.0" -t ${HUB_IMAGE_PATH}:18-ubuntu -t ${HUB_IMAGE_PATH}:18 .
- DOCKER_BUILDKIT=1 docker image build -f Dockerfile_alpine --build-arg="ALPINE_VERSION=3.18" -t ${HUB_IMAGE_PATH}:18-alpine .
- docker image push ${HUB_IMAGE_PATH}:18
- docker image push ${HUB_IMAGE_PATH}:18-ubuntu
- docker image push ${HUB_IMAGE_PATH}:18-alpine
build_dockerio_16:
stage: build
extends: .build
only:
- master
script:
- DOCKER_BUILDKIT=1 docker image build -f Dockerfile_ubuntu --build-arg="UBUNTU_VERSION=jammy" --build-arg="NODE_VERSION=16.20.2" -t ${HUB_IMAGE_PATH}:16-ubuntu -t ${HUB_IMAGE_PATH}:16 .
- DOCKER_BUILDKIT=1 docker image build -f Dockerfile_alpine --build-arg="ALPINE_VERSION=3.16" -t ${HUB_IMAGE_PATH}:16-alpine .
- docker image push ${HUB_IMAGE_PATH}:16
- docker image push ${HUB_IMAGE_PATH}:16-ubuntu
- docker image push ${HUB_IMAGE_PATH}:16-alpine

View File

@ -1,12 +0,0 @@
stages:
- triggers
build_cifo:
stage: triggers
trigger:
include: .gitlab-ci.cifo.yml
build_dockerio:
stage: triggers
trigger:
include: .gitlab-ci.dockerio.yml

40
Dockerfile.alpine Normal file
View File

@ -0,0 +1,40 @@
# 14.21.3 = 3.14
# 16.20.2 = 3.16
# 18.19.1 = 3.18
# 20.11.1 = 3.19
ARG REGISTRY_URL=git.winteraccess.id/docker
ARG ALPINE_VERSION=3.19
FROM ${REGISTRY_URL}/alpine:${ALPINE_VERSION}
LABEL maintainer="<Muhamad Aditya Prima> aprimediet@gmail.com"
WORKDIR /
# SET CACHE DIR
ENV NODE_DIR /usr/local/share/nodejs
ENV NPM_CACHE_DIR ${NODE_DIR}/.npm-cache
ENV YARN_CACHE_DIR ${NODE_DIR}/.yarn-cache
# INSTALL WGET AND REQUIRED BUILD TOOLS
RUN --mount=type=cache,target=/var/cache/apk \
apk update && apk upgrade && apk add \
nodejs nodejs-dev npm
# SET NPM GLOBAL CACHE
RUN npm -g config set cache ${NPM_CACHE_DIR} && \
npm config set cache ${NPM_CACHE_DIR}
# INSTALL YARN
RUN --mount=type=cache,target=${NPM_CACHE_DIR} \
npm i -g yarn
# CREATE YARN CACHE DIR
RUN mkdir -p ${YARN_CACHE_DIR}
# SET YARN CACHE DIR
RUN yarn config set cache-folder ${YARN_CACHE_DIR}
# CLEAR CACHE
RUN rm -rf /var/cache/apk/* && \
npm cache clean --force && \
npm -g cache clean --force

51
Dockerfile.ubuntu Normal file
View File

@ -0,0 +1,51 @@
ARG REGISTRY_URL=git.winteraccess.id/docker
ARG UBUNTU_VERSION=jammy
FROM ${REGISTRY_URL}/ubuntu:${UBUNTU_VERSION}
LABEL maintainer="<Muhamad Aditya Prima> aprimediet@gmail.com"
ARG NVM_VERSION=0.39.7
ARG NODE_VERSION=20.11.1
WORKDIR /
# CREATE NVM_DIR
ENV NVM_DIR /usr/local/share/nvm
ENV NPM_CACHE_DIR ${NVM_DIR}/.npm-cache
ENV YARN_CACHE_DIR ${NVM_DIR}/.yarn-cache
RUN mkdir -p ${NVM_DIR}
# UPGRADE PACKAGES FIRST
RUN --mount=type=cache,target=/var/cache/apt/archives \
apt -y update && apt -y upgrade
# GET LATEST NVM
ADD https://raw.githubusercontent.com/nvm-sh/nvm/v${NVM_VERSION}/install.sh /tmp
# INSTALL NVM AND DESIGNATED NODE VERSION
RUN bash /tmp/install.sh && \
. $NVM_DIR/nvm.sh && \
nvm install v${NODE_VERSION} && \
nvm alias default v${NODE_VERSION} && \
nvm use default
ENV NODE_PATH $NVM_DIR/versions/node/v${NODE_VERSION}/lib/node_modules
ENV PATH $PATH:$NVM_DIR/versions/node/v${NODE_VERSION}/bin
# SET NPM GLOBAL CACHE
RUN npm -g config set cache ${NPM_CACHE_DIR} && \
npm config set cache ${NPM_CACHE_DIR}
# INSTALL YARN
RUN --mount=type=cache,target=${NPM_CACHE_DIR} \
npm i -g yarn
# CREATE YARN CACHE DIR
RUN mkdir -p ${YARN_CACHE_DIR}
# SET YARN CACHE DIR
RUN yarn config set cache-folder ${YARN_CACHE_DIR}
# CLEAR APT CACHE
RUN apt -y clean && rm -rf /tmp/* && \
npm cache clean --force && npm -g cache clean --force

View File

@ -1,19 +0,0 @@
# 14.21.3 = 3.14
# 16.20.2 = 3.16
# 18.19.0 = 3.18
ARG REGISTRY_URL=aprimediet
ARG ALPINE_VERSION=3.18
FROM ${REGISTRY_URL}/alpine:${ALPINE_VERSION}
LABEL maintainer="<Muhamad Aditya Prima> aprimediet@gmail.com"
# INSTALL WGET AND REQUIRED BUILD TOOLS
RUN --mount=type=cache,target=/var/cache/apk \
apk add --update \
nodejs nodejs-dev npm
# INSTALL YARN
RUN npm i -g yarn
# CLEAR CACHE
RUN rm -rf /var/cache/apk/*

View File

@ -1,33 +0,0 @@
ARG UBUNTU_VERSION=jammy
FROM aprimediet/ubuntu:${UBUNTU_VERSION}
LABEL maintainer="<Muhamad Aditya Prima> aprimediet@gmail.com"
ARG NVM_VERSION=0.39.5
ARG NODE_VERSION=18.19.0
ENV HOME /root
ENV NVM_DIR $HOME/.nvm
# UPGRADE PACKAGES FIRST
RUN --mount=type=cache,target=/var/cache/apt/archives \
apt -y update && apt -y upgrade
# GET LATEST NVM
ADD https://raw.githubusercontent.com/nvm-sh/nvm/v${NVM_VERSION}/install.sh /tmp
# INSTALL NVM AND DESIGNATED NODE VERSION
RUN bash /tmp/install.sh && \
. $NVM_DIR/nvm.sh && \
nvm install v${NODE_VERSION} && \
nvm alias default v${NODE_VERSION} && \
nvm use default
ENV NODE_PATH $NVM_DIR/versions/node/v${NODE_VERSION}/lib/node_modules
ENV PATH $PATH:$NVM_DIR/versions/node/v${NODE_VERSION}/bin
# INSTALL YARN
RUN npm i -g yarn
# CLEAR APT CACHE
RUN apt -y clean && rm -f /tmp/*