1 Commits
master ... pg

Author SHA1 Message Date
702d225db4 Change: PG stuff 2025-06-16 22:35:38 +01:00
3 changed files with 46 additions and 109 deletions

View File

@ -5,17 +5,14 @@ GAME_IMAGE=git.old-metin2.com/metin2/server:latest
WEB_IMAGE=git.old-metin2.com/metin2/web:latest WEB_IMAGE=git.old-metin2.com/metin2/web:latest
################################################################################ ################################################################################
# MySQL settings # PostgreSQL settings
################################################################################ ################################################################################
MYSQL_HOST=mysql POSTGRES_HOST=postgresql
MYSQL_USER=root POSTGRES_USER=server
MYSQL_PASSWORD=metin2 POSTGRES_PASSWORD=metin2
MYSQL_PORT=3306 POSTGRES_PORT=5432
MYSQL_EXTERNAL_PORT=3306 POSTGRES_EXTERNAL_PORT=5432
MYSQL_DB_ACCOUNT=account POSTGRES_DB=account
MYSQL_DB_PLAYER=player
MYSQL_DB_COMMON=common
MYSQL_DB_LOG=log
################################################################################ ################################################################################
# Web app settings # Web app settings

View File

@ -1,5 +0,0 @@
CREATE DATABASE account CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
CREATE DATABASE common CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
CREATE DATABASE log CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
CREATE DATABASE player CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
CREATE DATABASE website CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

View File

@ -1,13 +1,10 @@
x-environment: x-environment: &common-environment
&common-environment POSTGRES_HOST: ${POSTGRES_HOST}
MYSQL_HOST: ${MYSQL_HOST} POSTGRES_USER: ${POSTGRES_USER}
MYSQL_USER: ${MYSQL_USER} POSTGRES_PASSWORD: ${POSTGRES_PASSWORD}
MYSQL_PASSWORD: ${MYSQL_PASSWORD} POSTGRES_PORT: ${POSTGRES_PORT}
MYSQL_PORT: ${MYSQL_PORT} POSTGRES_EXTERNAL_PORT: ${POSTGRES_EXTERNAL_PORT}
MYSQL_DB_ACCOUNT: ${MYSQL_DB_ACCOUNT} POSTGRES_DB: ${POSTGRES_DB}
MYSQL_DB_PLAYER: ${MYSQL_DB_PLAYER}
MYSQL_DB_COMMON: ${MYSQL_DB_COMMON}
MYSQL_DB_LOG: ${MYSQL_DB_LOG}
TEST_SERVER: ${TEST_SERVER} TEST_SERVER: ${TEST_SERVER}
@ -20,62 +17,23 @@ x-environment:
WEB_APP_KEY: ${WEB_APP_KEY} WEB_APP_KEY: ${WEB_APP_KEY}
services: services:
# MySQL Database # PostgreSQL Database
mysql: postgresql:
# The biarms/mysql Docker image supports ARM machines; you may also use mysql:5.5 image: postgresql:16
image: biarms/mysql:5.5
restart: always restart: always
environment: environment:
# Password for root access # Password for root access
MYSQL_ROOT_PASSWORD: ${MYSQL_PASSWORD} POSTGRES_DB: ${POSTGRES_DB}
POSTGRES_USER: ${POSTGRES_USER}
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD}
ports: ports:
- '${MYSQL_EXTERNAL_PORT}:${MYSQL_PORT}' - "${POSTGRES_EXTERNAL_PORT}:${POSTGRES_PORT}"
expose: expose:
- ${MYSQL_PORT} - ${POSTGRES_PORT}
volumes: volumes:
- ./storage/database/:/var/lib/mysql/ - ./storage/database/:/var/lib/postgresql/data/
- ./assets/db-init/:/docker-entrypoint-initdb.d/:ro
healthcheck: healthcheck:
test: mysqladmin ping -h localhost -u root -p$$MYSQL_ROOT_PASSWORD test: pg_isready -d $POSTGRES_DB
interval: 10s
timeout: 5s
retries: 5
# Web management system
web:
image: ${WEB_IMAGE}
restart: always
environment:
# Application config
APP_NAME: ${WEB_APP_NAME}
APP_ENV: ${WEB_APP_ENV}
APP_KEY: ${WEB_APP_KEY}
APP_URL: ${WEB_APP_URL}
# Database credentials
DB_HOST: ${MYSQL_HOST}
DB_PORT: ${MYSQL_PORT}
DB_USERNAME: ${MYSQL_USER}
DB_PASSWORD: ${MYSQL_PASSWORD}
# E-mail config
MAIL_MAILER: ${WEB_MAIL_MAILER}
MAIL_HOST: ${WEB_MAIL_HOST}
MAIL_PORT: ${WEB_MAIL_PORT}
MAIL_USERNAME: ${WEB_MAIL_USERNAME}
MAIL_PASSWORD: ${WEB_MAIL_PASSWORD}
MAIL_ENCRYPTION: ${WEB_MAIL_ENCRYPTION}
MAIL_FROM_ADDRESS: ${WEB_MAIL_FROM_ADDRESS}
MAIL_FROM_NAME: ${WEB_MAIL_FROM_NAME}
ports:
- '${WEB_EXTERNAL_PORT}:80'
volumes:
- ./storage/web/:/app/storage/
depends_on:
mysql:
condition: service_healthy
healthcheck:
test: curl --fail http://localhost:80/ || exit 1
interval: 10s interval: 10s
timeout: 5s timeout: 5s
retries: 5 retries: 5
@ -91,9 +49,7 @@ services:
volumes: volumes:
- ./storage/log/db/:/app/log/ - ./storage/log/db/:/app/log/
depends_on: depends_on:
mysql: postgresql:
condition: service_healthy
web:
condition: service_healthy condition: service_healthy
# Auth server # Auth server
@ -102,7 +58,6 @@ services:
restart: always restart: always
environment: environment:
<<: *common-environment <<: *common-environment
MYSQL_DB_PLAYER: ${MYSQL_DB_ACCOUNT}
GAME_HOSTNAME: auth GAME_HOSTNAME: auth
GAME_CHANNEL: 1 GAME_CHANNEL: 1
GAME_AUTH_SERVER: master GAME_AUTH_SERVER: master
@ -112,14 +67,12 @@ services:
- 11000 - 11000
- 12000 - 12000
ports: ports:
- '11000:11000' - "11000:11000"
command: game command: game
volumes: volumes:
- ./storage/log/auth/:/app/log/ - ./storage/log/auth/:/app/log/
depends_on: depends_on:
mysql: postgresql:
condition: service_healthy
web:
condition: service_healthy condition: service_healthy
# Game server (CH1) # Game server (CH1)
@ -138,15 +91,13 @@ services:
- 13000 - 13000
- 14000 - 14000
ports: ports:
- '13000:13000' - "13000:13000"
command: game command: game
volumes: volumes:
- ./storage/log/ch1/first/:/app/log/ - ./storage/log/ch1/first/:/app/log/
- ./storage/mark/:/app/mark/ - ./storage/mark/:/app/mark/
depends_on: depends_on:
mysql: postgresql:
condition: service_healthy
web:
condition: service_healthy condition: service_healthy
ch1_game1: ch1_game1:
@ -164,14 +115,12 @@ services:
- 13001 - 13001
- 14001 - 14001
ports: ports:
- '13001:13001' - "13001:13001"
command: game command: game
volumes: volumes:
- ./storage/log/ch1/game1/:/app/log/ - ./storage/log/ch1/game1/:/app/log/
depends_on: depends_on:
mysql: postgresql:
condition: service_healthy
web:
condition: service_healthy condition: service_healthy
ch1_game2: ch1_game2:
@ -189,14 +138,12 @@ services:
- 13002 - 13002
- 14002 - 14002
ports: ports:
- '13002:13002' - "13002:13002"
command: game command: game
volumes: volumes:
- ./storage/log/ch1/game2/:/app/log/ - ./storage/log/ch1/game2/:/app/log/
depends_on: depends_on:
mysql: postgresql:
condition: service_healthy
web:
condition: service_healthy condition: service_healthy
# Game server (game99) # Game server (game99)
@ -215,12 +162,10 @@ services:
- 13099 - 13099
- 14099 - 14099
ports: ports:
- '13099:13099' - "13099:13099"
command: game command: game
volumes: volumes:
- ./storage/log/game99/:/app/log/ - ./storage/log/game99/:/app/log/
depends_on: depends_on:
mysql: postgresql:
condition: service_healthy
web:
condition: service_healthy condition: service_healthy