diff options
author | Robin H. Johnson <robbat2@gentoo.org> | 2011-01-13 20:06:06 +0000 |
---|---|---|
committer | Robin H. Johnson <robbat2@gentoo.org> | 2011-01-13 20:06:06 +0000 |
commit | 2cbdf92b21fe25b148408f5da0d8aa7c0d089081 (patch) | |
tree | 0c773e3005e87ba91ab695a4929ec665998ef422 /dev-db/mysql-init-scripts | |
parent | stable ppc, bug 351480 (diff) | |
download | historical-2cbdf92b21fe25b148408f5da0d8aa7c0d089081.tar.gz historical-2cbdf92b21fe25b148408f5da0d8aa7c0d089081.tar.bz2 historical-2cbdf92b21fe25b148408f5da0d8aa7c0d089081.zip |
Revamp the MySQL init scripts. Please note if you are using multiple internal "slots", that you should use multiple init files now. Bug #215535: ensure directory for pidfile exists. Bug #253670: Fix manpage reference. Bug #172870: Fix hup errors for non-running mysqld in logrotate script. Bug #171753: better multiple server support.
Package-Manager: portage-2.2.0_alpha14/cvs/Linux x86_64
Diffstat (limited to 'dev-db/mysql-init-scripts')
-rw-r--r-- | dev-db/mysql-init-scripts/ChangeLog | 15 | ||||
-rw-r--r-- | dev-db/mysql-init-scripts/Manifest | 7 | ||||
-rw-r--r-- | dev-db/mysql-init-scripts/files/logrotate.mysql | 6 | ||||
-rw-r--r-- | dev-db/mysql-init-scripts/files/mysql-5.1.53-conf.d | 75 | ||||
-rw-r--r-- | dev-db/mysql-init-scripts/files/mysql-5.1.53-init.d | 121 | ||||
-rw-r--r-- | dev-db/mysql-init-scripts/mysql-init-scripts-2.0_pre1.ebuild | 54 |
6 files changed, 271 insertions, 7 deletions
diff --git a/dev-db/mysql-init-scripts/ChangeLog b/dev-db/mysql-init-scripts/ChangeLog index 7cdd01b394c7..b0b0a9a8bf7b 100644 --- a/dev-db/mysql-init-scripts/ChangeLog +++ b/dev-db/mysql-init-scripts/ChangeLog @@ -1,6 +1,17 @@ # ChangeLog for dev-db/mysql-init-scripts -# Copyright 1999-2010 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/dev-db/mysql-init-scripts/ChangeLog,v 1.4 2010/10/19 05:53:42 leio Exp $ +# Copyright 1999-2011 Gentoo Foundation; Distributed under the GPL v2 +# $Header: /var/cvsroot/gentoo-x86/dev-db/mysql-init-scripts/ChangeLog,v 1.5 2011/01/13 20:06:06 robbat2 Exp $ + +*mysql-init-scripts-2.0_pre1 (13 Jan 2011) + + 13 Jan 2011; Robin H. Johnson <robbat2@gentoo.org> + +mysql-init-scripts-2.0_pre1.ebuild, +files/mysql-5.1.53-conf.d, + +files/mysql-5.1.53-init.d, files/logrotate.mysql: + Revamp the MySQL init scripts. Please note if you are using multiple internal + "slots", that you should use multiple init files now. Bug #215535: ensure + directory for pidfile exists. Bug #253670: Fix manpage reference. Bug + #172870: Fix hup errors for non-running mysqld in logrotate script. Bug + #171753: better multiple server support. 19 Oct 2010; Mart Raudsepp <leio@gentoo.org> mysql-init-scripts-1.2.ebuild: diff --git a/dev-db/mysql-init-scripts/Manifest b/dev-db/mysql-init-scripts/Manifest index 0150b4c53e54..e026f8757bd1 100644 --- a/dev-db/mysql-init-scripts/Manifest +++ b/dev-db/mysql-init-scripts/Manifest @@ -1,8 +1,11 @@ -AUX logrotate.mysql 453 RMD160 d1fd681cea5073b662d521c7473eb121d15f50e4 SHA1 1e52a9df3a42c8705f4c22bb6758674fdfb04135 SHA256 d873c55e0fe4ba545fc40f6724a9415db9e9a2da3e80c00b3443b7ab73bc7a8b +AUX logrotate.mysql 491 RMD160 4e34d1724c9970a230cbd4b0908adc869abe70e7 SHA1 03db73f8ca1a46b935c67a5ded076f5813012ded SHA256 a82f4497594e03cce55dce1f008206bafb85e3e4c6fc1f43c7a90d57be5f7aa1 +AUX mysql-5.1.53-conf.d 2885 RMD160 def25af6a0b54cb863997954d614ec89ac2d0e41 SHA1 69549baff600bc2c71a2f2a98e8d4c66bf3f45cb SHA256 72a4fcf9480b2072af546da81975c1b7fcb6d7ead93b0de8d9a6e415cddbd457 +AUX mysql-5.1.53-init.d 3354 RMD160 1526da4c3d8a2fa00579605af020241c8cb53ff2 SHA1 4badb6f71ae39964366c9e76ef6f7e84965d4d67 SHA256 6abb1aeb5b82f8911aca59daf5dfbe199bc4d602842bf2ebec20830ed2869203 AUX mysql.conf.d 3273 RMD160 a2661c832c1091b2d05e599fc58cce6f686c7f31 SHA1 64e9bb80099bf6e14a07764fcb69bb02682aee0b SHA256 ee049781a3885305ce9999371198ff54f97fee4d2ad0814ba3aa3a03abc2724c AUX mysql.rc6 10661 RMD160 0a0a1d84febd750a62cf331841b1bb765ccdae87 SHA1 35ceea9fc1e2e58f742d396bdcd1a17c7ad9c4f1 SHA256 039e54883fc42d3b9ddfdfca46bb906420a7d47156f5b1392292f4aa3f712149 AUX mysqlmanager.conf.d 1009 RMD160 b443dc0cd1cb7fb054fe7229a52b8d093e634652 SHA1 0d82531df24ba4f0d957176b6fa0076a1cae0356 SHA256 35353f585cc9d3f97bbcfe77224d183e0fedcf4134377b8bff4c278462577cc7 AUX mysqlmanager.rc6 6632 RMD160 17fd2bdfcad0ca6e32e6ee91e1e0db7ce3263fef SHA1 18c6fc53a65a4f92dacd229585199b94f1c888cc SHA256 0d37cb3199a2752604a105d54340a61b9ee062e6c1d977a863628b694d93e96d EBUILD mysql-init-scripts-1.2.ebuild 766 RMD160 8cadfcc8f2b5af9914e2ec8eb3e8f64e8e4c151e SHA1 b9f43b8c5fb21de47e5cb6eb6ddf4af0d68bf8b7 SHA256 c052738cd94042676a6c082cfa2544acf3663c020e7705c5712a3c1254cbf762 -MISC ChangeLog 749 RMD160 44f3a379bc6a772724ec16834cab8877458ba02d SHA1 83abe40b310da1b4bbd5bf321dc82132b7701228 SHA256 59f4c9870b88be4f688e79c5c2705bf5cb843848705fffc720f953b70687b1c5 +EBUILD mysql-init-scripts-2.0_pre1.ebuild 1884 RMD160 ed69a11c61076ec933963fadbc6a170420dd1b33 SHA1 94654b12c3db9fcd7ecce8b18e17fa19a723381e SHA256 a51ec29339c3520b2b123110dea7e7f2514b2644b3637ed13b56ac18ea312467 +MISC ChangeLog 1315 RMD160 839d917a7ad289cc3baa2a38dd57727405a8921c SHA1 16cb82cb16aa3fb321dd9a5289c3609167814dbb SHA256 54a15d8c94852a878ebb41b90dc4ec5492e97498f78237168787abc3965600ed MISC metadata.xml 159 RMD160 a50a94af7706288c46f81d6c3da9b5f888050eee SHA1 5eb253a678d6faa0f1c6b3c5720a804ed8923566 SHA256 5cfd5aa0e8104c0326b5f4c9205a6449a94e0f6f6abfd2626f1e7a8fe77b98b7 diff --git a/dev-db/mysql-init-scripts/files/logrotate.mysql b/dev-db/mysql-init-scripts/files/logrotate.mysql index 90024705a422..3399e30df538 100644 --- a/dev-db/mysql-init-scripts/files/logrotate.mysql +++ b/dev-db/mysql-init-scripts/files/logrotate.mysql @@ -1,6 +1,6 @@ -# Copyright 1999-2006 Gentoo Foundation +# 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.1 2007/01/12 16:54:20 chtekk Exp $ +# $Header: /var/cvsroot/gentoo-x86/dev-db/mysql-init-scripts/files/logrotate.mysql,v 1.2 2011/01/13 20:06:06 robbat2 Exp $ /var/log/mysql/mysql.err /var/log/mysql/mysql.log /var/log/mysql/mysqld.err { monthly @@ -10,6 +10,6 @@ size 5M sharedscripts missingok postrotate -/bin/kill -HUP `cat /var/run/mysqld/mysqld.pid` +[ -f /var/run/mysqld/mysqld.pid ] && /bin/kill -HUP `cat /var/run/mysqld/mysqld.pid` endscript } diff --git a/dev-db/mysql-init-scripts/files/mysql-5.1.53-conf.d b/dev-db/mysql-init-scripts/files/mysql-5.1.53-conf.d new file mode 100644 index 000000000000..a53440b3bcce --- /dev/null +++ b/dev-db/mysql-init-scripts/files/mysql-5.1.53-conf.d @@ -0,0 +1,75 @@ +# 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/mysql-5.1.53-conf.d,v 1.1 2011/01/13 20:06:06 robbat2 Exp $ + +# 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" + +# vim: ft=gentoo-conf-d et ts=4 sw=4: diff --git a/dev-db/mysql-init-scripts/files/mysql-5.1.53-init.d b/dev-db/mysql-init-scripts/files/mysql-5.1.53-init.d new file mode 100644 index 000000000000..d824b6ae650e --- /dev/null +++ b/dev-db/mysql-init-scripts/files/mysql-5.1.53-init.d @@ -0,0 +1,121 @@ +#!/sbin/runscript +# 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/mysql-5.1.53-init.d,v 1.1 2011/01/13 20:06:06 robbat2 Exp $ + +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. + local varlist="${!mysql_slot_*} ${!MYSQL_BLOG_PID_FILE*} ${!STOPTIMEOUT*}" + varlist="${varlist// /}" + # 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 [ -n "${varlist}" -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 + + # 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) + + 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 + eerror "You don't appear to have the mysql database installed yet." + eerror "Please run /usr/bin/mysql_install_db to have this done..." + return 1 + fi + + local piddir="${pidfile%/*}" + if [ ! -d "$piddir" ] ; then + mkdir "$piddir" && \ + chown mysql "$piddir" + rc=$? + if [ $rc -ne 0 ]; then + eerror "Directory $piddir for pidfile does not exist and cannot be created" + return 1 + fi + 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 $? +} +# vim: filetype=gentoo-init-d sw=2 ts=2 sts=2 noet: + diff --git a/dev-db/mysql-init-scripts/mysql-init-scripts-2.0_pre1.ebuild b/dev-db/mysql-init-scripts/mysql-init-scripts-2.0_pre1.ebuild new file mode 100644 index 000000000000..5dbda8d057cd --- /dev/null +++ b/dev-db/mysql-init-scripts/mysql-init-scripts-2.0_pre1.ebuild @@ -0,0 +1,54 @@ +# 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/mysql-init-scripts-2.0_pre1.ebuild,v 1.1 2011/01/13 20:06:06 robbat2 Exp $ + +DESCRIPTION="Gentoo MySQL init scripts." +HOMEPAGE="http://www.gentoo.org/" +SRC_URI="" + +LICENSE="GPL-2" +SLOT="0" +KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~mips ~ppc ~ppc64 ~s390 ~sh ~sparc ~x86 ~sparc-fbsd ~x86-fbsd" +IUSE="" + +DEPEND="" +# This _will_ break with MySQL 5.0, 4.x, 3.x +# It also NEEDS openrc for the save_options/get_options builtins. +RDEPEND="!<dev-db/mysql-5.1 + sys-apps/openrc" + +src_install() { + newconfd "${FILESDIR}/mysql-5.1.53-conf.d" "mysql" + newinitd "${FILESDIR}/mysql-5.1.53-init.d" "mysql" + + insinto /etc/logrotate.d + newins "${FILESDIR}/logrotate.mysql" "mysql" +} + +pkg_postinst() { + grep -sq mysql_slot "${ROOT}"/etc/conf.d/mysql + old_conf_present=$? + grep -sq mysql_slot "${ROOT}"/etc/init.d/mysql + old_init_present=$? + + egrep -sq 'MY_CNF|MY_ARGS|(STARTUP|STOP)_TIMEOUT' "${ROOT}"/etc/conf.d/mysql + new_conf_present=$? + grep -sq 'MY_CNF|MY_ARGS|(STARTUP|STOP)_TIMEOUT' "${ROOT}"/etc/init.d/mysql + new_init_present=$? + + einfo "Please note if you are using multiple internal 'slots' in the old" + einfo "conf.d fille, that you should use multiple init files now." + + # new scripts present + if [ $new_conf_present -eq 0 -a $new_init_present -eq 0 -a + $old_conf_present -eq 1 -a $old_init_present -eq 1 ]; then + : + elif [ $old_conf_present -eq 0 -a $old_init_present -eq 0 -a + $new_conf_present -eq 1 -a $new_init_present -eq 1 ]; then + ewarn "Old /etc/init.d/mysql and /etc/conf.d/mysql still present!" + ewarn "Update both of those files to the new versions!" + else + eerror "DANGER, mixed update of /etc/init.d/mysql and /etc/conf.d/mysql" + eerror "detected! You must update BOTH to the new versions" + fi +} |