Compare commits
1 Commits
lesson4-ci
...
lesson3-ci
Author | SHA1 | Date | |
---|---|---|---|
dfd16e74c5 |
@@ -7,79 +7,28 @@ image: docker:20.10.16
|
|||||||
|
|
||||||
variables:
|
variables:
|
||||||
REGISTRY: hub.bildme.ru
|
REGISTRY: hub.bildme.ru
|
||||||
GITLAB: git.bildme.ru
|
|
||||||
IMAGE_NAME: $REGISTRY/$CI_PROJECT_PATH:latest
|
IMAGE_NAME: $REGISTRY/$CI_PROJECT_PATH:latest
|
||||||
RELEASE_NAME: go-site
|
VERSION: 0.0.1
|
||||||
VERSION: 0.0.5
|
|
||||||
PACKAGE_REGISTRY_URL: https://${GITLAB}/api/v4/projects/${CI_PROJECT_ID}/packages/generic/${RELEASE_NAME}/${VERSION}
|
|
||||||
|
|
||||||
stages:
|
stages:
|
||||||
- build
|
- build
|
||||||
- push
|
|
||||||
- artifacts
|
|
||||||
- release
|
|
||||||
- deploy
|
- deploy
|
||||||
|
|
||||||
.rules: &rules
|
|
||||||
rules:
|
|
||||||
- if: $CI_COMMIT_TAG
|
|
||||||
when: never
|
|
||||||
- if: $CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH
|
|
||||||
|
|
||||||
build_main:
|
build_main:
|
||||||
stage: build
|
stage: build
|
||||||
image: golang:latest
|
variables:
|
||||||
<<: *rules
|
DOCKER_BASEIMAGE: golang:latest
|
||||||
script:
|
|
||||||
- cd app
|
|
||||||
- CGO_ENABLED=0 GOOS=linux GO111MODULE=auto go build -a -ldflags="-X 'main.Version=v${VERSION}'" -installsuffix cgo -o go-site .
|
|
||||||
artifacts:
|
|
||||||
paths:
|
|
||||||
- app/go-site
|
|
||||||
tags:
|
|
||||||
- docker
|
|
||||||
|
|
||||||
push_image:
|
|
||||||
stage: push
|
|
||||||
<<: *rules
|
|
||||||
before_script:
|
before_script:
|
||||||
- docker login -u gitlab-ci-token -p $CI_BUILD_TOKEN $REGISTRY
|
- docker login -u gitlab-ci-token -p $CI_BUILD_TOKEN $REGISTRY
|
||||||
script:
|
script:
|
||||||
- docker build -t $IMAGE_NAME .
|
- docker build --pull --build-arg DOCKER_BASEIMAGE=${DOCKER_BASEIMAGE} -build-arg VERSION=${VERSION} -t $IMAGE_NAME .
|
||||||
- docker push $IMAGE_NAME
|
- docker push $IMAGE_NAME
|
||||||
tags:
|
tags:
|
||||||
- docker
|
- docker
|
||||||
|
|
||||||
package:
|
|
||||||
stage: release
|
|
||||||
<<: *rules
|
|
||||||
before_script:
|
|
||||||
- apk add curl
|
|
||||||
script:
|
|
||||||
- FILE_NAME=${RELEASE_NAME}
|
|
||||||
- cd app
|
|
||||||
- 'curl --header "JOB-TOKEN: ${CI_JOB_TOKEN}" --upload-file ${FILE_NAME} ${PACKAGE_REGISTRY_URL}/${FILE_NAME}'
|
|
||||||
|
|
||||||
release:
|
|
||||||
stage: release
|
|
||||||
image: registry.gitlab.com/gitlab-org/release-cli:latest
|
|
||||||
<<: *rules
|
|
||||||
script:
|
|
||||||
- echo "Release ${RELEASE_NAME}"
|
|
||||||
release:
|
|
||||||
name: 'Release $VERSION'
|
|
||||||
description: 'Release $VERSION'
|
|
||||||
tag_name: '$VERSION'
|
|
||||||
ref: '$CI_COMMIT_SHA'
|
|
||||||
assets:
|
|
||||||
links:
|
|
||||||
- name: '${RELEASE_NAME}'
|
|
||||||
url: '${PACKAGE_REGISTRY_URL}/${RELEASE_NAME}'
|
|
||||||
|
|
||||||
deploy_prod:
|
deploy_prod:
|
||||||
stage: deploy
|
|
||||||
image: hub.realmanual.ru/pub/openssh-client:latest
|
image: hub.realmanual.ru/pub/openssh-client:latest
|
||||||
<<: *rules
|
stage: deploy
|
||||||
variables:
|
variables:
|
||||||
DOCKER_SERVER: 192.168.9.199
|
DOCKER_SERVER: 192.168.9.199
|
||||||
before_script:
|
before_script:
|
||||||
@@ -90,18 +39,6 @@ deploy_prod:
|
|||||||
- ssh-keyscan ${DOCKER_SERVER} >> ~/.ssh/known_hosts
|
- ssh-keyscan ${DOCKER_SERVER} >> ~/.ssh/known_hosts
|
||||||
- chmod 644 ~/.ssh/known_hosts
|
- chmod 644 ~/.ssh/known_hosts
|
||||||
script:
|
script:
|
||||||
- ssh root@${DOCKER_SERVER} "docker rm -f main-go; docker pull hub.bildme.ru/firstgroup/go-site && docker run -d --rm --name main-go -p 3000:3000 hub.bildme.ru/firstgroup/go-site:latest"
|
- ssh root@${DOCKER_SERVER} "docker rm -f main-go; docker pull hub.bildme.ru/firstgroup/go-site && docker run --rm --name main-go -p 3000:3000 hub.bildme.ru/firstgroup/go-site:latest"
|
||||||
environment:
|
|
||||||
name: production
|
|
||||||
url: http://${DOCKER_SERVER}:3000/
|
|
||||||
tags:
|
tags:
|
||||||
- docker
|
- docker
|
||||||
# when:
|
|
||||||
# manual
|
|
||||||
|
|
||||||
|
|
||||||
### Что можно добавить ?
|
|
||||||
### - версионирование тегов
|
|
||||||
### - возможность откатываться назад на версию (на нужную версию через ввод переменной)
|
|
||||||
### - тестирование кода линтером перед деплоем
|
|
||||||
### - возможность деплоя на два окружения (сценарий, когда сначала на стейдж, потом в ручную по тригеру на прод)
|
|
||||||
|
@@ -1,10 +1,21 @@
|
|||||||
|
ARG DOCKER_BASEIMAGE
|
||||||
|
FROM ${DOCKER_BASEIMAGE}
|
||||||
|
|
||||||
|
LABEL maintainer="${DOCKER_MAINTAINER:-vasyakrg@gmail.com}"
|
||||||
|
|
||||||
|
ADD ./app /app/
|
||||||
|
WORKDIR /app/
|
||||||
|
|
||||||
|
ARG VERSION=0.0.1
|
||||||
|
ENV VERSION=${VERSION}
|
||||||
|
|
||||||
|
RUN CGO_ENABLED=0 GOOS=linux GO111MODULE=auto go build -a -ldflags="-X 'main.Version=v${VERSION}'" -installsuffix cgo -o main .
|
||||||
|
|
||||||
|
|
||||||
FROM alpine
|
FROM alpine
|
||||||
ENV LANGUAGE="ru"
|
ENV LANGUAGE="ru"
|
||||||
|
COPY --from=0 /app/ /
|
||||||
COPY app/go-site /app/
|
|
||||||
WORKDIR /app
|
|
||||||
|
|
||||||
RUN apk add --no-cache ca-certificates &&\
|
RUN apk add --no-cache ca-certificates &&\
|
||||||
chmod +x go-site
|
chmod +x main
|
||||||
|
|
||||||
CMD [ "./go-site" ]
|
CMD [ "./main" ]
|
||||||
|
@@ -6,10 +6,8 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
)
|
)
|
||||||
|
|
||||||
var Version = "0.0.1"
|
|
||||||
|
|
||||||
func indexHandler(w http.ResponseWriter, r *http.Request) {
|
func indexHandler(w http.ResponseWriter, r *http.Request) {
|
||||||
w.Write([]byte("<h1>Hello World, im ver:"+Version+" !</h1>"))
|
w.Write([]byte("<h1>Hello World!</h1>"))
|
||||||
}
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
@@ -18,7 +16,7 @@ func main() {
|
|||||||
port = "3000"
|
port = "3000"
|
||||||
}
|
}
|
||||||
|
|
||||||
fmt.Print("\nVersion:", Version, ", Im run in http://127.0.0.1:", port)
|
fmt.Print("\nim run in http://127.0.0.1:", port)
|
||||||
|
|
||||||
mux := http.NewServeMux()
|
mux := http.NewServeMux()
|
||||||
mux.HandleFunc("/", indexHandler)
|
mux.HandleFunc("/", indexHandler)
|
||||||
|
Reference in New Issue
Block a user