Agregando moka
This commit is contained in:
62
stacks/moka/.env.example
Normal file
62
stacks/moka/.env.example
Normal file
@@ -0,0 +1,62 @@
|
||||
APP_NAME=Moka
|
||||
APP_ENV=production
|
||||
APP_KEY=
|
||||
APP_DEBUG=false
|
||||
|
||||
APP_URL=http://localhost
|
||||
|
||||
APP_LOCALE=es
|
||||
APP_FALLBACK_LOCALE=en
|
||||
APP_FAKER_LOCALE=en_US
|
||||
APP_MAINTENANCE_DRIVER=file
|
||||
|
||||
PHP_CLI_SERVER_WORKERS=4
|
||||
|
||||
BCRYPT_ROUNDS=12
|
||||
|
||||
LOG_CHANNEL=stack
|
||||
LOG_STACK=single
|
||||
LOG_DEPRECATIONS_CHANNEL=null
|
||||
LOG_LEVEL=debug
|
||||
|
||||
DB_CONNECTION=pgsql
|
||||
DB_HOST=pgsql
|
||||
DB_PORT=5432
|
||||
DB_DATABASE=moka
|
||||
DB_USERNAME=moka
|
||||
DB_PASSWORD=secret
|
||||
|
||||
SESSION_DRIVER=database
|
||||
SESSION_LIFETIME=120
|
||||
SESSION_ENCRYPT=false
|
||||
SESSION_PATH=/
|
||||
SESSION_DOMAIN=null
|
||||
|
||||
BROADCAST_CONNECTION=log
|
||||
FILESYSTEM_DISK=local
|
||||
QUEUE_CONNECTION=database
|
||||
CACHE_STORE=database
|
||||
|
||||
MEMCACHED_HOST=127.0.0.1
|
||||
|
||||
REDIS_CLIENT=phpredis
|
||||
REDIS_HOST=127.0.0.1
|
||||
REDIS_PASSWORD=null
|
||||
REDIS_PORT=6379
|
||||
|
||||
MAIL_MAILER=log
|
||||
MAIL_SCHEME=null
|
||||
MAIL_HOST=127.0.0.1
|
||||
MAIL_PORT=2525
|
||||
MAIL_USERNAME=null
|
||||
MAIL_PASSWORD=null
|
||||
MAIL_FROM_ADDRESS="hello@example.com"
|
||||
MAIL_FROM_NAME="${APP_NAME}"
|
||||
|
||||
AWS_ACCESS_KEY_ID=
|
||||
AWS_SECRET_ACCESS_KEY=
|
||||
AWS_DEFAULT_REGION=us-east-1
|
||||
AWS_BUCKET=
|
||||
AWS_USE_PATH_STYLE_ENDPOINT=false
|
||||
|
||||
VITE_APP_NAME="${APP_NAME}"
|
||||
0
stacks/moka/compose.traefik.yml
Normal file
0
stacks/moka/compose.traefik.yml
Normal file
103
stacks/moka/compose.yml
Normal file
103
stacks/moka/compose.yml
Normal file
@@ -0,0 +1,103 @@
|
||||
x-app-base: &app-base
|
||||
image: git.skrd.fun/skrd/moka:latest
|
||||
restart: unless-stopped
|
||||
env_file:
|
||||
- .env
|
||||
|
||||
x-healthcheck-common: &healthcheck
|
||||
interval: 10s
|
||||
timeout: 5s
|
||||
retries: 3
|
||||
start_period: 20s
|
||||
|
||||
services:
|
||||
app:
|
||||
<<: *app-base
|
||||
depends_on:
|
||||
pgsql:
|
||||
condition: service_healthy
|
||||
redis:
|
||||
condition: service_healthy
|
||||
environment:
|
||||
CONTAINER_ROLE: web
|
||||
volumes:
|
||||
- ${DATA_DIR}/storage:/app/storage
|
||||
healthcheck:
|
||||
<<: *healthcheck
|
||||
test: ["CMD", "php", "-r", "exit((int) !@fsockopen('127.0.0.1', 8000));"]
|
||||
|
||||
queue:
|
||||
<<: *app-base
|
||||
depends_on:
|
||||
app:
|
||||
condition: service_healthy
|
||||
pgsql:
|
||||
condition: service_healthy
|
||||
redis:
|
||||
condition: service_healthy
|
||||
environment:
|
||||
CONTAINER_ROLE: queue
|
||||
volumes:
|
||||
- ${DATA_DIR}/storage:/app/storage
|
||||
healthcheck:
|
||||
<<: *healthcheck
|
||||
test:
|
||||
[
|
||||
"CMD",
|
||||
"php",
|
||||
"-r",
|
||||
"$$cmd = str_replace(\"\\0\", ' ', (string) file_get_contents('/proc/1/cmdline')); exit(str_contains($$cmd, 'artisan queue:work') ? 0 : 1);",
|
||||
]
|
||||
|
||||
scheduler:
|
||||
<<: *app-base
|
||||
depends_on:
|
||||
app:
|
||||
condition: service_healthy
|
||||
pgsql:
|
||||
condition: service_healthy
|
||||
redis:
|
||||
condition: service_healthy
|
||||
environment:
|
||||
CONTAINER_ROLE: scheduler
|
||||
volumes:
|
||||
- ${DATA_DIR}/storage:/app/storage
|
||||
healthcheck:
|
||||
<<: *healthcheck
|
||||
test:
|
||||
[
|
||||
"CMD",
|
||||
"php",
|
||||
"-r",
|
||||
"$$cmd = str_replace(\"\\0\", ' ', (string) file_get_contents('/proc/1/cmdline')); exit(str_contains($$cmd, 'artisan schedule:work') ? 0 : 1);",
|
||||
]
|
||||
|
||||
pgsql:
|
||||
image: postgres:18
|
||||
restart: unless-stopped
|
||||
shm_size: 128mb
|
||||
environment:
|
||||
PGPASSWORD: "${DB_PASSWORD:-secret}"
|
||||
POSTGRES_DB: "${DB_DATABASE}"
|
||||
POSTGRES_USER: "${DB_USERNAME}"
|
||||
POSTGRES_PASSWORD: "${DB_PASSWORD:-secret}"
|
||||
volumes:
|
||||
- ${DATA_DIR}/db:/var/lib/postgresql
|
||||
healthcheck:
|
||||
test: ["CMD-SHELL", "pg_isready -U $$POSTGRES_USER -d $$POSTGRES_DB"]
|
||||
interval: 10s
|
||||
timeout: 5s
|
||||
retries: 5
|
||||
start_period: 10s
|
||||
|
||||
redis:
|
||||
image: redis:alpine
|
||||
restart: unless-stopped
|
||||
volumes:
|
||||
- ${DATA_DIR}/cache:/data
|
||||
healthcheck:
|
||||
test: ["CMD", "redis-cli", "ping"]
|
||||
interval: 10s
|
||||
timeout: 5s
|
||||
retries: 5
|
||||
start_period: 5s
|
||||
Reference in New Issue
Block a user