「🔨」 fix(Mariadb): entrypoint working !!!!!!!!!!!!1
This commit is contained in:
14
Makefile
14
Makefile
@ -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
|
||||||
|
@ -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)
|
||||||
|
@ -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)
|
||||||
}
|
}
|
||||||
|
@ -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
|
||||||
|
Reference in New Issue
Block a user