docker compose

This commit is contained in:
2025-08-28 00:00:18 +03:00
parent ae70c229f7
commit ebb4c5926f
7 changed files with 96 additions and 31 deletions

14
.env
View File

@@ -1,7 +1,7 @@
TG_TOKEN= # Used for bot AND docker compose
PREFIXES=/;! PSQL_USER=kurumi_bot
DEBUG=true PSQL_PASS=kurumi_bot
USE_REQ_LOG=true PSQL_NAME=kurumi_bot
PSQL_USER= MONGO_USER=kurumi_bot
PSQL_NAME= MONGO_PASS=kurumi_bot
PSQL_PASS= MONGO_NAME=kurumi_bot

5
.env.development Normal file
View File

@@ -0,0 +1,5 @@
# User ONLY for bot. Rename to .env.production
TG_TOKEN=
PREFIXES=/;!
DEBUG=true
USE_REQ_LOG=true

3
.gitignore vendored
View File

@@ -1,3 +1,4 @@
logs/ logs/
.idea/ .idea/
config.json config.json
.env.production

View File

@@ -3,5 +3,5 @@ WORKDIR /usr/src/kurumi
COPY go.mod go.sum ./ COPY go.mod go.sum ./
RUN go mod download RUN go mod download
COPY . . COPY . .
RUN go build -v -o /usr/local/bin/kurumi ./ RUN --mount=type=cache,target=/go/pkg/mod go build -trimpath -o /usr/local/bin/kurumi ./
CMD ["kurumi"] CMD ["kurumi"]

View File

@@ -1,9 +1,7 @@
package database package database
import ( import (
"encoding/json"
"fmt" "fmt"
"io"
"log" "log"
"os" "os"
@@ -19,33 +17,23 @@ type config struct {
} }
var Database *gorm.DB var Database *gorm.DB
var conf *config
func loadConfig() {
file, err := os.Open("./config.json")
if err != nil {
log.Fatalln(err)
}
data, err := io.ReadAll(file)
if err != nil {
log.Fatalln(err)
}
conf = new(config)
err = json.Unmarshal(data, conf)
if err != nil {
log.Fatalln(err)
}
}
func getDSN() string { func getDSN() string {
return fmt.Sprintf("postgresql://%s:%s@%s/%s?sslmode=disable", conf.User, conf.Password, conf.Host, conf.Database) user := os.Getenv("PSQL_USER")
password := os.Getenv("PSQL_PASS")
database := os.Getenv("PSQL_NAME")
log.Println("user:", user, "database:", database)
return fmt.Sprintf("postgresql://%s:%s@%s/%s?sslmode=disable", user, password, "postgres", database)
} }
func Connect() { func Connect() {
var err error var err error
loadConfig()
Database, err = gorm.Open(postgres.Open(getDSN()), new(gorm.Config)) Database, err = gorm.Open(postgres.Open(getDSN()), new(gorm.Config))
if err != nil { if err != nil {
log.Fatalln(err) log.Fatalln(err)
} }
err = Database.AutoMigrate(&User{}, &Fraction{}, &Group{}, &ShopAuto{})
if err != nil {
log.Fatalln(err)
}
} }

67
docker-compose.yml Normal file
View File

@@ -0,0 +1,67 @@
services:
postgres:
image: postgres:alpine
networks:
- bot
restart: always
ports:
- "5432:5432"
environment:
POSTGRES_DB: ${PSQL_NAME}
POSTGRES_USER: ${PSQL_USER}
POSTGRES_PASSWORD: ${PSQL_PASS}
healthcheck:
test: ["CMD-SHELL", "pg_isready -U ${PSQL_USER} -d ${PSQL_NAME}"]
interval: 2s
retries: 5
timeout: 10s
volumes:
- ./scripts/postgres:/docker-entrypoint-initdb.d
- postgres_data:/var/lib/postgresql/data
mongo:
image: mongo:noble
networks:
- bot
restart: always
ports:
- "27017:27017"
environment:
MONGO_INITDB_ROOT_USERNAME: ${MONGO_USER}
MONGO_INITDB_ROOT_PASSWORD: ${MONGO_PASS}
MONGO_INIDB_DATABASE: ${MONGO_NAME}
volumes:
- ./scripts/mongo:/docker-entrypoint-initdb.d
- mongo_data:/data/db
redis:
image: redis:alpine
networks:
- bot
restart: always
ports:
- "6379:6379"
bot:
env_file:
- .env
- .env.production
build:
context: ./
dockerfile: ./Dockerfile
networks:
- bot
depends_on:
mongo:
condition: service_started
redis:
condition: service_started
postgres:
condition: service_healthy
restart: true
networks:
bot:
driver: bridge
volumes:
postgres_data:
mongo_data:

View File

@@ -3,6 +3,8 @@ package main
import ( import (
"kurumibot/database" "kurumibot/database"
"kurumibot/plugins" "kurumibot/plugins"
"log"
"os"
"kurumibot/laniakea" "kurumibot/laniakea"
) )
@@ -10,12 +12,14 @@ import (
func main() { func main() {
database.Connect() database.Connect()
bot := laniakea.NewBot(&laniakea.BotSettings{ bot := laniakea.NewBot(&laniakea.BotSettings{
Token: "", Token: os.Getenv("TG_TOKEN"),
Debug: true, Debug: true,
Prefixes: laniakea.LoadPrefixesFromEnv(), Prefixes: laniakea.LoadPrefixesFromEnv(),
UseRequestLogger: true, UseRequestLogger: true,
LoggerBasePath: "./logs/", LoggerBasePath: "./logs/",
}) })
log.Println(os.Getenv("PSQL_NAME"))
log.Println(os.Getenv("PREFIXES"))
bot = bot.ErrorTemplate("Во время выполнения команды произошла ошибка!\nСообщите об этом разработчику!\n\n%s") bot = bot.ErrorTemplate("Во время выполнения команды произошла ошибка!\nСообщите об этом разработчику!\n\n%s")
plugins.RegisterEconomy(bot) plugins.RegisterEconomy(bot)
plugins.RegisterWaifus(bot) plugins.RegisterWaifus(bot)