]> Frank Brehm's Git Trees - config/helga/etc.git/commitdiff
saving uncommitted changes in /etc prior to emerge run
authorFrank Brehm <frank@brehm-online.com>
Tue, 25 Oct 2016 19:26:29 +0000 (21:26 +0200)
committerroot <root@helga.brehm-online.com>
Tue, 25 Oct 2016 19:26:29 +0000 (21:26 +0200)
.etckeeper
conf.d/mysql
conf.d/mysql-s6 [new file with mode: 0644]
init.d/mysql
init.d/mysql-s6 [new file with mode: 0755]
logrotate.d/mysql

index e6504d3db3ad22a14e301b41af3acda29507713e..3f2ce6f99e7ea7b3a47fb562d91fc977e53d043f 100755 (executable)
@@ -440,6 +440,7 @@ maybe chmod 0644 'conf.d/mit-krb5kdc'
 maybe chmod 0644 'conf.d/mit-krb5kpropd'
 maybe chmod 0644 'conf.d/modules'
 maybe chmod 0644 'conf.d/mysql'
+maybe chmod 0644 'conf.d/mysql-s6'
 maybe chmod 0644 'conf.d/named'
 maybe chmod 0644 'conf.d/net'
 maybe chmod 0644 'conf.d/net-online'
@@ -1678,6 +1679,7 @@ maybe chmod 0755 'init.d/modules'
 maybe chmod 0755 'init.d/mount-ro'
 maybe chmod 0755 'init.d/mtab'
 maybe chmod 0755 'init.d/mysql'
+maybe chmod 0755 'init.d/mysql-s6'
 maybe chmod 0755 'init.d/named'
 maybe chmod 0755 'init.d/net-online'
 maybe chmod 0755 'init.d/net.lo'
index 953575b24766992ee167af4bf99fa83913723f79..eefb867f0b79d20704aba1758b4c32d0c2b5553f 100644 (file)
@@ -1,6 +1,6 @@
 # Copyright 1999-2014 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
-# $Header: /var/cvsroot/gentoo-x86/dev-db/mysql-init-scripts/files/conf.d-2.0,v 1.1 2014/08/21 03:08:13 grknight Exp $
+# $Id$
 
 # If you want a non-stock location for the config file, uncomment or update
 # either of these as needed. If you do use it, you must make sure that none of
diff --git a/conf.d/mysql-s6 b/conf.d/mysql-s6
new file mode 100644 (file)
index 0000000..eefb867
--- /dev/null
@@ -0,0 +1,79 @@
+# Copyright 1999-2014 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Id$
+
+# If you want a non-stock location for the config file, uncomment or update
+# either of these as needed. If you do use it, you must make sure that none of
+# your socket, pidfile, datadir, logfiles, binary logs, relay logs or InnoDB
+# files collide with each other.
+MY_CNF="/etc/mysql/my.cnf"
+#MY_CNF="${MY_CNF:-/etc/${SVCNAME}/my.cnf}"
+#MY_CNF="${MY_CNF:-/etc/mysql/my-${SVCNAME/mysql.}.cnf}"
+
+# Place any additional arguments here that you might need
+# Common/useful options:
+# --skip-slave-start=1 - For bringing up replication initially
+# --server-id=NNN - Server ID for replication
+# --skip-networking - lock it down to UNIX sockets only
+MY_ARGS=""
+
+# This setting (in seconds) should be high enough to allow InnoDB to do a full
+# checkpoint recovery. 900 is the default used in the upstream RPM startup
+# scripts. 30 seconds should be sufficent if you just have a tiny <1GiB
+# database. After the core startup is done, we wait this long for the UNIX
+# socket to appear.
+STARTUP_TIMEOUT="900"
+
+# This is how long, in milliseconds, we wait for pidfile to be created, early
+# in the startup.
+STARTUP_EARLY_TIMEOUT="1000"
+
+# How long (in seconds) should we wait for shutdown?
+STOP_TIMEOUT=120
+
+# integer [-20 .. 19 ] default 0
+# change the priority of the server -20 (high) to 19 (low)
+# see nice(1) for description
+#NICE=0
+
+# See start-stop-daemon(8) for possible settings
+#IONICE=2
+
+# If defined, --verbose gets passed to S-S-D
+#DEBUG=1
+
+# Depending on your usage of MySQL, you may also wish to start it after some
+# other services are up. Uncomment the lines below as needed. If these aren't
+# enough for you, we encourage you to file a bug, and help us understand how
+# you are using MySQL.
+
+# Do your MySQL ACLs refer to hostnames not in your /etc/hosts?
+# If so, you need DNS before you can accept connections.
+# Avoid dependency circular loops if you use MySQL to power a local DNS server.
+#rc_use="dns"
+#rc_after="dns"
+
+# Does your MySQL bind to an IP on an interface other than net.lo?
+# Alternatively you might wish to specify the exact interface here.
+#rc_use="net"
+#rc_after="net"
+
+# Do you store your MySQL files on a SAN or other network filesystem, that is
+# provided by the netmount init script?
+#rc_need="netmount"
+
+# Or from NFS? P.S. This is not a good idea in most cases, but does have some
+# valid usage cases, so we provide the option.
+#rc_need="nfsmount"
+
+# Should any one of the instances satisfy the requirement for MySQL coming up?
+# By default, we say no.
+[ "${SVCNAME}" != mysql ] && rc_provide="!mysql"
+# But uncomment this next instead if you think it should.
+#rc_provide="mysql"
+
+# The conditional above has a false-positive "failure" return value as a
+# side-effect, and since it's the last statement, without the next line, this
+# script returns failure.
+return 0
+# vim: ft=gentoo-conf-d et ts=4 sw=4:
index 2d0574588a94cf25175c0232d6dac7de2ccaff47..19a4b927dc48f5d6b1e5f4d7b35808d842002c4b 100755 (executable)
@@ -1,7 +1,7 @@
-#!/sbin/runscript
-# Copyright 1999-2014 Gentoo Foundation
+#!/sbin/openrc-run
+# Copyright 1999-2016 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
-# $Header: /var/cvsroot/gentoo-x86/dev-db/mysql-init-scripts/files/init.d-2.0,v 1.3 2014/09/23 01:23:27 grknight Exp $
+# $Id$
 
 extra_commands="checkconfig"
 
@@ -72,7 +72,7 @@ start() {
        if [ ! -d "${datadir}"/mysql ] ; then
                # find which package is installed to report an error
                local EROOT=$(portageq envvar EROOT)
-               local DBPKG_P=$(portageq match ${EROOT} $(portageq expand_virtual ${EROOT} virtual/mysql))
+               local DBPKG_P=$(portageq match ${EROOT} $(portageq expand_virtual ${EROOT} virtual/mysql | head -n1))
                if [ -z ${DBPKG_P} ] ; then
                        eerror "You don't appear to have a server package installed yet."
                else
diff --git a/init.d/mysql-s6 b/init.d/mysql-s6
new file mode 100755 (executable)
index 0000000..573ffbc
--- /dev/null
@@ -0,0 +1,129 @@
+#!/sbin/openrc-run
+# Copyright 1999-2016 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Id$
+
+depend() {
+       use net.lo
+       # localmount needed for $basedir
+       need localmount s6-svscan
+}
+
+get_config() {
+       my_print_defaults --config-file="$1" mysqld |
+       sed -n -e "s/^--$2=//p"
+}
+
+mysql_svcname() {
+       local ebextra=
+       case "${svc_name}" in
+               mysql*) ;;
+               *) ebextra=" (mysql)" ;;
+       esac
+       echo "${svc_name}${ebextra}"
+}
+
+extra_commands="checkconfig"
+supervisor=s6
+name=$(mysql_svcname)
+s6_service_timeout_stop="$((1000*${STOP_TIMEOUT:-120}))"
+#s6_svwait_options_start="-U -t $((1000*${STARTUP_EARLY_TIMEOUT:-1000}))"
+svc_name=${RC_SVCNAME%-s6}
+s6_service_path=/var/svc.d/${svc_name}
+
+start_pre() {
+       # Check the config or die
+       checkconfig || return 1
+
+       MY_CNF="${MY_CNF:-/etc/${svc_name}/my.cnf}"
+
+       if [ ! -r "${MY_CNF}" ] ; then
+               eerror "Cannot read the configuration file \`${MY_CNF}'"
+               return 1
+       fi
+
+       # tail -n1 is critical as these we only want the last instance of the option
+       local basedir=$(get_config "${MY_CNF}" basedir | tail -n1)
+       local datadir=$(get_config "${MY_CNF}" datadir | tail -n1)
+       local pidfile=$(get_config "${MY_CNF}" pid-file | tail -n1)
+       local socket=$(get_config "${MY_CNF}" socket | tail -n1)
+       local chroot=$(get_config "${MY_CNF}" chroot | tail -n1)
+
+       if [ -n "${chroot}" ] ; then
+               socket="${chroot}/${socket}"
+               pidfile="${chroot}/${pidfile}"
+       fi
+
+       if [ ! -d "${datadir}" ] ; then
+               eerror "MySQL datadir \`${datadir}' is empty or invalid"
+               eerror "Please check your config file \`${MY_CNF}'"
+               return 1
+       fi
+
+       if [ ! -d "${datadir}"/mysql ] ; then
+               # find which package is installed to report an error
+               local EROOT=$(portageq envvar EROOT)
+               local DBPKG_P=$(portageq match ${EROOT} $(portageq expand_virtual ${EROOT} virtual/mysql | head -n1))
+               if [ -z ${DBPKG_P} ] ; then
+                       eerror "You don't appear to have a server package installed yet."
+               else
+                       eerror "You don't appear to have the mysql database installed yet."
+                       eerror "Please run \`emerge --config =${DBPKG_P}\` to have this done..."
+               fi
+               return 1
+       fi
+
+       local piddir="${pidfile%/*}"
+       checkpath -d --owner mysql:mysql --mode 0755 "$piddir"
+       rc=$?
+       if [ $rc -ne 0 ]; then
+               eerror "Directory $piddir for pidfile does not exist and cannot be created"
+               return 1
+       fi
+
+       # Prepare env files to source
+       mkdir -p "/var/svc.d/${svc_name}"
+       echo "MY_CNF=\"${MY_CNF}\"" > "/var/svc.d/${svc_name}/env"
+       echo "MY_ARGS=\"${MY_ARGS}\"" >> "/var/svc.d/${svc_name}/env"
+       echo "basedir=\"${basedir}\"" >> "/var/svc.d/${svc_name}/env"
+       mkdir -p "/var/svc.d/${svc_name}/log"
+       echo "SVCNAME=\"${svc_name}\"" > "/var/svc.d/${svc_name}/log/env"
+       echo "S6_LOG_OPTIONS=\"${S6_LOG_OPTIONS}\"" > "/var/svc.d/${svc_name}/log/env"
+}
+
+start_post() {
+       local socket=$(get_config "${MY_CNF}" socket | tail -n1)
+       local chroot=$(get_config "${MY_CNF}" chroot | tail -n1)
+       local startup_timeout=${STARTUP_TIMEOUT:-900}
+
+       if [ -n "${chroot}" ] ; then
+               socket="${chroot}/${socket}"
+       fi
+       ewaitfile ${startup_timeout} "${socket}"
+}
+
+checkconfig() {
+       local my_cnf="${MY_CNF:-/etc/${svc_name}/my.cnf}"
+       local basedir=$(get_config "${my_cnf}" basedir | tail -n1)
+       local svc_name=$(mysql_svcname)
+       ebegin "Checking mysqld configuration for ${svc_name}"
+
+       if [ ${RC_CMD} = "checkconfig" ] ; then
+               # We are calling checkconfig specifically.  Print warnings regardless.
+               "${basedir}"/sbin/mysqld --defaults-file="${my_cnf}" --help --verbose > /dev/null
+       else
+               # Suppress output to check the return value
+               "${basedir}"/sbin/mysqld --defaults-file="${my_cnf}" --help --verbose > /dev/null 2>&1
+
+               # If the above command does not return 0,
+               # then there is an error to echo to the user
+               if [ $? -ne 0 ] ; then
+                       "${basedir}"/sbin/mysqld --defaults-file="${my_cnf}" --help --verbose > /dev/null
+               fi
+       fi
+
+       eend $? "${svc_name} config check failed"
+}
+
+# vim: filetype=gentoo-init-d sw=2 ts=2 sts=2 noet:
+
index 3399e30df5385980cf4832c37d463f294bb08152..2367d938c0456ce0cb9d06afccbe60d5feb8ad02 100644 (file)
@@ -1,6 +1,6 @@
 # Copyright 1999-2011 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
-# $Header: /var/cvsroot/gentoo-x86/dev-db/mysql-init-scripts/files/logrotate.mysql,v 1.2 2011/01/13 20:06:06 robbat2 Exp $
+# $Id$
 
 /var/log/mysql/mysql.err /var/log/mysql/mysql.log /var/log/mysql/mysqld.err {
 monthly