Merge pull request #2 from SamuelTariku/1-docker-container-fix
1 docker container fix
This commit is contained in:
commit
221fed90e9
17
Dockerfile
Normal file
17
Dockerfile
Normal file
|
|
@ -0,0 +1,17 @@
|
||||||
|
# Builder stage
|
||||||
|
FROM golang:1.24-alpine AS builder
|
||||||
|
|
||||||
|
WORKDIR /app
|
||||||
|
COPY go.mod go.sum ./
|
||||||
|
RUN go mod download
|
||||||
|
COPY . .
|
||||||
|
RUN go build -ldflags="-s -w" -o ./bin/web ./cmd/main.go
|
||||||
|
|
||||||
|
# Runner stage
|
||||||
|
FROM alpine:3.21 AS runner
|
||||||
|
WORKDIR /app
|
||||||
|
COPY .env .
|
||||||
|
COPY --from=builder /app/bin/web /app/bin/web
|
||||||
|
RUN apk add --no-cache ca-certificates
|
||||||
|
EXPOSE ${PORT}
|
||||||
|
CMD ["/app/bin/web"]
|
||||||
|
|
@ -1,3 +1,5 @@
|
||||||
|
version: '3.9'
|
||||||
|
|
||||||
services:
|
services:
|
||||||
postgres:
|
postgres:
|
||||||
image: postgres:16-alpine
|
image: postgres:16-alpine
|
||||||
|
|
@ -14,6 +16,7 @@ services:
|
||||||
interval: 5s
|
interval: 5s
|
||||||
timeout: 3s
|
timeout: 3s
|
||||||
retries: 5
|
retries: 5
|
||||||
|
|
||||||
migrate:
|
migrate:
|
||||||
image: migrate/migrate
|
image: migrate/migrate
|
||||||
volumes:
|
volumes:
|
||||||
|
|
@ -32,6 +35,34 @@ services:
|
||||||
networks:
|
networks:
|
||||||
- app
|
- app
|
||||||
|
|
||||||
|
app:
|
||||||
|
build:
|
||||||
|
context: .
|
||||||
|
dockerfile: Dockerfile
|
||||||
|
target: runner
|
||||||
|
ports:
|
||||||
|
- ${PORT}:8080
|
||||||
|
environment:
|
||||||
|
- DB_URL=postgresql://root:secret@postgres:5432/gh?sslmode=disable
|
||||||
|
depends_on:
|
||||||
|
migrate:
|
||||||
|
condition: service_completed_successfully
|
||||||
|
networks:
|
||||||
|
- app
|
||||||
|
command: ["/app/bin/web"]
|
||||||
|
|
||||||
|
|
||||||
|
test:
|
||||||
|
build:
|
||||||
|
context: .
|
||||||
|
dockerfile: Dockerfile
|
||||||
|
target: builder
|
||||||
|
volumes:
|
||||||
|
- .:/app
|
||||||
|
command: ["tail", "-f", "/dev/null"]
|
||||||
|
networks:
|
||||||
|
- app
|
||||||
|
|
||||||
networks:
|
networks:
|
||||||
app:
|
app:
|
||||||
driver: bridge
|
driver: bridge
|
||||||
40
makefile
40
makefile
|
|
@ -1,41 +1,57 @@
|
||||||
include .env
|
include .env
|
||||||
.PHONY: test
|
.PHONY: test
|
||||||
test:
|
test:
|
||||||
@go test ./app
|
@docker compose up -d test
|
||||||
|
@docker compose exec test go test ./...
|
||||||
|
@docker compose stop test
|
||||||
|
|
||||||
.PHONY: coverage
|
.PHONY: coverage
|
||||||
coverage:
|
coverage:
|
||||||
@mkdir -p coverage
|
@mkdir -p coverage
|
||||||
@go test -coverprofile=coverage.out ./internal/...
|
@docker compose up -d test
|
||||||
@go tool cover -func=coverage.out -o coverage/coverage.txt
|
@docker compose exec test sh -c "go test -coverprofile=coverage.out ./internal/... && go tool cover -func=coverage.out -o coverage/coverage.txt"
|
||||||
|
@docker cp $(shell docker ps -q -f "name=fortunebet-test-1"):/app/coverage ./ || true
|
||||||
|
@docker compose stop test
|
||||||
|
|
||||||
.PHONY: build
|
.PHONY: build
|
||||||
build:
|
build:
|
||||||
@go build -ldflags="-s" -o ./bin/web ./
|
@docker compose build app
|
||||||
|
|
||||||
.PHONY: run
|
.PHONY: run
|
||||||
run:
|
run:
|
||||||
@echo "Running Go application"
|
@docker compose up -d
|
||||||
@go run ./cmd/main.go
|
|
||||||
|
.PHONY: stop
|
||||||
|
stop:
|
||||||
|
@docker compose down
|
||||||
|
|
||||||
.PHONY: air
|
.PHONY: air
|
||||||
air:
|
air:
|
||||||
@echo "Running air"
|
@echo "Running air locally (not in Docker)"
|
||||||
@air -c .air.toml
|
@air -c .air.toml
|
||||||
.PHONY: migrations/up
|
|
||||||
|
.PHONY: migrations/new
|
||||||
migrations/new:
|
migrations/new:
|
||||||
@echo 'Creating migration files for DB_URL'
|
@echo 'Creating migration files for DB_URL'
|
||||||
@migrate create -seq -ext=.sql -dir=./db/migrations $(name)
|
@migrate create -seq -ext=.sql -dir=./db/migrations $(name)
|
||||||
|
|
||||||
.PHONY: migrations/up
|
.PHONY: migrations/up
|
||||||
migrations/up:
|
migrations/up:
|
||||||
@echo 'Running up migrations...'
|
@echo 'Running up migrations...'
|
||||||
@migrate -path ./db/migrations -database $(DB_URL) up
|
@docker compose up migrate
|
||||||
|
|
||||||
.PHONY: swagger
|
.PHONY: swagger
|
||||||
swagger:
|
swagger:
|
||||||
@swag init -g cmd/main.go
|
@swag init -g cmd/main.go
|
||||||
|
|
||||||
.PHONY: db-up
|
.PHONY: db-up
|
||||||
db-up:
|
db-up:
|
||||||
docker compose -f compose.db.yaml up
|
@docker compose up -d postgres
|
||||||
|
|
||||||
.PHONY: db-down
|
.PHONY: db-down
|
||||||
db-down:
|
db-down:
|
||||||
docker compose -f compose.db.yaml down
|
@docker compose down
|
||||||
|
|
||||||
.PHONY: sqlc-gen
|
.PHONY: sqlc-gen
|
||||||
sqlc-gen:
|
sqlc-gen:
|
||||||
@sqlc generate
|
@sqlc generate
|
||||||
Loading…
Reference in New Issue
Block a user