SHA256
1
0
forked from pool/mariadb

Accepting request 184338 from server:database

- avoiding file conflicts with mytop
- updated to MariaDB 5.5.32
  * Release notes:
    http://kb.askmonty.org/v/mariadb-5532-release-notes
  * Changelog:
    http://kb.askmonty.org/v/mariadb-5532-changelog
- enable support for libaio (bnc#796164)
- better rights for logdir (bnc#789263)
- Moving directory with configuration to upstream default
  (/etc/mysql -> /etc/my.cnf.d)
- New default config file
- updated to MariaDB 5.5.31
  * Release notes:
    http://kb.askmonty.org/v/mariadb-5531-release-notes
  * Changelog:
    http://kb.askmonty.org/v/mariadb-5531-changelog
- cleanups in upgrade procedure
- little cleanup of systemd
- updated to MariaDB 5.5.30
  * Release notes:
    http://kb.askmonty.org/v/mariadb-5530-release-notes
  * Changelog:
    http://kb.askmonty.org/v/mariadb-5530-changelog

OBS-URL: https://build.opensuse.org/request/show/184338
OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/mariadb?expand=0&rev=29
This commit is contained in:
Stephan Kulow 2013-07-27 13:48:10 +00:00 committed by Git OBS Bridge
commit 84cdc1899a
11 changed files with 265 additions and 57 deletions

View File

@ -109,6 +109,7 @@ BuildMySQL() {
-DWITH_INNOBASE_STORAGE_ENGINE=1 \ -DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \ -DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \
-DWITH_EMBEDDED_SERVER=true \ -DWITH_EMBEDDED_SERVER=true \
-DCOMPILATION_COMMENT="openSUSE package" \
-DDENABLE_DOWNLOADS=false \ -DDENABLE_DOWNLOADS=false \
"$@" .. "$@" ..
make %{?jobs:-j%jobs} make %{?jobs:-j%jobs}

View File

@ -1,3 +1,3 @@
version https://git-lfs.github.com/spec/v1 version https://git-lfs.github.com/spec/v1
oid sha256:9d7787ba1d8fcb24323d602ecf38185504f9b0edfca9e00533045c88867a9c42 oid sha256:b2b4528bfd705dccf6be532a58ace71daff468b7e2777a01f569836a29552488
size 220 size 323

View File

@ -10,6 +10,9 @@ install -m 644 _build/sql/mysqld.sym %buildroot%_libdir/mysql/mysqld.sym
# remove handler socket client # remove handler socket client
rm -f %buildroot%_libdir/libhsclient* rm -f %buildroot%_libdir/libhsclient*
rm -f %buildroot%_bindir/hsclient* rm -f %buildroot%_bindir/hsclient*
if [ -f "%{buildroot}%{_bindir}/mytop" ]; then
mv %{buildroot}%{_bindir}/mytop %{buildroot}%{_bindir}/%{name}_mytop
fi
rm -f %buildroot%_libdir/mysql/plugin/handlersocket.so rm -f %buildroot%_libdir/mysql/plugin/handlersocket.so
# remove most static libs (FIXME: don't build them at all...) # remove most static libs (FIXME: don't build them at all...)
rm -f %buildroot%_libdir/libmysqlclient*a rm -f %buildroot%_libdir/libmysqlclient*a
@ -56,11 +59,14 @@ filelist mysqlslap >mysql-bench.files
filelist mysql_client_test mysql_client_test_embedded mysql_waitpid mysqltest mysqltest_embedded >mysql-test.files filelist mysql_client_test mysql_client_test_embedded mysql_waitpid mysqltest mysqltest_embedded >mysql-test.files
# all binaries that don't need to be in a "default" install (mysql.rpm + # all binaries that don't need to be in a "default" install (mysql.rpm +
# mysql-client.rpm) # mysql-client.rpm)
filelist msql2mysql mysql_plugin mysql_convert_table_format mysql_find_rows mysql_setpermission mysql_tzinfo_to_sql mysql_zap mysqlaccess mysqlhotcopy perror replace mysql_embedded mytop hsclient >mysql-tools.files filelist msql2mysql mysql_config_editor mysql_plugin mysql_convert_table_format mysql_find_rows mysql_setpermission mysql_tzinfo_to_sql mysql_zap mysqlaccess mysqlhotcopy perror replace mysql_embedded %{name}_mytop hsclient >mysql-tools.files
filelist ndbd ndbmtd ndbd_redo_log_reader >mysql-ndb-storage.files filelist ndbd ndbmtd ndbd_redo_log_reader >mysql-ndb-storage.files
filelist ndb_mgmd >mysql-ndb-management.files filelist ndb_mgmd >mysql-ndb-management.files
filelist ndb_{config,desc,error_reporter,mgm,print_backup_file,print_schema_file,print_sys_file,restore,select_all,select_count,show_tables,size.pl,test_platform,waiter} >mysql-ndb-tools.files filelist ndb_{config,desc,error_reporter,mgm,print_backup_file,print_schema_file,print_sys_file,restore,select_all,select_count,show_tables,size.pl,test_platform,waiter} >mysql-ndb-tools.files
filelist ndb_{cpcd,delete_all,drop_index,index_stat,print_file,redo_log_reader,drop_table} ndbinfo_select_all memcached >mysql-ndb-extra.files filelist ndb_{cpcd,delete_all,drop_index,index_stat,print_file,redo_log_reader,drop_table} ndbinfo_select_all memcached >mysql-ndb-extra.files
[ -z "`ls -1 "%buildroot/usr/share/mysql/"*.ini`" ] || echo '/usr/share/mysql/*.ini' >> mysql.files
[ -z "`ls -1 "%buildroot/usr/share/mysql/"*.cnf`" ] || echo '/usr/share/mysql/*.cnf' >> mysql.files
[ \! -f "%buildroot/usr/share/%name"/dictionary.txt ] || echo "/usr/share/%name/dictionary.txt" >> mysql.files
errmsg_list() errmsg_list()
{ {
echo '%%defattr(-, root, root)' echo '%%defattr(-, root, root)'
@ -87,7 +93,7 @@ install -m 644 _buildlibmysqld/*.so* %buildroot%_libdir
ln -s libmysqld.so.0.0.1 %buildroot%_libdir/libmysqld.so.0 ln -s libmysqld.so.0.0.1 %buildroot%_libdir/libmysqld.so.0
ln -s libmysqld.so.0.0.1 %buildroot%_libdir/libmysqld.so ln -s libmysqld.so.0.0.1 %buildroot%_libdir/libmysqld.so
%endif %endif
install -m 660 _build/support-files/my-medium.cnf %buildroot/etc/my.cnf install -m 660 %{S:14} %buildroot/etc/my.cnf
install -m 640 scripts/mysqlaccess.conf %buildroot/etc/mysqlaccess.conf install -m 640 scripts/mysqlaccess.conf %buildroot/etc/mysqlaccess.conf
for i in "${DOCS[@]}"; do for i in "${DOCS[@]}"; do
install -m 644 "${i}" "${DOCDIR}" || true install -m 644 "${i}" "${DOCDIR}" || true
@ -129,15 +135,15 @@ cat mysql-ndb-storage.files mysql-ndb-management.files \
done done
%endif %endif
%if ! 0%{prefered} > 0 %if ! 0%{prefered} > 0
cat libmysqlclient-devel.files | while read tmp; do cat libmysqlclient-devel.files | sed 's|%%doc\ ||' | while read tmp; do
cd '%buildroot' cd '%buildroot'
rm -f .$tmp rm -f ."$tmp"
done done
rm -rf '%buildroot'/%_libdir/libmysqld.* rm -rf '%buildroot'/%_libdir/libmysqld.*
rm -rf '%buildroot'/%_libdir/*.la rm -rf '%buildroot'/%_libdir/*.la
rm -rf '%buildroot'/%_libdir/*.so rm -rf '%buildroot'/%_libdir/*.so
rm -rf '%buildroot'/%_datadir/man/*/mysql_config.1*
rm -rf '%buildroot'/%_includedir rm -rf '%buildroot'/%_includedir
rm -rf '%buildroot'/%_datadir/man/*/mysql_config*
rm -rf '%buildroot'/%_datadir/aclocal rm -rf '%buildroot'/%_datadir/aclocal
rm -rf '%buildroot'/%_libdir/*.a rm -rf '%buildroot'/%_libdir/*.a
%endif %endif
@ -152,8 +158,9 @@ ln -s libndbclient.so.6.0.0 '%buildroot'%_libdir/libndbclient.so.6
if [ -f '%buildroot'/usr/bin/mysqlaccess.conf ]; then if [ -f '%buildroot'/usr/bin/mysqlaccess.conf ]; then
mv '%buildroot'/usr/bin/mysqlaccess.conf '%buildroot'/etc/mysqlaccess.conf mv '%buildroot'/usr/bin/mysqlaccess.conf '%buildroot'/etc/mysqlaccess.conf
fi fi
mkdir -p '%buildroot'/etc/mysql mkdir -p '%buildroot'/etc/my.cnf.d
bzip2 -cd '%_sourcedir'/configuration-tweaks.tar.bz2 | tar -C '%buildroot'/etc/mysql -xvf - rm -rf '%buildroot'/etc/my.cnf.d/*
bzip2 -cd '%_sourcedir'/configuration-tweaks.tar.bz2 | tar -C '%buildroot'/etc/my.cnf.d -xvf -
if [ -z "`ls '%buildroot'/usr/share/info/mysql.info*`" ]; then if [ -z "`ls '%buildroot'/usr/share/info/mysql.info*`" ]; then
install -D -m 0644 Docs/mysql.info "%buildroot/usr/share/info/mysql.info" install -D -m 0644 Docs/mysql.info "%buildroot/usr/share/info/mysql.info"
gzip -9 "%buildroot/usr/share/info/mysql.info" gzip -9 "%buildroot/usr/share/info/mysql.info"
@ -163,6 +170,6 @@ if [ "`ls '%buildroot'%_libdir/mysql/plugin/dialog*.so`" ]; then
echo '%%dir %%_libdir/mysql/plugin' >> mysql-client.files echo '%%dir %%_libdir/mysql/plugin' >> mysql-client.files
echo '%%_libdir/mysql/plugin/dialog*.so' >> mysql-client.files echo '%%_libdir/mysql/plugin/dialog*.so' >> mysql-client.files
fi fi
rm -rf '%buildroot'/etc/my.cnf.d rm -rf '%buildroot'/usr/share/doc/{mysql,mariadb}*
rm -rf '%buildroot'/usr/share/doc/%{name}-%{version} rm -rf '%buildroot'/usr/share/mysql/solaris
rm -rf '%buildroot'/usr/share/mysql/SELinux rm -rf '%buildroot'/usr/share/mysql/SELinux

View File

@ -1,3 +0,0 @@
version https://git-lfs.github.com/spec/v1
oid sha256:5d6df248b16736c2d3e9f163bb672390d59625f28520410bb746cf8a6d843dfc
size 21299322

3
mariadb-5.5.32.tar.bz2 Normal file
View File

@ -0,0 +1,3 @@
version https://git-lfs.github.com/spec/v1
oid sha256:6ae38e45391899f5377ed75e6974100af165f654842517db2b53033159257d72
size 21314660

View File

@ -1,3 +1,58 @@
-------------------------------------------------------------------
Thu Jul 25 13:08:06 CEST 2013 - mhrusecky@suse.cz
- avoiding file conflicts with mytop
-------------------------------------------------------------------
Tue Jul 23 10:28:10 CEST 2013 - mhrusecky@suse.cz
- updated to MariaDB 5.5.32
* Release notes:
http://kb.askmonty.org/v/mariadb-5532-release-notes
* Changelog:
http://kb.askmonty.org/v/mariadb-5532-changelog
-------------------------------------------------------------------
Thu Jun 6 13:22:37 UTC 2013 - mhrusecky@suse.com
- enable support for libaio (bnc#796164)
- better rights for logdir (bnc#789263)
-------------------------------------------------------------------
Wed Jun 5 08:48:42 UTC 2013 - mhrusecky@suse.com
- Moving directory with configuration to upstream default
(/etc/mysql -> /etc/my.cnf.d)
-------------------------------------------------------------------
Wed Jun 5 05:51:45 UTC 2013 - mhrusecky@suse.com
- New default config file
-------------------------------------------------------------------
Fri May 24 08:27:48 CEST 2013 - mhrusecky@suse.cz
- updated to MariaDB 5.5.31
* Release notes:
http://kb.askmonty.org/v/mariadb-5531-release-notes
* Changelog:
http://kb.askmonty.org/v/mariadb-5531-changelog
- cleanups in upgrade procedure
-------------------------------------------------------------------
Tue Mar 26 13:56:50 CET 2013 - mhrusecky@suse.cz
- little cleanup of systemd
-------------------------------------------------------------------
Tue Mar 26 11:11:37 CET 2013 - mhrusecky@suse.cz
- updated to MariaDB 5.5.30
* Release notes:
http://kb.askmonty.org/v/mariadb-5530-release-notes
* Changelog:
http://kb.askmonty.org/v/mariadb-5530-changelog
------------------------------------------------------------------- -------------------------------------------------------------------
Tue Mar 12 16:03:07 UTC 2013 - tpaszkowski@suse.com Tue Mar 12 16:03:07 UTC 2013 - tpaszkowski@suse.com

View File

@ -35,9 +35,9 @@ Name: mariadb
Summary: Server part of MariaDB Summary: Server part of MariaDB
License: SUSE-GPL-2.0-with-FLOSS-exception License: SUSE-GPL-2.0-with-FLOSS-exception
Group: Productivity/Databases/Servers Group: Productivity/Databases/Servers
Version: 5.5.29 Version: 5.5.32
Release: 0 Release: 0
%define srv_vers 5.5.29 %define srv_vers 5.5.32
Url: http://www.mariab.org Url: http://www.mariab.org
Source: mariadb-%{version}.tar.bz2 Source: mariadb-%{version}.tar.bz2
Source2: baselibs.conf Source2: baselibs.conf
@ -51,6 +51,7 @@ Source10: build.inc
Source11: install.inc Source11: install.inc
Source12: series Source12: series
Source13: configuration-tweaks.tar.bz2 Source13: configuration-tweaks.tar.bz2
Source14: my.ini
BuildRoot: %{_tmppath}/%{name}-%{version}-build BuildRoot: %{_tmppath}/%{name}-%{version}-build
%if 0%{?suse_version} %if 0%{?suse_version}
PreReq: pwdutils PreReq: pwdutils
@ -60,6 +61,8 @@ BuildRequires: autoconf
BuildRequires: automake BuildRequires: automake
BuildRequires: cmake BuildRequires: cmake
BuildRequires: gcc-c++ BuildRequires: gcc-c++
BuildRequires: libaio-devel
BuildRequires: libedit-devel
BuildRequires: libtool BuildRequires: libtool
BuildRequires: ncurses-devel BuildRequires: ncurses-devel
BuildRequires: openssl-devel BuildRequires: openssl-devel
@ -77,9 +80,6 @@ BuildRequires: fdupes
%if 0%{?fedora_version} > 11 %if 0%{?fedora_version} > 11
BuildRequires: sqlite BuildRequires: sqlite
%endif %endif
%if 0%{?suse_version} >= 1210
BuildRequires: systemd
%endif
%if 0%{?suse_version} > 1030 %if 0%{?suse_version} > 1030
Recommends: logrotate Recommends: logrotate
%else %else
@ -91,6 +91,7 @@ Requires: %{name}-errormessages = %version
Requires: perl-base Requires: perl-base
# systemd requirements for openSUSE >= 12.1 # systemd requirements for openSUSE >= 12.1
%if 0%{?suse_version} >= 1210 %if 0%{?suse_version} >= 1210
BuildRequires: systemd
%{?systemd_requires} %{?systemd_requires}
%endif %endif
Provides: mysql = %{srv_vers} Provides: mysql = %{srv_vers}
@ -171,6 +172,9 @@ languages and applications need to dynamically load and use MariaDB.
Summary: Client for MariaDB Summary: Client for MariaDB
Group: Productivity/Databases/Clients Group: Productivity/Databases/Clients
Provides: mysql-client = %{srv_vers} Provides: mysql-client = %{srv_vers}
%if 0%{?suse_version}
PreReq: pwdutils
%endif
%if 0%{?use_extra_provides} > 0 %if 0%{?use_extra_provides} > 0
Provides: %{extra_provides}-client = %{version} Provides: %{extra_provides}-client = %{version}
Obsoletes: %{extra_provides}-client < %{version} Obsoletes: %{extra_provides}-client < %{version}
@ -385,6 +389,12 @@ rm -f mysql-test/t/file_contents.test mysql-test/r/file_contents.result
%service_add_pre mysql.service %service_add_pre mysql.service
%endif %endif
%pre client
/usr/sbin/groupadd -r mysql >/dev/null 2>/dev/null || :
/usr/sbin/useradd -r -o -g mysql -u 60 -c "MySQL database admin" \
-s /bin/false -d /var/lib/mysql mysql 2> /dev/null || :
/usr/sbin/usermod -g mysql -s /bin/false mysql || :
%post %post
# systemd requirment # systemd requirment
%if 0%{?suse_version} >= 1210 %if 0%{?suse_version} >= 1210
@ -396,10 +406,6 @@ rm -f mysql-test/t/file_contents.test mysql-test/r/file_contents.result
####################################################################### #######################################################################
%preun %preun
[ $1 = 1 ] || /usr/sbin/rcmysql stop [ $1 = 1 ] || /usr/sbin/rcmysql stop
# systemd requirment
%if 0%{?suse_version} >= 1210
%service_del_preun mysql.service
%endif
%pretrans -p <lua> %pretrans -p <lua>
if posix.access("/usr/sbin/rcmysql", "x") then if posix.access("/usr/sbin/rcmysql", "x") then
@ -411,16 +417,8 @@ if posix.access("/usr/sbin/rcmysql", "x") then
end end
end end
dbfile="var/mysql/mysql/db.ISM"
olddir="var/mysql"
newdir="var/lib/mysql"
-- Do the database files still belong to root (very old installation)?
-- Change ownerships
if posix.stat(dbfile, "uid") == 0 then
os.execute("/bin/chown -Rv mysql:mysql var/mysql/")
end
%posttrans %posttrans
[ -z "`ls %{_infodir}/mysql.info.* 2> /dev/null`" ] || \
%install_info --info-dir=%{_infodir} %{_infodir}/mysql.info.* %install_info --info-dir=%{_infodir} %{_infodir}/mysql.info.*
if [ -d /var/lib/mysql ]; then if [ -d /var/lib/mysql ]; then
touch /var/lib/mysql/.run-mysql_upgrade touch /var/lib/mysql/.run-mysql_upgrade
@ -463,11 +461,11 @@ fi
if [ $1 = 0 ]; then if [ $1 = 0 ]; then
%install_info_delete --info-dir=%{_infodir} %{_infodir}/mysql.info.* %install_info_delete --info-dir=%{_infodir} %{_infodir}/mysql.info.*
%{insserv_cleanup} %{insserv_cleanup}
rm -f "/var/lib/systemd/migrated/mysql.service"
if [ -x /usr/bin/systemctl ]; then
/usr/bin/systemctl daemon-reload >/dev/null 2>&1 || :
fi
fi fi
# systemd requirment
%if 0%{?suse_version} >= 1210
%service_del_postun mysql.service
%endif
####################################################################### #######################################################################
# Files section # # Files section #
@ -476,8 +474,8 @@ fi
%files -f mysql.files %files -f mysql.files
%defattr(-, root, root) %defattr(-, root, root)
%config(noreplace) %attr(0640, root, mysql) /etc/my.cnf %config(noreplace) %attr(0640, root, mysql) /etc/my.cnf
%dir %attr(0750, root, mysql) /etc/mysql %dir %attr(0750, root, mysql) /etc/my.cnf.d
%config(noreplace) %attr(0640, root, mysql) /etc/mysql/* %config(noreplace) %attr(0640, root, mysql) /etc/my.cnf.d/*
%config /etc/logrotate.d/mysql %config /etc/logrotate.d/mysql
%doc %{_defaultdocdir}/%{name} %doc %{_defaultdocdir}/%{name}
%doc %{_infodir}/mysql.info.* %doc %{_infodir}/mysql.info.*
@ -486,8 +484,6 @@ fi
%dir /usr/share/%{name} %dir /usr/share/%{name}
%dir /usr/share/mysql %dir /usr/share/mysql
/usr/share/%{name}/charsets/ /usr/share/%{name}/charsets/
/usr/share/mysql/*.cnf
/usr/share/mysql/*.ini
/usr/share/%{name}/*.sql /usr/share/%{name}/*.sql
%ghost %dir %attr(755,mysql,mysql)/var/run/mysql %ghost %dir %attr(755,mysql,mysql)/var/run/mysql
%dir %{_libdir}/mysql %dir %{_libdir}/mysql

103
my.ini Normal file
View File

@ -0,0 +1,103 @@
# This is default example of MySQL/MariaDB configuration provided with openSUSE package
# It is based on upstream defaults with some additional examples.
# The following options will be passed to all MariaDB clients
[client]
# password = your_password
# port = 3306
# socket = /var/run/mysql/mysql.sock
[mysqld]
# Remove leading # if you don't want to listen on network (only socket - safer)
# skip-networking
# Remove leading # and set to the amount of RAM for the most important data
# cache in MySQL. Start at 70% of total RAM for dedicated server, else 10%.
# innodb_buffer_pool_size = 128M
# Using newer file format that supports dynamic and compressed row formats.
# If you are using replication you have to make sure, that these options are
# set everywhere the same way (probably comment them out is the easiest way)
innodb_file_format=Barracuda
innodb_file_per_table=ON
# Remove leading # to turn on a very important data integrity option: logging
# changes to the binary log between backups.
# log_bin=mysql-bin
# binlog_format=mixed
# Remove leading # if you want to store your database elsewhere
# datadir = /var/lib/mysql
# required unique id between 1 and 2^32 - 1
# defaults to 1 if master-host is not set
# but will not function as a master if omitted
server-id = 1
# These are commonly set, remove the # and set as required.
# port = 3306
# socket = /var/run/mysql/mysql.sock
# Don't listen on a TCP/IP port at all. This can be a security enhancement,
# if all processes that need to connect to mysqld run on the same host.
# All interaction with mysqld must be made via Unix sockets or named pipes.
# Note that using this option without enabling named pipes on Windows
# (via the "enable-named-pipe" option) will render mysqld useless!
#
# skip-networking
# Remove leading # to set options mainly useful for reporting servers.
# The server defaults are faster for transactions and fast SELECTs.
# Adjust sizes as needed, experiment to find the optimal values.
# join_buffer_size = 128M
# sort_buffer_size = 2M
# read_rnd_buffer_size = 2M
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
[mysqld_multi]
mysqld = /usr/bin/mysqld_safe
mysqladmin = /usr/bin/mysqladmin
log = /var/log/mysqld_multi.log
# If you want to use mysqld_multi uncomment 1 or more mysqld sections
# below or add your own ones.
# WARNING
# --------
# If you uncomment mysqld1 than make absolutely sure, that database mysql,
# configured above, is not started. This may result in corrupted data!
#
# [mysqld1]
# port = 3306
# datadir = /var/lib/mysql
# pid-file = /var/lib/mysql/mysqld.pid
# socket = /var/lib/mysql/mysql.sock
# user = mysql
# [mysqld2]
# port = 3307
# datadir = /var/lib/mysql-databases/mysqld2
# pid-file = /var/lib/mysql-databases/mysqld2/mysql.pid
# socket = /var/lib/mysql-databases/mysqld2/mysql.sock
# user = mysql
# [mysqld3]
# port = 3308
# datadir = /var/lib/mysql-databases/mysqld3
# pid-file = /var/lib/mysql-databases/mysqld3/mysql.pid
# socket = /var/lib/mysql-databases/mysqld3/mysql.sock
# user = mysql
# [mysqld6]
# port = 3309
# datadir = /var/lib/mysql-databases/mysqld6
# pid-file = /var/lib/mysql-databases/mysqld6/mysql.pid
# socket = /var/lib/mysql-databases/mysqld6/mysql.sock
# user = mysql
!include_dir /etc/mysql
!include_dir /etc/my.cnf.d

View File

@ -1,3 +1,3 @@
version https://git-lfs.github.com/spec/v1 version https://git-lfs.github.com/spec/v1
oid sha256:ab62b051b2d913334d421d92dfbe156e55e5571fd163f57d1c58587550ae9341 oid sha256:2b34d03c24091c0a8120aae545ac9f0959b4167c21e7a1954819836bdf66a673
size 11762 size 11823

View File

@ -91,9 +91,14 @@ wait_for_socket()
# See https://bugzilla.novell.com/show_bug.cgi?id=223209 # See https://bugzilla.novell.com/show_bug.cgi?id=223209
kill_mysql () kill_mysql ()
{ {
local pid exe local pid exe test_pid_file
test -e "$pid_file" || return 7 # not running if [ "$1" ]; then
pid=`cat "$pid_file"` || return 4 # insufficient privileges test_pid_file="$1"
else
test_pid_file="$pid_file"
fi
test -e "$test_pid_file" || return 7 # not running
pid=`cat "$test_pid_file"` || return 4 # insufficient privileges
if ! test -e /proc/version; then if ! test -e /proc/version; then
mount -n -t proc proc /proc mount -n -t proc proc /proc
test -e /proc/version || return 100 test -e /proc/version || return 100
@ -106,10 +111,10 @@ kill_mysql ()
kill -CONT "$pid" kill -CONT "$pid"
for i in `seq 3000`; do for i in `seq 3000`; do
# mysqld removes its pid file # mysqld removes its pid file
test -e "$pid_file" || return 0 test -e "$test_pid_file" || return 0
LC_ALL=C sleep 0.1 LC_ALL=C sleep 0.1
done done
test -e "$pid_file" || return 0 test -e "$test_pid_file" || return 0
return 1 return 1
} }
@ -324,7 +329,7 @@ else
log_dir="`dirname "$i"`" log_dir="`dirname "$i"`"
if [ \! -d "$log_dir" ]; then if [ \! -d "$log_dir" ]; then
mkdir -p "$log_dir" mkdir -p "$log_dir"
chmod 660 "$log_dir" chmod 770 "$log_dir"
fi fi
done done
@ -339,12 +344,14 @@ else
check_obsolete check_obsolete
# Run mysql_upgrade on every package install/upgrade. Not allways # Run mysql_upgrade on every package install/upgrade. Not allways
# necessary, but doesn't do any harm. # necessary, but doesn't do any harm.
if test -f "$datadir/.run-mysql_upgrade" ; then if [ -f "/var/lib/mysql/.run-mysql_upgrade" ]; then
echo >> "$log_upgrade" echo > "$log_upgrade"
echo "`LANG="" date` - upgrading MySQL..." >> "$log_upgrade" echo "`LANG="" date` - upgrading MySQL..." >> "$log_upgrade"
echo >> "$log_upgrade" echo >> "$log_upgrade"
echo "Will update MySQL now, if you encounter any problems, please read following file:" | tee -a "$log_upgrade" echo "Will update MySQL now, if you encounter any problems, please read following file:" | tee -a "$log_upgrade"
echo " /usr/share/doc/packages/mysql/README.SuSE" | tee -a "$log_upgrade" echo " /usr/share/doc/packages/mysql/README.SuSE" | tee -a "$log_upgrade"
sed -i -e 's|^\([^#]*skip-locking\)|#\1\nskip-external-locking|' \
-e 's|^\([^#]*skip-federated\)|#\1|' /etc/my.cnf
# Check logs for inconsistencies # Check logs for inconsistencies
SRCLOGS="" SRCLOGS=""
ALL_SRCLOGS="" ALL_SRCLOGS=""
@ -364,10 +371,13 @@ else
fi fi
fi fi
check_obsolete >> "$log_upgrade" check_obsolete >> "$log_upgrade"
# instead of running mysqld --bootstrap, which wouldn't allow # instead of running mysqld --bootstrap, which wouldn't allow
# us to run mysql_upgrade, we start a full-featured server with # us to run mysql_upgrade, we start a full-featured server with
# --skip-grant-tables and restict access to it by unix # --skip-grant-tables and restict access to it by unix
# permissions of the named socket # permissions of the named socket
protected="`cat /var/run/mysql/protecteddir 2> /dev/null`" protected="`cat /var/run/mysql/protecteddir 2> /dev/null`"
if [ -d "$protected" ]; then if [ -d "$protected" ]; then
pid="`cat "$protected/mysqld.pid" 2> /dev/null`" pid="`cat "$protected/mysqld.pid" 2> /dev/null`"
@ -375,6 +385,7 @@ else
[ "`readlink "/proc/$pid/exe" | grep "mysql"`" ]; then [ "`readlink "/proc/$pid/exe" | grep "mysql"`" ]; then
echo "Can't update as another updating process is currently running" | tee -a "$log_upgrade" echo "Can't update as another updating process is currently running" | tee -a "$log_upgrade"
echo "Please check process $pid and terminate it before restarting MySQL" | tee -a "$log_upgrade" echo "Please check process $pid and terminate it before restarting MySQL" | tee -a "$log_upgrade"
touch /var/lib/mysql/.run-mysql_upgrade
rc_failed; rc_status -v; rc_exit; rc_failed; rc_status -v; rc_exit;
else else
rm -rf "$protected" rm -rf "$protected"
@ -382,9 +393,16 @@ else
fi fi
protected="`mktemp -d -p /var/tmp mysql-protected.XXXXXX | tee /var/run/mysql/protecteddir`" protected="`mktemp -d -p /var/tmp mysql-protected.XXXXXX | tee /var/run/mysql/protecteddir`"
export TMPDIR="$TEMPDIR" export TMPDIR="$TEMPDIR"
# Run upgrade, double check
# We need to restart mysql every time as programs
# reloads privileges tables, so we can get lock out
for cmd in "/usr/bin/mysql_upgrade" \
"/usr/bin/mysql_upgrade"; do
[ -z "$protected" ] || chown "$mysql_daemon_user:$mysql_daemon_group" "$protected" [ -z "$protected" ] || chown "$mysql_daemon_user:$mysql_daemon_group" "$protected"
[ "`ls -ld "$protected" | grep "^drwx------[\\.\+]\?[[:blank:]]\+[0-9]\+[[:blank:]]\+$mysql_daemon_user[[:blank:]]\+$mysql_daemon_group[[:blank:]]\+.*"`" ] || { [ "`ls -ld "$protected" | grep "^drwx------[\\.\+]\?[[:blank:]]\+[0-9]\+[[:blank:]]\+$mysql_daemon_user[[:blank:]]\+$mysql_daemon_group[[:blank:]]\+.*"`" ] || {
echo "Can't create secure $protected" | tee -a "$log_upgrade" echo "Can't create secure $protected" | tee -a "$log_upgrade"
touch /var/lib/mysql/.run-mysql_upgrade
rc_failed; rc_status -v; rc_exit; rc_failed; rc_status -v; rc_exit;
} }
@ -403,21 +421,49 @@ else
wait_for_socket "$protected/mysql.sock" || { wait_for_socket "$protected/mysql.sock" || {
echo "error: $protected/mysql.sock file didn't appeared... " | tee -a "$log_upgrade" echo "error: $protected/mysql.sock file didn't appeared... " | tee -a "$log_upgrade"
echo " Try checking \"$log_upgrade_run\"... " | tee -a "$log_upgrade" echo " Try checking \"$log_upgrade_run\"... " | tee -a "$log_upgrade"
touch /var/lib/mysql/.run-mysql_upgrade
rc_failed; rc_status -v; rc_exit; rc_failed; rc_status -v; rc_exit;
} }
if [ "`grep "Upgrading MySQL..." "$log_upgrade"`" ]; then
echo "Rechecking whether everything is Ok... " | tee -a "$log_upgrade"
LANG=C $cmd --no-defaults --force \
--socket="$protected/mysql.sock" | \
sed -e 's|^|\ \ \ |' | \
tee -a "$log_upgrade"
else
echo "Upgrading MySQL... " | tee -a "$log_upgrade" echo "Upgrading MySQL... " | tee -a "$log_upgrade"
/usr/bin/mysql_upgrade \ LANG=C $cmd --no-defaults --force \
--socket="$protected/mysql.sock" | tee -a "$log_upgrade" --socket="$protected/mysql.sock" | \
sed -e 's|^|\ \ \ |' \
-e 's|error|info|' \
-e 's|\(Table\ upgrade\ required.\).*|\1|' | \
tee -a "$log_upgrade"
fi
[ "$PIPESTATUS" -ne 0 ] && { [ "$PIPESTATUS" -ne 0 ] && {
rc_failed; rc_status -v; rc_failed; rc_status -v;
kill -TERM "`cat $protected/mysqld.pid`" kill_mysql "$protected/mysqld.pid"
rc_exit; } rc_exit; }
kill -TERM "`cat $protected/mysqld.pid`"
kill_mysql "$protected/mysqld.pid" || {
echo "error: Can't stop protected MySQL... " | tee -a "$log_upgrade"
rc_failed; rc_status -v;
kill_mysql "$protected/mysqld.pid"
rc_exit; }
# Everything went fine
if [ -z "`grep REPAIR "$log_upgrade"`" ] && \
[ -z "`grep "Table\ upgrade\ required" "$log_upgrade"`" ]; then
break
fi
done # end of upgrade
rm -rf "$protected" rm -rf "$protected"
# Fix ownerships and permissions for $datadir # Fix ownerships and permissions for $datadir
chmod 750 "$datadir" chmod 750 "$datadir"
chown -R "$mysql_daemon_user:$mysql_daemon_group" "$datadir" chown -R "$mysql_daemon_user:$mysql_daemon_group" "$datadir"
rm -f "$datadir/.run-mysql_upgrade" \ rm -f /var/lib/mysql/.run-mysql_upgrade \
rm -f /var/lib/mysql/.force_upgrade \
"$datadir"/{update-stamp-*,mysql/stamp-4.1} # used in the past "$datadir"/{update-stamp-*,mysql/stamp-4.1} # used in the past
chown "$mysql_daemon_user:$mysql_daemon_group" "$log_upgrade" chown "$mysql_daemon_user:$mysql_daemon_group" "$log_upgrade"
chmod 640 "$log_upgrade" chmod 640 "$log_upgrade"

2
series
View File

@ -5,7 +5,7 @@ mariadb-5.1.50-strncat-overflow.patch
mariadb-5.5.28-install_db-quiet.patch mariadb-5.5.28-install_db-quiet.patch
mysql-community-server-5.1.51-mysql_config.patch mysql-community-server-5.1.51-mysql_config.patch
mariadb-5.5.25-mysqld_multi-features.patch mariadb-5.5.25-mysqld_multi-features.patch
mariadb-5.1.50-upgrade-exit-status.patch mariadb-5.5.32-upgrade-exit-status.patch
mariadb-5.2.3-cnf.patch mariadb-5.2.3-cnf.patch
mysql-community-server-5.5.6-safe-process-in-bin.patch mysql-community-server-5.5.6-safe-process-in-bin.patch
mariadb-5.5.28-group.patch mariadb-5.5.28-group.patch