1
0

🔨」 fix(Mariadb): entrypoint working !!!!!!!!!!!!1

This commit is contained in:
2025-01-09 17:29:36 +01:00
parent c447c3ae70
commit 5402fb13b6
4 changed files with 66 additions and 33 deletions

View File

@ -8,13 +8,21 @@ DOCKERFILE_DB := $(DOCKER_FOLDER)/$(DB_SERVER_NAME)/Dockerfile
DOCKERFILE_WEVSRV := $(DOCKER_FOLDER)/$(WEB_SERVER_NAME)/Dockerfile DOCKERFILE_WEVSRV := $(DOCKER_FOLDER)/$(WEB_SERVER_NAME)/Dockerfile
DOCKERFILE_CMS := $(DOCKER_FOLDER)/$(CMS_NAME)/Dockerfile DOCKERFILE_CMS := $(DOCKER_FOLDER)/$(CMS_NAME)/Dockerfile
db-build: build-db:
docker build -f $(DOCKERFILE_DB) -t $(DB_SERVER_NAME) . docker build -f $(DOCKERFILE_DB) -t $(DB_SERVER_NAME) .
websrv-build: build-websrv:
docker build -f $(DOCKERFILE_WEVSRV) -t $(WEB_SERVER_NAME) . docker build -f $(DOCKERFILE_WEVSRV) -t $(WEB_SERVER_NAME) .
cms-build: build-cms:
docker build -f $(DOCKERFILE_CMS) -t $(CMS_NAME) . docker build -f $(DOCKERFILE_CMS) -t $(CMS_NAME) .
start-db:
docker compose up db --build
clean-db:
docker stop inception-db
docker container rm inception-db
docker volume rm inception_wp-db
.PHONY: cms-build db-build websrv-build .PHONY: cms-build db-build websrv-build

View File

@ -111,30 +111,44 @@ func waitForMariaDB(rootPass string) {
os.Exit(1) os.Exit(1)
} }
func escapeIdentifier(identifier string) string { //func escapeIdentifier(identifier string) string {
// Replace backticks with double backticks to safely escape identifiers // // Replace backticks with double backticks to safely escape identifiers
return fmt.Sprintf("`%s`", strings.ReplaceAll(identifier, "'", "\"")) // return fmt.Sprintf("%s", strings.ReplaceAll(identifier, "'", "\""))
} //}
func escapePassword(password string) string { func escapePassword(password string) string {
// Escape single quotes in passwords // Escape single quotes in passwords
return strings.ReplaceAll(password, "'", "\\'") new := strings.ReplaceAll(password, "\"", "")
return strings.ReplaceAll(new, "'", "\\'")
} }
func configureMariaDB(rootPassword, user, password, database string) { func configureMariaDB(rootPassword, user, password, database string) {
cmd := exec.Command("mariadb", "-uroot", "-p"+rootPassword, "-e", fmt.Sprintf(` cmd := exec.Command("mariadb", "-uroot", "-e", fmt.Sprintf(`
ALTER USER 'root'@'localhost' IDENTIFIED BY '%s'; ALTER USER 'root'@'localhost' IDENTIFIED BY '%s';
CREATE DATABASE IF NOT EXISTS %s; CREATE DATABASE IF NOT EXISTS %s;
CREATE USER IF NOT EXISTS '%s'@'%%' IDENTIFIED BY '%s'; CREATE USER IF NOT EXISTS '%s'@'%%';
GRANT ALL PRIVILEGES ON %s.* TO '%s'@'localhost' IDENTIFIED BY '%s';
GRANT ALL PRIVILEGES ON %s.* TO '%s'@'%%'; GRANT ALL PRIVILEGES ON %s.* TO '%s'@'%%';
FLUSH PRIVILEGES; FLUSH PRIVILEGES;
`, escapePassword(rootPassword), escapeIdentifier(database), escapeIdentifier(user), escapePassword(password), escapeIdentifier(database), escapeIdentifier(user))) `,
cmd.Stdout = os.Stdout escapePassword(rootPassword),
cmd.Stderr = os.Stderr escapePassword(database),
if err := cmd.Run(); err != nil { escapePassword(user),
escapePassword(database),
escapePassword(user),
escapePassword(password),
escapePassword(database),
escapePassword(user),
))
// Capture standard output and error
output, err := cmd.CombinedOutput()
if err != nil {
fmt.Printf("Error configuring MariaDB: %v\n", err) fmt.Printf("Error configuring MariaDB: %v\n", err)
fmt.Printf("Command Output: %s\n", string(output))
os.Exit(1) os.Exit(1)
} }
fmt.Println("MariaDB configured successfully.")
} }
func main() { func main() {
@ -159,27 +173,29 @@ func main() {
cmd.Stdout = os.Stdout cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr cmd.Stderr = os.Stderr
if err := cmd.Run(); err != nil { if err := cmd.Run(); err != nil {
_log.Log("error", "Error initializing MariaDB") _log.Log("error", fmt.Sprintf("Error initializing MariaDB: %v", err))
} }
// Starting temp mariadb server for config // Starting temp mariadb server for config
cmd = exec.Command("mariadbd-safe", "--skip-networking") cmd = exec.Command("mariadbd-safe", "--datadir="+dataDir, "--skip-networking")
cmd.Stdout = os.Stdout cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr cmd.Stderr = os.Stderr
if err := cmd.Start(); err != nil { if err := cmd.Start(); err != nil {
fmt.Printf("Error starting MariaDB: %v\n", err) _log.Log("error", fmt.Sprintf("Error starting MariaDB: %v", err))
os.Exit(1)
} }
// Wait for mariadb to start // Wait for mariadb to start
waitForMariaDB(rootPass) waitForMariaDB(rootPass)
configureMariaDB(rootPass, user, pass, dbName) configureMariaDB(rootPass, user, pass, dbName)
cmd_stop := exec.Command("mariadb-admin", "-uroot", "-p"+escapePassword(rootPass), "shutdown")
cmd = exec.Command("mysqladmin", "-uroot", "-p"+rootPass, "shutdown") cmd_stop.Stdout = os.Stdout
if err := cmd.Run(); err != nil { cmd_stop.Stderr = os.Stderr
if err := cmd_stop.Run(); err != nil {
fmt.Printf("Error stopping MariaDB: %v\n", err) fmt.Printf("Error stopping MariaDB: %v\n", err)
} }
} }
if err := removeSkipNetworking(filePath); err != nil { if err := removeSkipNetworking(filePath); err != nil {
fmt.Printf("Error: %v\n", err) fmt.Printf("Error: %v\n", err)

View File

@ -3,14 +3,13 @@ package main
import ( import (
"database/sql" "database/sql"
"fmt" "fmt"
"strings"
"os" "os"
"strings"
"git.keyzox.me/42_adjoly/inception/internal/env" "git.keyzox.me/42_adjoly/inception/internal/env"
"git.keyzox.me/42_adjoly/inception/internal/log" "git.keyzox.me/42_adjoly/inception/internal/log"
) )
func escapeIdentifier(identifier string) string { func escapeIdentifier(identifier string) string {
// Replace backticks with double backticks to safely escape identifiers // Replace backticks with double backticks to safely escape identifiers
return fmt.Sprintf("`%s`", strings.ReplaceAll(identifier, "'", "\"")) return fmt.Sprintf("`%s`", strings.ReplaceAll(identifier, "'", "\""))
@ -21,30 +20,41 @@ func escapePassword(password string) string {
return strings.ReplaceAll(password, "'", "\\'") return strings.ReplaceAll(password, "'", "\\'")
} }
func checkHealth(host, user, pass, port, dbName string) bool { func checkHealth(host, user, pass, port, dbName string) bool {
dsn := fmt.Sprintf("%s:%s@tcp(%s:%s)/%s", user, pass, host, port, dbName) dsn := fmt.Sprintf("%s:%s@tcp(%s:%s)/%s", user, pass, host, port, dbName)
// Attempt to open a database connection
db, err := sql.Open("mysql", dsn) db, err := sql.Open("mysql", dsn)
if err != nil { if err != nil {
_log.Log("error", "Failed to open database connection") _log.Log("warning", fmt.Sprintf("Failed to open database connection: %v", err))
return false
} }
defer db.Close() defer db.Close()
// Attempt to ping the database
if err := db.Ping(); err != nil { if err := db.Ping(); err != nil {
_log.Log("error", "Health check failed") _log.Log("warning", fmt.Sprintf("Health check failed: %v", err))
return false
} }
_log.Log("note", "Health check passed successfully")
return true return true
} }
func main() { func main() {
// Load environment variables
pass := escapePassword(env.FileEnv("MYSQL_PASSWORD", "default")) pass := escapePassword(env.FileEnv("MYSQL_PASSWORD", "default"))
user := escapeIdentifier(env.FileEnv("MYSQL_USER", "mariadb")) user := escapeIdentifier(env.FileEnv("MYSQL_USER", "mariadb"))
dbName := escapeIdentifier(env.EnvCheck("MYSQL_DATABASE", "default")) dbName := escapeIdentifier(env.EnvCheck("MYSQL_DATABASE", "default"))
dbHost := escapeIdentifier("localhost") dbHost := "127.0.0.1"
// Perform the health check
res := checkHealth(dbHost, user, pass, "3306", dbName) res := checkHealth(dbHost, user, pass, "3306", dbName)
if res == true{ if res {
_log.Log("note", "Mariadb is healthy") _log.Log("note", "MariaDB is healthy")
os.Exit(0) os.Exit(0)
} }
_log.Log("error", "Health check failed")
_log.Log("warning", "Health check failed")
os.Exit(1)
} }

View File

@ -36,7 +36,6 @@ VOLUME /var/lib/mysql
ENTRYPOINT [ "/docker-entrypoint" ] ENTRYPOINT [ "/docker-entrypoint" ]
WORKDIR /var/lib/mysql WORKDIR /var/lib/mysql
#USER mysql
EXPOSE 3306 EXPOSE 3306
CMD [ "mariadbd", "--user=mysql" ] CMD [ "mariadbd", "--user=mysql" ]
HEALTHCHECK --interval=30s --timeout=10s --retries=3 CMD /docker-healthcheck HEALTHCHECK --interval=30s --timeout=10s --retries=3 CMD /docker-healthcheck