services: mysql-upgrade: Support custom datadir.

* gnu/services/databases.scm (mysql-upgrade-wrapper): Take service
configuration as argument, and pass the config file to mysql_upgrade.
(mysql-upgrade-shepherd-service): Pass CONFIG instead of just socket and
executable to MYSQL-UPGRADE-WRAPPER.
This commit is contained in:
Marius Bakke 2022-10-29 18:18:43 +02:00
parent c7b266fdf2
commit 6ac97bb503
No known key found for this signature in database
GPG key ID: A2A06DF2A33A54FA

View file

@ -6,7 +6,7 @@
;;; Copyright © 2018 Clément Lassieur <clement@lassieur.org> ;;; Copyright © 2018 Clément Lassieur <clement@lassieur.org>
;;; Copyright © 2018 Julien Lepiller <julien@lepiller.eu> ;;; Copyright © 2018 Julien Lepiller <julien@lepiller.eu>
;;; Copyright © 2019 Robert Vollmert <rob@vllmrt.net> ;;; Copyright © 2019 Robert Vollmert <rob@vllmrt.net>
;;; Copyright © 2020 Marius Bakke <marius@gnu.org> ;;; Copyright © 2020, 2022 Marius Bakke <marius@gnu.org>
;;; Copyright © 2021 David Larsson <david.larsson@selfhosted.xyz> ;;; Copyright © 2021 David Larsson <david.larsson@selfhosted.xyz>
;;; Copyright © 2021 Aljosha Papsch <ep@stern-data.com> ;;; Copyright © 2021 Aljosha Papsch <ep@stern-data.com>
;;; ;;;
@ -678,10 +678,13 @@ (define (mysql-install-shepherd-service config)
(list #$(mysql-install config)) (list #$(mysql-install config))
#:log-file "/var/log/mysqld-install.log"))))) #:log-file "/var/log/mysqld-install.log")))))
(define (mysql-upgrade-wrapper mysql socket-file) (define (mysql-upgrade-wrapper config)
;; The MySQL socket and PID file may appear before the server is ready to ;; The MySQL socket and PID file may appear before the server is ready to
;; accept connections. Ensure the socket is responsive before attempting ;; accept connections. Ensure the socket is responsive before attempting
;; to run the upgrade script. ;; to run the upgrade script.
(let ((mysql (mysql-configuration-mysql config))
(socket-file (mysql-configuration-socket config))
(config-file (mysql-configuration-file config)))
(program-file (program-file
"mysql-upgrade-wrapper" "mysql-upgrade-wrapper"
#~(begin #~(begin
@ -696,7 +699,7 @@ (define (mysql-upgrade-wrapper mysql socket-file)
(close-port sock) (close-port sock)
;; The socket is ready! ;; The socket is ready!
(execl mysql-upgrade mysql-upgrade (execl mysql-upgrade mysql-upgrade
(string-append "--socket=" #$socket-file)))) (string-append "--defaults-file=" #$config-file))))
(lambda args (lambda args
(if (< i timeout) (if (< i timeout)
(begin (begin
@ -704,7 +707,7 @@ (define (mysql-upgrade-wrapper mysql socket-file)
(loop (+ 1 i))) (loop (+ 1 i)))
;; No luck, give up. ;; No luck, give up.
(throw 'timeout-error (throw 'timeout-error
"MySQL server did not appear in time!")))))))))) "MySQL server did not appear in time!")))))))))))
(define (mysql-upgrade-shepherd-service config) (define (mysql-upgrade-shepherd-service config)
(list (shepherd-service (list (shepherd-service
@ -712,11 +715,9 @@ (define (mysql-upgrade-shepherd-service config)
(requirement '(mysql)) (requirement '(mysql))
(one-shot? #t) (one-shot? #t)
(documentation "Upgrade MySQL database schemas.") (documentation "Upgrade MySQL database schemas.")
(start (let ((mysql (mysql-configuration-mysql config)) (start #~(make-forkexec-constructor
(socket (mysql-configuration-socket config))) (list #$(mysql-upgrade-wrapper config))
#~(make-forkexec-constructor #:user "mysql" #:group "mysql")))))
(list #$(mysql-upgrade-wrapper mysql socket))
#:user "mysql" #:group "mysql"))))))
(define (mysql-shepherd-services config) (define (mysql-shepherd-services config)