NestJS의 텔레그램 봇을 위한 dokku 인프라 및 docker compose에 postgres 추가
연결
https://github.com/EndyKaufman/kaufman-bot - 봇의 소스 코드
https://telegram.me/DevelopKaufmanBot - 텔레그램의 현재 봇
https://github.com/dokku/dokku-postgres - docker compose용 dokku-postgres 플러그인
https://github.com/EndyKaufman/postgres-default - 확장이 활성화된 13개의 postgres
개발 및 프로덕션 인프라에 Postgres 추가
prod와 dev infra에 대한 데이터베이스 설정은 동일하며 dev infra에 대해서만 설명합니다.
도커 작성 파일 업데이트
도커/dev/docker-compose.yml
version: "3"
networks:
kaufman-bot-network:
ipam:
config:
- subnet: "172.6.0.0/16"
volumes:
kaufman-bot-postgres-volume:
external: true
services:
kaufman-bot-postgres:
image: 'endykaufman/postgres-default'
container_name: 'kaufman-bot-postgres'
environment:
- POSTGRES_USER=${ROOT_POSTGRES_USER}
- POSTGRES_PASSWORD=${ROOT_POSTGRES_PASSWORD}
- POSTGRES_DB=postgres
env_file:
- ../../.env.local
ports:
- '5432:5432'
volumes:
- kaufman-bot-postgres-volume:/var/lib/postgresql/data
networks:
- kaufman-bot-network
kaufman-bot-server:
image: node:16-alpine
user: ${CURRENT_UID}
container_name: "kaufman-bot-server"
environment:
- TELEGRAM_BOT_TOKEN=${TELEGRAM_BOT_TOKEN}
- PORT=3000
ports:
- "3000:3000"
- "9229:9229"
working_dir: "/app"
volumes:
- ./../../:/app
networks:
- kaufman-bot-network
command: "npm run serve"
tty: true
depends_on:
- kaufman-bot-postgres
env 파일 업데이트
.env.local
TELEGRAM_BOT_TOKEN=1111111:AAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
ROOT_POSTGRES_USER=postgres
ROOT_POSTGRES_PASSWORD=postgres
업데이트 스크립트
도커/dev/docker-compose-up.sh
#!/bin/bash
#export UID=$(id -u)
#export GID=$(id -g)
export CURRENT_UID=$(id -u):$(id -g)
docker volume create --name=kaufman-bot-postgres-volume --label=kaufman-bot-postgres-volume
docker-compose -f ./docker/dev/docker-compose.yml --compatibility up -d
드롭 볼륨이 있는 두 번째 다운 스크립트 추가
도커/dev/docker-compose-clean-down.sh
#!/bin/bash
#export UID=$(id -u)
#export GID=$(id -g)
export CURRENT_UID=$(id -u):$(id -g)
docker-compose -f ./docker/dev/docker-compose.yml down
docker volume rm kaufman-bot-postgres-volume --force
prod infra의 경우 다른 폴더에서만 같은 작업을 수행합니다.
package.json에 새 스크립트 추가
패키지.json
...
"docker:dev:clean-down": "export $(xargs < ./.env.local) > /dev/null 2>&1 && ./docker/dev/docker-compose-clean-down.sh",
"docker:dev:clean-restart": "npm run docker:dev:clean-down && npm run docker:dev:up",
"docker:prod:clean-down": "export $(xargs < ./.env.local) > /dev/null 2>&1 && ./docker/prod/docker-compose-clean-down.sh",
"docker:prod:clean-restart": "npm run docker:prod:clean-down && npm run docker:prod:up"
...
개발 인프라 재시작
npm run docker:dev:clean-restart
endy@endy-virtual-machine:~/Projects/current/kaufman-bot$ npm run docker:dev:clean-restart
> [email protected] docker:dev:clean-restart
> npm run docker:dev:clean-down && npm run docker:dev:up
> [email protected] docker:dev:clean-down
> export $(xargs < ./.env.local) > /dev/null 2>&1 && ./docker/dev/docker-compose-clean-down.sh
Stopping kaufman-bot-server ... done
Stopping kaufman-bot-postgres ... done
Removing kaufman-bot-server ... done
Removing kaufman-bot-postgres ... done
Removing network dev_kaufman-bot-network
kaufman-bot-postgres-volume
> [email protected] docker:dev:up
> export $(xargs < ./.env.local) > /dev/null 2>&1 && ./docker/dev/docker-compose-up.sh
kaufman-bot-postgres-volume
Creating network "dev_kaufman-bot-network" with the default driver
Creating kaufman-bot-postgres ... done
Creating kaufman-bot-server ... done
데이터베이스 확인
데이터베이스로 컨테이너에 연결
docker exec -it $(docker ps -aqf "name=kaufman-bot-postgres") sh
사용자 전환
su postgres
psql 모드 실행
psql
데이터베이스 이름 선택
SELECT current_database();
endy@endy-virtual-machine:~/Projects/current/kaufman-bot$ docker exec -it $(docker ps -aqf "name=kaufman-bot-postgres") sh
# su postgres
postgres@48966265f189:/$ psql
psql (13.3 (Debian 13.3-1.pgdg100+1))
Type "help" for help.
postgres=# SELECT current_database();
current_database
------------------
postgres
(1 row)
postgres=#
dokku 인프라에 postgres 추가(서버에서)
dokku-postgres 설치
이제 ssh를 통해 Ubuntu의 서버에 연결하고 postgres 작업을 설정합니다.
sudo dokku plugin:install https://github.com/dokku/dokku-postgres.git postgres
root@vps17825:~# sudo dokku plugin:install https://github.com/dokku/dokku-postgres.git postgres
-----> Cloning plugin repo https://github.com/dokku/dokku-postgres.git to /var/lib/dokku/plugins/available/postgres
Cloning into 'postgres'...
remote: Enumerating objects: 2356, done.
remote: Counting objects: 100% (417/417), done.
remote: Compressing objects: 100% (276/276), done.
remote: Total 2356 (delta 244), reused 267 (delta 118), pack-reused 1939
Receiving objects: 100% (2356/2356), 483.24 KiB | 3.48 MiB/s, done.
Resolving deltas: 100% (1580/1580), done.
-----> Plugin postgres enabled
Adding user dokku to group adm
Starting nginx (via systemctl): nginx.service.
14.1: Pulling from library/postgres
5eb5b503b376: Pull complete
daa0467a6c48: Pull complete
7cf625de49ef: Pull complete
bb8afcc973b2: Pull complete
c74bf40d29ee: Pull complete
2ceaf201bb22: Pull complete
1255f255c0eb: Pull complete
d27501cd0cca: Pull complete
ff5b6d09a5d0: Pull complete
f635aec27645: Pull complete
a165c6729250: Pull complete
b0aa4f86b611: Pull complete
9efc4664d9d2: Pull complete
Digest: sha256:3162a6ead070474b27289f09eac4c865e75f93847a2d7098f718ee5a721637c4
Status: Downloaded newer image for postgres:14.1
docker.io/library/postgres:14.1
1.31.1-uclibc: Pulling from library/busybox
76df9210b28c: Pull complete
Digest: sha256:cd421f41ebaab52ae1ac91a8391ddbd094595264c6e689954b79b3d24ea52f88
Status: Downloaded newer image for busybox:1.31.1-uclibc
docker.io/library/busybox:1.31.1-uclibc
0.3.3: Pulling from dokku/ambassador
aad63a933944: Pull complete
2888dfab2eb5: Pull complete
51ccf60e0642: Pull complete
Digest: sha256:87c0214e190e7f6975953027157a8933701596b4b864ff66dd3cc3f6ead5c38d
Status: Downloaded newer image for dokku/ambassador:0.3.3
docker.io/dokku/ambassador:0.3.3
0.10.3: Pulling from dokku/s3backup
aad63a933944: Already exists
6654c5b7b2dc: Pull complete
26abcd9faf98: Pull complete
d1a36cd3ba61: Pull complete
9517d44e685b: Pull complete
32e8b2c4797f: Pull complete
Digest: sha256:3651f8ef12000206df55fec8ad4860d6f26b2b5af1308c0e2358253641626024
Status: Downloaded newer image for dokku/s3backup:0.10.3
docker.io/dokku/s3backup:0.10.3
0.4.3: Pulling from dokku/wait
aad63a933944: Already exists
3409ea528c35: Pull complete
88e35d065209: Pull complete
Digest: sha256:5eb9da766abdd5e8cedbde9870acd4b54c1c7e63e72c99e338b009d06f808f04
Status: Downloaded newer image for dokku/wait:0.4.3
docker.io/dokku/wait:0.4.3
-----> Priming bash-completion cache
root@vps17825:~#
데이터베이스 서비스 생성
UUID 확장이 활성화된 사용자 정의 빌드를 사용하고 있습니다https://hub.docker.com/r/endykaufman/postgres-default.
dokku postgres:create global-postgres --image "endykaufman/postgres-default" --image-version latest --root-password=ROOT_PASSWORD --password=ADMIN_PASSWORD
root@vps17825:~# dokku postgres:create global-postgres --image "endykaufman/postgres-default" --root-password=ROOT_PASSWORD --password=ADMIN_PASSWORD
/var/lib/dokku/plugins/enabled/postgres/subcommands/create: illegal option -- -
/var/lib/dokku/plugins/enabled/postgres/subcommands/create: illegal option -- -
Error response from daemon: manifest for endykaufman/postgres-default:14.1 not found: manifest unknown: manifest unknown
! Postgres image endykaufman/postgres-default:14.1 pull failed
root@vps17825:~# dokku postgres:create global-postgres --image "endykaufman/postgres-default" --image-version latest --root-password=ROOT_PASSWORD --password=ADMIN_PASSWORD
/var/lib/dokku/plugins/enabled/postgres/subcommands/create: illegal option -- -
/var/lib/dokku/plugins/enabled/postgres/subcommands/create: illegal option -- -
latest: Pulling from endykaufman/postgres-default
b4d181a07f80: Pull complete
46ca1d02c28c: Pull complete
a756866b5565: Pull complete
36c49e539e90: Pull complete
664019fbcaff: Pull complete
727aeee9c480: Pull complete
796589e6b223: Pull complete
6664992e747d: Pull complete
0f933aa7ccec: Pull complete
99b5e5d88b32: Pull complete
a901b82e6004: Pull complete
625fd35fd0f3: Pull complete
9e37bf358a5d: Pull complete
8c5f37d7fa57: Pull complete
Digest: sha256:a3d342741451f717b79b2404e88363ea902a769d45a0bd7dbbbeeb73bb443f93
Status: Downloaded newer image for endykaufman/postgres-default:latest
docker.io/endykaufman/postgres-default:latest
! Specified password may not be as secure as the auto-generated password
Waiting for container to be ready
Creating container database
Securing connection to database
=====> Postgres container created: global-postgres
=====> global-postgres postgres service information
Config dir: /var/lib/dokku/services/postgres/global-postgres/data
Config options:
Data dir: /var/lib/dokku/services/postgres/global-postgres/data
Dsn: postgres://postgres:assword=ADMIN_PASSWORD@dokku-postgres-global-postgres:5432/global_postgres
Exposed ports: -
Id: 50dbeaef39b80ca97823ad35ac771b241c2214eb3bd5cd81564f9dee546ae783
Internal ip: 172.17.0.5
Links: -
Service root: /var/lib/dokku/services/postgres/global-postgres
Status: running
Version: endykaufman/postgres-default:latest
모든 postgres 서비스 나열
dokku postgres:list
데이터베이스 확인
데이터베이스에 연결
데이터베이스 이름 선택
SELECT current_database();
root@vps17825:~# dokku postgres:connect global-postgres
psql (13.3 (Debian 13.3-1.pgdg100+1))
SSL connection (protocol: TLSv1.3, cipher: TLS_AES_256_GCM_SHA384, bits: 256, compression: off)
Type "help" for help.
global_postgres=# SELECT current_database();
current_database
------------------
global_postgres
(1 row)
global_postgres=#
다음 게시물에서는 응용 프로그램에 대한 데이터베이스를 만들고 이동 경로를 통한 첫 번째 마이그레이션을 수행합니다.
Reference
이 문제에 관하여(NestJS의 텔레그램 봇을 위한 dokku 인프라 및 docker compose에 postgres 추가), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://dev.to/endykaufman/add-postgres-to-docker-compose-and-dokku-infrastructure-for-telegram-bot-in-nestjs-23ih텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념 (Collection and Share based on the CC Protocol.)