-
Notifications
You must be signed in to change notification settings - Fork 6
/
Makefile
executable file
·132 lines (100 loc) · 4.76 KB
/
Makefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
POSTGRES_DSN="postgresql://u8user:u8pass@localhost:5432/u8views?sslmode=disable"
include Makefile.ansible
env-up:
docker-compose -f docker-compose.yml --env-file .env up -d
restart:
docker restart go_u8views_app
logs:
docker logs go_u8views_app
pg:
docker exec -it go_u8views_postgres bash
env-down:
docker-compose -f docker-compose.yml --env-file .env down
env-down-with-clear:
docker-compose -f docker-compose.yml --env-file .env down --remove-orphans -v # --rmi=all
app-build:
docker exec go_u8views_app go build -o /bin/u8views-server ./cmd/v3/main.go
app-start:
docker exec go_u8views_app u8views-server
app-stop:
docker exec go_u8views_app pkill u8views-server || echo "u8views-server already stopped"
app-restart: app-build app-stop app-start
# make migrate-pgsql-create NAME=init
migrate-pgsql-create:
# mkdir -p ./internal/storage/migrations
$(eval NAME ?= todo)
goose -dir ./internal/storage/migrations -table schema_migrations postgres $(POSTGRES_DSN) create $(NAME) sql
migrate-pgsql-goose-install:
docker exec go_u8views_app go install github.com/pressly/goose/v3/cmd/goose@latest
migrate-pgsql-up: migrate-pgsql-goose-install
docker exec go_u8views_app goose -dir ./internal/storage/migrations -table schema_migrations postgres up
migrate-pgsql-redo:
docker exec go_u8views_app goose -dir ./internal/storage/migrations -table schema_migrations postgres redo
migrate-pgsql-down:
docker exec go_u8views_app goose -dir ./internal/storage/migrations -table schema_migrations postgres down
migrate-pgsql-reset:
docker exec go_u8views_app goose -dir ./internal/storage/migrations -table schema_migrations postgres reset
migrate-pgsql-status:
docker exec go_u8views_app goose -dir ./internal/storage/migrations -table schema_migrations postgres status
migrate-all-reset:
time make migrate-pgsql-reset migrate-pgsql-up
generate-sqlc:
sqlc generate
generate-template:
# go install github.com/valyala/quicktemplate/qtc
qtc -dir=./internal/templates/v2 -skipLineComments
git add .
# BENCHTIME=100x make bench
# BENCHTIME=1000x make bench
# BENCHTIME=10000x make bench
bench:
$(eval BENCHTIME ?= 100x)
echo "BENCHTIME=$(BENCHTIME) make bench"
POSTGRES_DSN=$(POSTGRES_DSN) go test ./internal/tests/... -v -bench=. -benchmem -benchtime=$(BENCHTIME)
postgres-fixtures:
test -f "./console/postgres-fixtures.sql"
cat ./console/postgres-fixtures.sql | docker exec -i go_u8views_postgres psql -d u8views -U u8user
postgres-fixtures-count:
test -f "./console/postgres-fixtures-count.sql"
cat ./console/postgres-fixtures-count.sql | docker exec -i go_u8views_postgres psql -d u8views -U u8user
postgres-fixtures-clear:
test -f "./console/postgres-fixtures-clear.sql"
cat ./console/postgres-fixtures-clear.sql | docker exec -i go_u8views_postgres psql -d u8views -U u8user
go-mod-update:
go mod tidy
go mod vendor
local-go-app-run:
POSTGRES_DSN=$(POSTGRES_DSN) PORT=:8080 go run ./cmd/v1/main.go
esbuild-minify:
MINIFY=true npm run --prefix=client esbuild
tree -h ./public/assets/js
esbuild:
MINIFY=false npm run --prefix=client esbuild
tree -h ./public/assets/js
# BIGINT PRIMARY KEY (time, user_id) 1 MONTH * 10 000 = 1.735GB
# BIGINT PRIMARY KEY (time, user_id) 1 YEAR * 10 000 = 8.447GB
# BIGINT PRIMARY KEY (user_id, time) 1 MONTH * 10 000 = 1.804GB
# INT PRIMARY KEY (user_id, time) 1 MONTH * 10 000 = 1.804GB
postgres-volume-size:
docker system df -v | grep go-u8views_postgres-data
docker stats --no-stream
ssh:
# cat ~/.ssh/id_ed25519.pub | ssh [email protected] "mkdir -p ~/.ssh && cat >> ~/.ssh/authorized_keys"
ssh -t [email protected] "cd /var/go/u8views/; bash --login"
ssh-copy-tls-certificates:
mkdir -p ./.docker/volumes/go/tls-certificates
scp -r [email protected]:/var/go/u8views/.docker/volumes/go/tls-certificates ./.docker/volumes/go
# POSTGRES_PASSWORD=$(echo "$RANDOM$RANDOM" | md5sum | head -c 16; echo;) make generate-production-environment-file
generate-production-environment-file:
touch .production.env
grep -qF 'PORT=' .production.env || echo 'PORT=:80' >> .production.env
grep -qF 'ENVIRONMENT=' .production.env || echo 'ENVIRONMENT="production"' >> .production.env
# Database
grep -qF 'POSTGRES_USER=' .production.env || echo 'POSTGRES_USER="u8user"' >> .production.env
grep -qF 'POSTGRES_PASSWORD=' .production.env || echo 'POSTGRES_PASSWORD="$(POSTGRES_PASSWORD)"' >> .production.env
grep -qF 'POSTGRES_DB=' .production.env || echo 'POSTGRES_DB="u8views"' >> .production.env
grep -qF 'POSTGRES_DSN=' .production.env || echo 'POSTGRES_DSN=postgresql://u8user:$(POSTGRES_PASSWORD)@postgres:5432/u8views?sslmode=disable' >> .production.env
# OAuth 2.0
grep -qF 'GITHUB_CLIENT_ID=' .production.env || echo 'GITHUB_CLIENT_ID=' >> .production.env
grep -qF 'GITHUB_CLIENT_SECRET=' .production.env || echo 'GITHUB_CLIENT_SECRET=' >> .production.env
cat .production.env