]> Frank Brehm's Git Trees - config/berta/etc.git/commitdiff
committing changes in /etc after emerge run
authorFrank Brehm <frank@brehm-online.com>
Tue, 21 Mar 2017 13:34:06 +0000 (14:34 +0100)
committerFrank Brehm <frank@brehm-online.com>
Tue, 21 Mar 2017 13:34:06 +0000 (14:34 +0100)
Package changes:
+dev-db/mysql-init-scripts-2.1-r1

.etckeeper
conf.d/mysql [new file with mode: 0644]
conf.d/mysql-s6 [new file with mode: 0644]
init.d/mysql [new file with mode: 0755]
init.d/mysql-s6 [new file with mode: 0755]
logrotate.d/mysql [new file with mode: 0644]

index 9c8669ed42f737a5a784ec67b13fd29197491054..3679ac54bedd97742edad94130e31837760ba58d 100755 (executable)
@@ -132,6 +132,8 @@ maybe chmod 0644 'conf.d/mit-krb5kadmind'
 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/net-online'
 maybe chmod 0644 'conf.d/netmount'
 maybe chmod 0644 'conf.d/pciparm'
@@ -451,6 +453,8 @@ maybe chmod 0755 'init.d/mit-krb5kpropd'
 maybe chmod 0755 'init.d/modules'
 maybe chmod 0755 'init.d/modules-load'
 maybe chmod 0755 'init.d/mount-ro'
+maybe chmod 0755 'init.d/mysql'
+maybe chmod 0755 'init.d/mysql-s6'
 maybe chmod 0755 'init.d/net-online'
 maybe chmod 0755 'init.d/net.lo'
 maybe chmod 0755 'init.d/netmount'
@@ -544,6 +548,7 @@ maybe chmod 0755 'logrotate.d'
 maybe chmod 0644 'logrotate.d/.keep_app-admin_logrotate-0'
 maybe chmod 0644 'logrotate.d/apache2'
 maybe chmod 0644 'logrotate.d/elog-save-summary'
+maybe chmod 0644 'logrotate.d/mysql'
 maybe chmod 0644 'logrotate.d/openrc'
 maybe chmod 0644 'logrotate.d/puppetdb'
 maybe chmod 0644 'logrotate.d/rsyncd'
diff --git a/conf.d/mysql b/conf.d/mysql
new file mode 100644 (file)
index 0000000..cecb9a9
--- /dev/null
@@ -0,0 +1,78 @@
+# Copyright 1999-2014 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+
+# 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:
diff --git a/conf.d/mysql-s6 b/conf.d/mysql-s6
new file mode 100644 (file)
index 0000000..cecb9a9
--- /dev/null
@@ -0,0 +1,78 @@
+# Copyright 1999-2014 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+
+# 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:
diff --git a/init.d/mysql b/init.d/mysql
new file mode 100755 (executable)
index 0000000..ac94a9d
--- /dev/null
@@ -0,0 +1,159 @@
+#!/sbin/openrc-run
+# Copyright 1999-2016 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+
+extra_commands="checkconfig"
+
+depend() {
+       use net.lo
+       # localmount needed for $basedir
+       need localmount
+}
+
+get_config() {
+       my_print_defaults --config-file="$1" mysqld |
+       sed -n -e "s/^--$2=//p"
+}
+
+mysql_svcname() {
+       local ebextra=
+       case "${SVCNAME}" in
+               mysql*) ;;
+               *) ebextra=" (mysql)" ;;
+       esac
+       echo "${SVCNAME}${ebextra}"
+}
+
+start() {
+       # Check for old conf.d variables that mean migration was not yet done.
+       set | egrep -sq '^(mysql_slot_|MYSQL_BLOG_PID_FILE|STOPTIMEOUT)'
+       rc=$?
+       # Yes, MYSQL_INIT_I_KNOW_WHAT_I_AM_DOING is a hidden variable.
+       # It does have a use in testing, as it is possible to build a config file
+       # that works with both the old and new init scripts simulateously.
+       if [ "${rc}" = 0 -a -z "${MYSQL_INIT_I_KNOW_WHAT_I_AM_DOING}" ]; then
+               eerror "You have not updated your conf.d for the new mysql-init-scripts-2 revamp."
+               eerror "Not proceeding because it may be dangerous."
+               return 1
+       fi
+
+       # Check the config or die
+       checkconfig || return 1
+
+       # Now we can startup
+       ebegin "Starting $(mysql_svcname)"
+
+       MY_CNF="${MY_CNF:-/etc/${SVCNAME}/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
+
+       local startup_timeout=${STARTUP_TIMEOUT:-900}
+       local startup_early_timeout=${STARTUP_EARLY_TIMEOUT:-1000}
+       local tmpnice="${NICE:+"--nicelevel "}${NICE}"
+       local tmpionice="${IONICE:+"--ionice "}${IONICE}"
+       start-stop-daemon \
+               ${DEBUG:+"--verbose"} \
+               --start \
+               --exec "${basedir}"/sbin/mysqld \
+               --pidfile "${pidfile}" \
+               --background \
+               --wait ${startup_early_timeout} \
+               ${tmpnice} \
+               ${tmpionice} \
+               -- --defaults-file="${MY_CNF}" ${MY_ARGS}
+       local ret=$?
+       if [ ${ret} -ne 0 ] ; then
+               eend ${ret}
+               return ${ret}
+       fi
+
+       ewaitfile ${startup_timeout} "${socket}"
+       eend $? || return 1
+
+       save_options pidfile "${pidfile}"
+       save_options basedir "${basedir}"
+}
+
+stop() {
+       ebegin "Stopping $(mysql_svcname)"
+
+       local pidfile="$(get_options pidfile)"
+       local basedir="$(get_options basedir)"
+       local stop_timeout=${STOP_TIMEOUT:-120}
+
+       start-stop-daemon \
+               ${DEBUG:+"--verbose"} \
+               --stop \
+               --exec "${basedir}"/sbin/mysqld \
+               --pidfile "${pidfile}" \
+               --retry ${stop_timeout}
+       eend $?
+}
+
+checkconfig() {
+       local my_cnf="${MY_CNF:-/etc/${SVCNAME}/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:
+
diff --git a/init.d/mysql-s6 b/init.d/mysql-s6
new file mode 100755 (executable)
index 0000000..74ff34b
--- /dev/null
@@ -0,0 +1,128 @@
+#!/sbin/openrc-run
+# Copyright 1999-2016 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+
+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:
+
diff --git a/logrotate.d/mysql b/logrotate.d/mysql
new file mode 100644 (file)
index 0000000..afb20c6
--- /dev/null
@@ -0,0 +1,14 @@
+# Copyright 1999-2011 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+
+/var/log/mysql/mysql.err /var/log/mysql/mysql.log /var/log/mysql/mysqld.err {
+monthly
+create 660 mysql mysql
+notifempty
+size 5M
+sharedscripts
+missingok
+postrotate
+[ -f /var/run/mysqld/mysqld.pid ] && /bin/kill -HUP `cat /var/run/mysqld/mysqld.pid`
+endscript
+}