Forráskód Böngészése

add a package for MySQL 5.1 (beta)

Ralf S. Engelschall 19 éve
szülő
commit
848465a7df
5 módosított fájl, 600 hozzáadás és 0 törlés
  1. 89 0
      mysql51/my.cnf
  2. 8 0
      mysql51/my.pwd
  3. 97 0
      mysql51/mysql51.patch
  4. 311 0
      mysql51/mysql51.spec
  5. 95 0
      mysql51/rc.mysql

+ 89 - 0
mysql51/my.cnf

@@ -0,0 +1,89 @@
+##
+##  my.cnf -- MySQL configuration
+##
+
+[client]
+socket       = @l_prefix@/var/mysql/mysql.sock
+port         = 3306
+
+[mysqld]
+#
+#   Network settings
+#
+
+bind-address = 127.0.0.1
+port         = 3306
+
+#   Unix domain socket only, disables TCP/IP
+#skip-networking
+
+#
+#   Log file settings
+#
+
+#   log file destinations (must be in sync with settings in rc.conf)
+log          = @l_prefix@/var/mysql/common.log
+log-update   = @l_prefix@/var/mysql/update.log
+#   binary log (use instead of log-update, server-id must be unique for
+#   replication)
+#log-bin      = @l_prefix@/var/mysql/binary.log
+#server-id    = 1
+
+#
+#   Performance settings
+#
+
+#   most important tuning parameters for mysqld
+set-variable = key_buffer_size=64M
+set-variable = table_cache=256
+
+#   less important tuning parameters (change if special problems occur)
+set-variable = join_buffer_size=1M
+set-variable = max_connections=1000
+set-variable = max_connect_errors=10
+set-variable = max_delayed_threads=20
+set-variable = max_heap_table_size=16777216
+set-variable = max_sort_length=1024
+set-variable = max_user_connections=1000
+set-variable = record_buffer=131072
+set-variable = sort_buffer=4M
+set-variable = key_buffer=1M
+set-variable = tmp_table_size=32M
+
+#   permanent query caching
+set-variable = query_cache_type=1
+#   maximum caching size of an individual query
+set-variable = query_cache_limit=1M
+#   maximum query cache size
+set-variable = query_cache_size=32M
+
+#   minimum chars for full-text search (FTS) index
+#ft_min_word_len=3
+
+#   Berkeley DB
+set-variable = bdb_cache_size=@l_mysql_bdb_cache_size@
+set-variable = bdb_log_buffer_size=@l_mysql_bdb_log_buffer_size@
+set-variable = bdb_max_lock=@l_mysql_bdb_max_lock@
+
+#   Innobase DB
+#set-variable = innodb_buffer_pool_size=70M
+#set-variable = innodb_additional_mem_pool_size=2M
+#set-variable = innodb_log_files_in_group=3
+#set-variable = innodb_log_file_size=20M
+#set-variable = innodb_log_buffer_size=8M
+#set-variable = innodb_lock_wait_timeout=50
+
+#
+#   Miscellaneous
+#
+
+#   directory for temporary tables
+tmpdir=@l_prefix@/var/mysql/tmp
+
+[mysqld_safe]
+datadir      = @l_prefix@/var/mysql
+socket       = @l_prefix@/var/mysql/mysql.sock
+set-variable = pid_file=@l_prefix@/var/mysql/mysqld.pid
+user         = @l_rusr@
+basedir      = @l_prefix@
+

+ 8 - 0
mysql51/my.pwd

@@ -0,0 +1,8 @@
+##
+##  my.pwd -- MySQL configuration (administrator password only)
+##
+
+[mysqladmin]
+user     = root
+password = 
+

+ 97 - 0
mysql51/mysql51.patch

@@ -0,0 +1,97 @@
+Index: include/Makefile.in
+--- include/Makefile.in.orig	2006-02-27 22:26:47 +0100
++++ include/Makefile.in	2006-03-11 13:38:18 +0100
+@@ -350,14 +350,14 @@
+ 			errmsg.h my_global.h my_net.h my_alloc.h \
+ 			my_getopt.h sslopt-longopts.h my_dir.h typelib.h \
+ 			sslopt-vars.h sslopt-case.h sql_common.h keycache.h \
+-			mysql_time.h mysql/plugin.h $(BUILT_SOURCES)
++			mysql_time.h mysql/plugin.h my_aes.h rijndael.h sha1.h $(BUILT_SOURCES)
+ 
+ noinst_HEADERS = config-win.h config-os2.h config-netware.h \
+ 			heap.h my_bitmap.h my_uctype.h \
+ 			myisam.h myisampack.h myisammrg.h ft_global.h\
+ 			mysys_err.h my_base.h help_start.h help_end.h \
+-			my_nosys.h my_alarm.h queues.h rijndael.h sha1.h \
+-			my_aes.h my_tree.h my_trie.h hash.h thr_alarm.h \
++			my_nosys.h my_alarm.h queues.h \
++			my_tree.h my_trie.h hash.h thr_alarm.h \
+ 			thr_lock.h t_ctype.h violite.h md5.h base64.h \
+ 			mysql_version.h.in my_handler.h my_time.h decimal.h \
+ 			my_vle.h my_user.h
+Index: include/my_global.h
+--- include/my_global.h.orig	2006-02-27 22:24:47 +0100
++++ include/my_global.h	2006-03-11 13:35:05 +0100
+@@ -819,9 +819,8 @@
+ #define FLT_MAX		((float)3.40282346638528860e+38)
+ #endif
+ 
+-#if !defined(HAVE_ISINF) && !defined(isinf)
++#undef isinf
+ #define isinf(X)    0
+-#endif
+ 
+ /* Define missing math constants. */
+ #ifndef M_PI
+Index: mysys/default.c
+--- mysys/default.c.orig	2006-02-27 22:24:56 +0100
++++ mysys/default.c	2006-03-11 13:35:05 +0100
+@@ -1001,7 +1001,7 @@
+   if ((env= getenv("ETC")))
+     *ptr++= env;
+ #endif
+-  *ptr++= "/etc/";
++  *ptr++= "@l_prefix@/etc/mysql/";
+ #endif
+   if ((env= getenv(STRINGIFY_ARG(DEFAULT_HOME_ENV))))
+     *ptr++= env;
+Index: scripts/mysql_config.sh
+--- scripts/mysql_config.sh.orig	2006-02-27 22:24:57 +0100
++++ scripts/mysql_config.sh	2006-03-11 13:35:05 +0100
+@@ -93,11 +93,11 @@
+ 
+ # Create options
+ 
+-libs="$ldflags -L$pkglibdir -lmysqlclient @ZLIB_DEPS@ @NON_THREADED_LIBS@"
++libs="$ldflags -L$pkglibdir -lmysqlclient -lmysys @ZLIB_DEPS@ @NON_THREADED_LIBS@"
+ libs="$libs @openssl_libs@ @STATIC_NSS_FLAGS@"
+ libs=`echo "$libs" | sed -e 's;  \+; ;g' | sed -e 's;^ *;;' | sed -e 's; *\$;;'`
+ 
+-libs_r="$ldflags -L$pkglibdir -lmysqlclient_r @ZLIB_DEPS@ @LIBS@ @openssl_libs@"
++libs_r="$ldflags -L$pkglibdir -lmysqlclient_r -lmysys @ZLIB_DEPS@ @LIBS@ @openssl_libs@"
+ libs_r=`echo "$libs_r" | sed -e 's;  \+; ;g' | sed -e 's;^ *;;' | sed -e 's; *\$;;'`
+ cflags="-I$pkgincludedir @CFLAGS@ " #note: end space!
+ include="-I$pkgincludedir"
+Index: scripts/mysql_create_system_tables.sh
+--- scripts/mysql_create_system_tables.sh.orig	2006-02-27 22:25:28 +0100
++++ scripts/mysql_create_system_tables.sh	2006-03-11 13:40:53 +0100
+@@ -81,9 +81,6 @@
+   c_d="$c_d ) engine=MyISAM"
+   c_d="$c_d CHARACTER SET utf8 COLLATE utf8_bin"
+   c_d="$c_d comment='Database privileges';"
+-  
+-  i_d="INSERT INTO db VALUES ('%','test','','Y','Y','Y','Y','Y','Y','N','Y','Y','Y','Y','Y','Y','Y','Y','N','N','Y','Y');
+-  INSERT INTO db VALUES ('%','test\_%','','Y','Y','Y','Y','Y','Y','N','Y','Y','Y','Y','Y','Y','Y','Y','N','N','Y','Y');"
+ fi
+ 
+ if test ! -f $mdata/host.frm
+@@ -174,17 +171,13 @@
+   then
+     i_u="INSERT INTO user VALUES ('localhost','root','','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','','','','',0,0,0,0);
+     INSERT INTO user VALUES ('$hostname','root','','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','','','','',0,0,0,0);
+-    REPLACE INTO user VALUES ('127.0.0.1','root','','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','','','','',0,0,0,0);
+-    INSERT INTO user (host,user) values ('localhost','');
+-    INSERT INTO user (host,user) values ('$hostname','');"
++    REPLACE INTO user VALUES ('127.0.0.1','root','','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','','','','',0,0,0,0);"
+   else
+     i_u="INSERT INTO user VALUES ('localhost','root','','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','','','','',0,0,0,0);"
+     if test "$windows" = "0"
+     then
+       i_u="$i_u
+-           INSERT INTO user VALUES ('$hostname','root','','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','','','','',0,0,0,0);
+-           INSERT INTO user (host,user) values ('$hostname','');
+-           INSERT INTO user (host,user) values ('localhost','');"
++           INSERT INTO user VALUES ('$hostname','root','','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','','','','',0,0,0,0);"
+     else
+       i_u="$i_u
+ 	   INSERT INTO user VALUES ('localhost','','','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','','','','',0,0,0);"

+ 311 - 0
mysql51/mysql51.spec

@@ -0,0 +1,311 @@
+##
+##  mysql51.spec -- OpenPKG RPM Package Specification
+##  Copyright (c) 2000-2006 OpenPKG Foundation e.V. <http://openpkg.net/>
+##  Copyright (c) 2000-2006 Ralf S. Engelschall <http://engelschall.com/>
+##
+##  Permission to use, copy, modify, and distribute this software for
+##  any purpose with or without fee is hereby granted, provided that
+##  the above copyright notice and this permission notice appear in all
+##  copies.
+##
+##  THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
+##  WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+##  MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+##  IN NO EVENT SHALL THE AUTHORS AND COPYRIGHT HOLDERS AND THEIR
+##  CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+##  SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+##  LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
+##  USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+##  ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+##  OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
+##  OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+##  SUCH DAMAGE.
+##
+
+#   package version
+%define       V_major   5.1
+%define       V_minor   7
+%define       V_mysql   %{V_major}.%{V_minor}-beta
+%define       V_opkg    %{V_major}.%{V_minor}
+
+#   package information
+Name:         mysql51
+Summary:      Fast Relational Database Management System
+URL:          http://www.mysql.com/products/mysql/
+Vendor:       MySQL AB
+Packager:     OpenPKG
+Distribution: OpenPKG
+Class:        EVAL
+Group:        Database
+License:      GPL
+Version:      %{V_opkg}
+Release:      20060311
+
+#   package options
+%option       with_server    yes
+%option       with_bdb       yes
+%option       with_innodb    no
+%option       with_ssl       no
+%option       with_ndb       no
+%option       with_embedded  no
+
+#   list of sources
+Source0:      http://sunsite.informatik.rwth-aachen.de/mysql/Downloads/MySQL-%{V_major}/mysql-%{V_mysql}.tar.gz
+Source1:      my.cnf
+Source2:      my.pwd
+Source3:      rc.mysql
+Patch0:       mysql51.patch
+
+#   build information
+Prefix:       %{l_prefix}
+BuildRoot:    %{l_buildroot}
+BuildPreReq:  OpenPKG, openpkg >= 20040130, perl, gcc, make
+PreReq:       OpenPKG, openpkg >= 20040130, perl
+BuildPreReq:  zlib, readline, ncurses
+PreReq:       zlib, readline, ncurses
+%if "%{with_ssl}" == "yes"
+BuildPreReq:  openssl
+PreReq:       openssl
+%endif
+AutoReq:      no
+AutoReqProv:  no
+Provides:     mysql = %{version}-%{release}
+
+%description
+    MySQL is a multi-user Relational Database Management System (RDBMS),
+    which is controlled through Structured Query Language (SQL) operating in
+    full multi-threading mode. The main goals of MySQL are speed, robustness
+    and ease of use. MySQL was originally developed because of the need for
+    a SQL server that could handle very big databases with magnitude higher
+    speed than what any database vendor could offer.
+
+%track
+    prog mysql51 = {
+        version   = %{V_mysql}
+        url       = http://dev.mysql.com/downloads/mysql/%{V_major}.html
+        regex     = mysql-(__VER__)\.tar\.gz
+    }
+
+%prep
+    %setup -q -n mysql-%{V_mysql}
+    %patch -p0
+
+%build
+    #   patch file search path
+    %{l_shtool} subst %{l_value -s -a} \
+        mysys/default.c
+
+    #   determine additional configure options
+    case "%{l_platform -t}" in
+        *-freebsd* ) opt="--with-client-ldflags=-static --with-mysqld-ldflags=-static" ;;
+        *-linux*   ) opt="--with-client-ldflags=-static --with-mysqld-ldflags=-static" ;;
+        *-sunos*   ) opt="--with-client-ldflags=-static --with-mysqld-ldflags=-static" ;;
+    esac
+
+    #   configure source tree
+    CC="%{l_cc}" \
+    CXX="%{l_cxx}" \
+    CFLAGS="%{l_cflags -O}" \
+    CXXFLAGS="%{l_cxxflags -O}" \
+    CPPFLAGS="%{l_cppflags ncurses}" \
+    LDFLAGS="-L`pwd`/bdb/build_unix -L`pwd`/libmysql %{l_ldflags}" \
+    ./configure \
+        --prefix=%{l_prefix} \
+        --sysconfdir=%{l_prefix}/etc/mysql \
+        --localstatedir=%{l_prefix}/var/mysql \
+        --libexecdir=%{l_prefix}/libexec/mysql \
+        --with-unix-socket-path=%{l_prefix}/var/mysql/mysql.sock \
+        --with-mysqld-user=%{l_musr} \
+        --enable-thread-safe-client \
+        --with-comment="%{l_openpkg_release}" \
+%if "%{with_server}" != "yes"
+        --without-server \
+%endif
+%if "%{with_bdb}" == "yes"
+        --with-berkeley-db \
+%endif
+%if "%{with_innodb}" == "no"
+        --without-innodb \
+%endif
+%if "%{with_ssl}" == "yes"
+        --with-openssl \
+        --with-openssl-includes=%{l_prefix}/include \
+        --with-openssl-libs=%{l_prefix}/lib \
+%endif
+%if "%{with_ndb}" == "yes"
+        --with-ndbcluster \
+        --with-ndb-shm \
+%endif
+%if "%{with_embedded}" == "yes"
+        --with-embedded-server \
+%endif
+        --without-readline \
+        --without-libedit \
+        --with-vio \
+        --with-named-z-libs=no \
+        --with-low-memory \
+        --disable-shared \
+        $opt
+
+    #   build source tree
+    %{l_make} %{l_mflags}
+
+%install
+    rm -rf $RPM_BUILD_ROOT
+
+    #   patch init script
+    %{l_shtool} subst %{l_value -s -a} \
+        scripts/mysql_install_db.sh
+
+    #   perform standard installation procedure
+    %{l_make} %{l_mflags} install \
+        AM_MAKEFLAGS="DESTDIR=$RPM_BUILD_ROOT" \
+        DESTDIR=$RPM_BUILD_ROOT
+
+    #   move utility 'replace', msql2mysql is patched for new path
+    mv $RPM_BUILD_ROOT%{l_prefix}/bin/replace \
+       $RPM_BUILD_ROOT%{l_prefix}/libexec/mysql/
+
+    #   strip installation area
+    rm -rf $RPM_BUILD_ROOT%{l_prefix}/mysql-test
+    rm -rf $RPM_BUILD_ROOT%{l_prefix}/sql-bench
+    rm -f  $RPM_BUILD_ROOT%{l_prefix}/info/dir
+    rm -f  $RPM_BUILD_ROOT%{l_prefix}/share/mysql/mysql-%{V_mysql}.spec
+    rm -f  $RPM_BUILD_ROOT%{l_prefix}/share/mysql/binary-configure
+    rm -f  $RPM_BUILD_ROOT%{l_prefix}/bin/make_win_src_distribution
+    rm -f  $RPM_BUILD_ROOT%{l_prefix}/bin/make_win_binary_distribution
+    rm -f  $RPM_BUILD_ROOT%{l_prefix}/bin/comp_err
+    strip  $RPM_BUILD_ROOT%{l_prefix}/bin/* 2>/dev/null || true
+    strip  $RPM_BUILD_ROOT%{l_prefix}/libexec/mysql/* 2>/dev/null || true
+
+    #   determine default parameters
+%if "%{with_bdb}" == "yes"
+    l_mysql_bdb_cache_size=8M
+    l_mysql_bdb_log_buffer_size=32k
+    l_mysql_bdb_max_lock=10000
+%else
+    l_mysql_bdb_cache_size=0
+    l_mysql_bdb_log_buffer_size=0
+    l_mysql_bdb_max_lock=0
+%endif
+%if "%{with_bdb}" == "yes" || "%{with_innodb}" == "yes"
+    l_mysqld=mysqld
+%else
+    l_mysqld=mysqld-max
+%endif
+
+    #   install global configuration
+    %{l_shtool} mkdir -f -p -m 755 $RPM_BUILD_ROOT%{l_prefix}/etc/mysql
+    %{l_shtool} install -c -m 644 %{l_value -s -a} \
+        -e "s;@l_mysql_bdb_cache_size@;${l_mysql_bdb_cache_size};g" \
+        -e "s;@l_mysql_bdb_log_buffer_size@;${l_mysql_bdb_log_buffer_size};g" \
+        -e "s;@l_mysql_bdb_max_lock@;${l_mysql_bdb_max_lock};g" \
+        %{SOURCE my.cnf} \
+        $RPM_BUILD_ROOT%{l_prefix}/etc/mysql/
+    %{l_shtool} install -c -m 600 \
+        %{SOURCE my.pwd} \
+        $RPM_BUILD_ROOT%{l_prefix}/etc/mysql/
+
+    #   install run-command script
+    %{l_shtool} mkdir -f -p -m 755 $RPM_BUILD_ROOT%{l_prefix}/etc/rc.d
+    %{l_shtool} install -c -m 755 %{l_value -s -a} \
+        -e "s;@l_mysqld@;${l_mysqld};g" \
+        %{SOURCE rc.mysql} $RPM_BUILD_ROOT%{l_prefix}/etc/rc.d/
+
+    #   make sure the database directory exists
+    %{l_shtool} mkdir -f -p -m 755 $RPM_BUILD_ROOT%{l_prefix}/var/mysql
+
+    #   directory for temporary tables
+    %{l_shtool} mkdir -f -p -m 700 $RPM_BUILD_ROOT%{l_prefix}/var/mysql/tmp
+
+    #   optional client-only installation
+%if "%{with_server}" != "yes"
+    rm -rf $RPM_BUILD_ROOT%{l_prefix}/libexec/mysql
+    ( cd $RPM_BUILD_ROOT%{l_prefix}/bin
+      for bin in *; do
+          case "$bin" in
+              mysql | mysql_config ) ;;
+              * ) rm -f $bin ;;
+          esac
+      done
+    ) || exit $?
+    ( cd $RPM_BUILD_ROOT%{l_prefix}/man/man1
+      for man in *; do
+          case "$man" in
+              mysql.1 | mysql_config.1 ) ;;
+              * ) rm -f $man ;;
+          esac
+      done
+    ) || exit $?
+%endif
+
+    #   determine the package files
+    %{l_rpmtool} files -v -ofiles -r$RPM_BUILD_ROOT \
+%if "%{with_server}" == "yes"
+        %{l_files_std} \
+        '%config %attr(644,%{l_musr},%{l_mgrp}) %{l_prefix}/etc/mysql/my.cnf' \
+        '%config %attr(600,%{l_susr},%{l_mgrp}) %{l_prefix}/etc/mysql/my.pwd' \
+        '%attr(-,%{l_rusr},%{l_rgrp}) %{l_prefix}/var/mysql' \
+        '%attr(-,%{l_rusr},%{l_rgrp}) %{l_prefix}/var/mysql/tmp'
+%else
+        %{l_files_std}
+%endif
+
+%files -f files
+
+%clean
+    rm -rf $RPM_BUILD_ROOT
+
+%pre
+%if "%{with_server}" == "yes"
+    #   before upgrade, save status and stop service
+    [ $1 -eq 2 ] || exit 0
+    eval `%{l_rc} mysql status 2>/dev/null | tee %{l_tmpfile}`
+    %{l_rc} mysql stop 2>/dev/null
+%endif
+    exit 0
+
+%post
+%if "%{with_server}" == "yes"
+    if [ $1 -eq 1 ]; then
+        #   after install, create initial database
+        $RPM_INSTALL_PREFIX/bin/mysql_install_db \
+            --defaults-file=$RPM_INSTALL_PREFIX/etc/mysql/my.cnf >/dev/null 2>&1
+        chown -R %{l_rusr}:%{l_rgrp} $RPM_INSTALL_PREFIX/var/mysql/*
+        ( echo "An initial MySQL DB was created. The owner of the database"
+          echo "is the DB user 'root'. Its initial password is empty."
+          echo "After starting MySQL with..."
+          echo ""
+          echo "  \$ $RPM_INSTALL_PREFIX/etc/rc mysql start"
+          echo ""
+          echo "...you should change the password as soon as possible with:"
+          echo ""
+          echo "  \$ $RPM_INSTALL_PREFIX/bin/mysqladmin \\ "
+          echo "    -u root password '<new-password>'"
+          echo ""
+          echo "Additionally, because the MySQL package includes automated"
+          echo "maintenance procedures that require administrator access to"
+          echo "the database, you must maintain a (plain text) copy of the"
+          echo "administrator account name and password:"
+          echo ""
+          echo "  \$ vi $RPM_INSTALL_PREFIX/etc/mysql/my.pwd"
+        ) | %{l_rpmtool} msg -b -t notice
+    fi
+    if [ $1 -eq 2 ]; then
+        #   after upgrade, restore status
+        { eval `cat %{l_tmpfile}`; rm -f %{l_tmpfile}; true; } >/dev/null 2>&1
+        [ ".$mysql_active" = .yes ] && %{l_rc} mysql start
+    fi
+%endif
+    exit 0
+
+%preun
+%if "%{with_server}" == "yes"
+    #   before erase, stop service and remove log files
+    [ $1 -eq 0 ] || exit 0
+    %{l_rc} mysql stop 2>/dev/null
+    rm -f $RPM_INSTALL_PREFIX/var/mysql/*.log* >/dev/null 2>&1 || true
+    rm -f $RPM_INSTALL_PREFIX/var/mysql/*.err* >/dev/null 2>&1 || true
+%endif
+    exit 0
+

+ 95 - 0
mysql51/rc.mysql

@@ -0,0 +1,95 @@
+#!@l_prefix@/lib/openpkg/bash @l_prefix@/etc/rc
+##
+##  rc.mysql -- Run-Commands
+##
+
+%config
+    mysql_enable="$openpkg_rc_def"
+    mysql_pwd_file=@l_prefix@/etc/mysql/my.pwd
+    mysql_cnf_file=@l_prefix@/etc/mysql/my.cnf
+    mysql_common_prolog="true"
+    mysql_common_epilog="true"
+    mysql_common_numfiles="10"
+    mysql_common_minsize="1M"
+    mysql_common_complevel="9"
+    mysql_update_prolog="true"
+    mysql_update_epilog="true"
+    mysql_update_numfiles="10"
+    mysql_update_minsize="1M"
+    mysql_update_complevel="9"
+    mysql_err_prolog="true"
+    mysql_err_epilog="true"
+    mysql_err_numfiles="10"
+    mysql_err_minsize="1M"
+    mysql_err_complevel="9"
+
+%common
+    mysql_pid_file=@l_prefix@/var/mysql/mysqld.pid
+    mysql_err_log=@l_prefix@/var/mysql/mysqld.err
+    mysql_common_log=@l_prefix@/var/mysql/common.log
+    mysql_update_log=@l_prefix@/var/mysql/update.log
+
+%status -u @l_rusr@ -o
+    mysql_usable="unknown"
+    mysql_active="no"
+    @l_prefix@/bin/mysqladmin \
+        --defaults-extra-file=${mysql_pwd_file} \
+        ping >/dev/null 2>&1 && mysql_active="yes"
+    if [ $mysql_active = "no" -a -f $mysql_pid_file ] ; then
+        kill -0 `cat $mysql_pid_file` && mysql_active="unknown"
+    fi
+    echo "mysql_enable=\"$mysql_enable\""
+    echo "mysql_usable=\"$mysql_usable\""
+    echo "mysql_active=\"$mysql_active\""
+
+%start -p 400 -u @l_rusr@
+    rcService mysql enable yes || exit 0
+    rcService mysql active yes && exit 0
+    cd @l_prefix@
+    @l_prefix@/bin/mysqld_safe >/dev/null 2>&1 \
+        --mysqld=@l_mysqld@ \
+        --pid-file="$mysql_pid_file" \
+        --log-error="$mysql_err_log" &
+
+%stop -p 600 -u @l_susr@
+    rcService mysql enable yes || exit 0
+    rcService mysql active no  && exit 0
+    HOME=@l_prefix@/etc/mysql @l_prefix@/bin/mysqladmin \
+        --defaults-extra-file=${mysql_pwd_file} \
+        flush-logs
+    HOME=@l_prefix@/etc/mysql @l_prefix@/bin/mysqladmin \
+        --defaults-extra-file=${mysql_pwd_file} \
+        shutdown
+
+%restart -p 400 -u @l_rusr@
+    rcService mysql enable yes || exit 0
+    rcService mysql active no  && exit 0
+    rc mysql stop start
+
+%daily -u @l_susr@
+    rcService mysql enable yes || exit 0
+    rcTmp -i
+    hintfile=`rcTmp -f -n hint`
+    shtool rotate -f \
+        -n ${mysql_common_numfiles} -s ${mysql_common_minsize} -d \
+        -z ${mysql_common_complevel} -m 660 -o @l_rusr@ -g @l_rgrp@ \
+        -P "${mysql_common_prolog}" \
+        -E "${mysql_common_epilog}; echo 1 >$hintfile" \
+        ${mysql_common_log}
+    shtool rotate -f \
+        -n ${mysql_update_numfiles} -s ${mysql_update_minsize} -d \
+        -z ${mysql_update_complevel} -m 660 -o @l_rusr@ -g @l_rgrp@ \
+        -P "${mysql_update_prolog}" \
+        -E "${mysql_update_epilog}; echo 1 >$hintfile" \
+        ${mysql_update_log}
+    shtool rotate -f \
+        -n ${mysql_err_numfiles} -s ${mysql_err_minsize} -d \
+        -z ${mysql_err_complevel} -m 660 -o @l_rusr@ -g @l_rgrp@ \
+        -P "${mysql_err_prolog}" \
+        -E "${mysql_err_epilog}; echo 1 >$hintfile" \
+        ${mysql_err_log}
+    if [ -s $hintfile ]; then
+        rc mysql restart
+    fi
+    rcTmp -k
+