diff options
-rwxr-xr-x | BUILD/compile-pentium-max | 3 | ||||
-rwxr-xr-x | Build-tools/Do-linux-build | 10 | ||||
-rw-r--r-- | Makefile.am | 2 | ||||
-rw-r--r-- | configure.in | 3 | ||||
-rw-r--r-- | include/Makefile.am | 2 | ||||
-rw-r--r-- | strings/Makefile.am | 3 | ||||
-rw-r--r-- | support-files/mysql.server.sh | 12 | ||||
-rw-r--r-- | support-files/mysql.spec.sh | 207 |
8 files changed, 135 insertions, 107 deletions
diff --git a/BUILD/compile-pentium-max b/BUILD/compile-pentium-max index 9838e6a287b..d41274d4f5e 100755 --- a/BUILD/compile-pentium-max +++ b/BUILD/compile-pentium-max @@ -8,6 +8,7 @@ extra_configs="$pentium_configs" strip=yes extra_configs="$extra_configs --with-innodb --with-berkeley-db \ - --enable-thread-safe-client --with-openssl --with-vio" + --with-embedded-server --enable-thread-safe-client \ + --with-openssl --with-vio" . "$path/FINISH.sh" diff --git a/Build-tools/Do-linux-build b/Build-tools/Do-linux-build index e5b0a49fe75..a8b12d8b4ae 100755 --- a/Build-tools/Do-linux-build +++ b/Build-tools/Do-linux-build @@ -1,9 +1,17 @@ #! /bin/sh set -e -x + +# Only use the "--with-other-libc" parameter, if another libc actually +# exists, since this will also force static linking, which does not work +# together with OpenSSL OTHER_LIBC_DIR=/usr/local/mysql-glibc +OTHER_LIBC="" +if [ -d OTHER_LIBC_DIR ] ; then + OTHER_LIBC="--with-other-libc=$OTHER_LIBC_DIR" +fi -BUILD/compile-pentium-max --with-other-libc=$OTHER_LIBC_DIR \ +BUILD/compile-pentium-max $OTHER_LIBC \ --with-comment="Official MySQL Binary" \ --prefix=/usr/local/mysql --with-extra-charset=complex \ --enable-thread-safe-client --enable-local-infile \ diff --git a/Makefile.am b/Makefile.am index 8cb67521a4a..44f3d9a62d5 100644 --- a/Makefile.am +++ b/Makefile.am @@ -17,7 +17,7 @@ # Process this file with automake to create Makefile.in AUTOMAKE_OPTIONS = foreign -TAR = gtar + # These are built from source in the Docs directory EXTRA_DIST = INSTALL-SOURCE README \ COPYING COPYING.LIB MIRRORS diff --git a/configure.in b/configure.in index 7febd8ec21f..5e593d17dc4 100644 --- a/configure.in +++ b/configure.in @@ -364,6 +364,9 @@ AC_PATH_PROG(SED, sed, sed) AC_PATH_PROG(CMP, cmp, cmp) AC_PATH_PROG(CHMOD, chmod, chmod) AC_PATH_PROG(HOSTNAME, hostname, hostname) +# Check for a GNU tar named 'gtar', fall back to 'tar' otherwise +# and hope that it's a GNU tar as well +AC_CHECK_PROGS(TAR, gtar tar) dnl We use a path for perl so the script startup works dnl We make sure to use perl, not perl5, in hopes that the RPMs will dnl not depend on the perl5 binary being installed (probably a bug in RPM) diff --git a/include/Makefile.am b/include/Makefile.am index 0745029a41d..1de98a07ef0 100644 --- a/include/Makefile.am +++ b/include/Makefile.am @@ -18,7 +18,7 @@ BUILT_SOURCES = mysql_version.h m_ctype.h my_config.h pkginclude_HEADERS = dbug.h m_string.h my_sys.h my_list.h \ mysql.h mysql_com.h mysqld_error.h mysql_embed.h \ - my_pthread.h my_no_pthread.h raid.h errmsg.h \ + my_semaphore.h my_pthread.h my_no_pthread.h raid.h errmsg.h \ my_global.h my_net.h my_alloc.h\ sslopt-case.h sslopt-longopts.h sslopt-usage.h \ sslopt-vars.h $(BUILT_SOURCES) diff --git a/strings/Makefile.am b/strings/Makefile.am index a29c5a3365d..433b4398b61 100644 --- a/strings/Makefile.am +++ b/strings/Makefile.am @@ -45,7 +45,8 @@ EXTRA_DIST = ctype-big5.c ctype-czech.c ctype-euc_kr.c \ ctype-gb2312.c ctype-gbk.c ctype-sjis.c \ ctype-tis620.c ctype-ujis.c ctype-latin1_de.c \ ctype_autoconf.c \ - strto.c strings-x86.s longlong2str-x86.s \ + strto.c strings-x86.s \ + longlong2str.c longlong2str-x86.s \ strxmov.c bmove_upp.c strappend.c strcont.c strend.c \ strfill.c strcend.c is_prefix.c strstr.c strinstr.c \ strmake.c strnmov.c strmov.c strnlen.c \ diff --git a/support-files/mysql.server.sh b/support-files/mysql.server.sh index eed749bf5b2..e6a32d91e77 100644 --- a/support-files/mysql.server.sh +++ b/support-files/mysql.server.sh @@ -13,6 +13,18 @@ # chkconfig: 2345 90 90 # description: A very fast and reliable SQL database engine. +# Comments to support LSB init script conventions +### BEGIN INIT INFO +# Provides: mysql +# Required-Start: $local_fs $network $remote_fs +# Required-Stop: $local_fs $network $remote_fs +# Default-Start: 3 5 +# Default-Stop: 3 5 +# Short-Description: start and stop MySLQ +# Description: MySQL is a very fast and reliable SQL database engine. +### END INIT INFO + + # The following variables are only set for letting mysql.server find things. # If you want to affect other MySQL variables, you should make your changes # in the /etc/my.cnf or other configuration files. diff --git a/support-files/mysql.spec.sh b/support-files/mysql.spec.sh index a6152fbde91..372c70327b9 100644 --- a/support-files/mysql.spec.sh +++ b/support-files/mysql.spec.sh @@ -6,7 +6,7 @@ %define see_base For a description of MySQL see the base MySQL RPM or http://www.mysql.com Name: MySQL -Summary: MySQL: a very fast and reliable SQL database engine +Summary: MySQL: a very fast and reliable SQL database server Group: Applications/Databases Summary(pt_BR): MySQL: Um servidor SQL rápido e confiável. Group(pt_BR): Aplicações/Banco_de_Dados @@ -18,54 +18,32 @@ Icon: mysql.gif URL: http://www.mysql.com/ Packager: David Axmark <david@mysql.com> Vendor: MySQL AB +Requires: fileutils sh-utils Provides: msqlormysql MySQL-server mysql Obsoletes: mysql # Think about what you use here since the first step is to # run a rm -rf -BuildRoot: /var/tmp/mysql +BuildRoot: %{_tmppath}/%{name}-%{version}-build # From the manual %description -MySQL is a true multi-user, multi-threaded SQL (Structured Query -Language) database server. MySQL is a client/server implementation -that consists of a server daemon (mysqld) and many different client -programs/libraries. - -The main goals of MySQL are speed, robustness and ease of use. MySQL -was originally developed because we needed a SQL server that could -handle very big databases with magnitude higher speed than what any -database vendor could offer to us. And since we did not need all the -features that made their server slow we made our own. We have now been -using MySQL since 1996 in a environment with more than 40 databases, -10,000 tables, of which more than 500 have more than 7 million -rows. This is about 200G of data. - -The base upon which MySQL is built is a set of routines that have been -used in a highly demanding production environment for many -years. While MySQL is still in development, it already offers a rich -and highly useful function set. - -See the documentation for more information. - -%description -l pt_BR -O MySQL é um servidor de banco de dados SQL realmente multiusuário e\ -multi-tarefa. A linguagem SQL é a mais popular linguagem para banco de\ -dados no mundo. O MySQL é uma implementação cliente/servidor que\ -consiste de um servidor chamado mysqld e diversos\ -programas/bibliotecas clientes. Os principais objetivos do MySQL são:\ -velocidade, robustez e facilidade de uso. O MySQL foi originalmente\ -desenvolvido porque nós na Tcx precisávamos de um servidor SQL que\ -pudesse lidar com grandes bases de dados e com uma velocidade muito\ -maior do que a que qualquer vendedor podia nos oferecer. Estamos\ -usando\ -o MySQL desde 1996 em um ambiente com mais de 40 bases de dados com 10.000\ -tabelas, das quais mais de 500 têm mais de 7 milhões de linhas. Isto é o\ -equivalente a aproximadamente 50G de dados críticos. A base da construção do\ -MySQL é uma série de rotinas que foram usadas em um ambiente de produção com\ -alta demanda por muitos anos. Mesmo o MySQL estando ainda em desenvolvimento,\ -ele já oferece um conjunto de funções muito ricas e úteis. Veja a documentação\ -para maiores informações. +The MySQL(TM) software delivers a very fast, multi-threaded, multi-user, +and robust SQL (Structured Query Language) database server. MySQL Server +is intended for mission-critical, heavy-load production systems as well +as for embedding into mass-deployed software. MySQL is a trademark of +MySQL AB. + +The MySQL software has Dual Licensing, which means you can use the MySQL +software free of charge under the GNU General Public License +(http://www.gnu.org/licenses/). You can also purchase commercial MySQL +licenses from MySQL AB if you do not wish to be bound by the terms of +the GPL. See the chapter "Licensing and Support" in the manual for +further info. + +The MySQL web site (http://www.mysql.com/) provides the latest +news and information about the MySQL software. Also please see the +documentation and the manual for more information. %package client Release: %{release} @@ -86,7 +64,7 @@ Este pacote contém os clientes padrão para o MySQL. %package bench Release: %{release} -Requires: MySQL-client MySQL-DBI-perl-bin perl +Requires: %{name}-client MySQL-DBI-perl-bin perl Summary: MySQL - Benchmarks and test system Group: Applications/Databases Summary(pt_BR): MySQL - Medições de desempenho @@ -104,7 +82,7 @@ Este pacote contém medições de desempenho de scripts e dados do MySQL. %package devel Release: %{release} -Requires: MySQL-client +Requires: %{name}-client Summary: MySQL - Development header files and libraries Group: Applications/Databases Summary(pt_BR): MySQL - Medições de desempenho @@ -139,21 +117,29 @@ Provides: mysql-Max Obsoletes: mysql-Max %description Max -Optional MySQL server binary that supports features -like transactional tables. To active this binary, just install this -package after the MySQL package. +Optional MySQL server binary that supports additional features like +transactional tables. To activate this binary, just install this +package in addition to the MySQL package. %package embedded Release: %{release} -Requires: devel +Requires: %{name}-devel Summary: MySQL - embedded library Group: Applications/Databases Summary(pt_BR): MySQL - Medições de desempenho Group(pt_BR): Aplicações/Banco_de_Dados -Obsoletes: embedded +Obsoletes: mysql-embedded %description embedded -This package contains the MySQL server as library. +This package contains the MySQL server as an embedded library. + +The embedded MySQL server library makes it possible to run a +full-featured MySQL server inside the client application. +The main benefits are increased speed and more simple management +for embedded applications. + +The API is identical for the embedded MySQL version and the +client/server version. %{see_base} @@ -188,9 +174,9 @@ sh -c "PATH=\"${MYSQL_BUILD_PATH:-/bin:/usr/bin}\" \ --sysconfdir=/etc \ --datadir=/usr/share \ --localstatedir=/var/lib/mysql \ - --infodir=/usr/info \ + --infodir=%{_infodir} \ --includedir=/usr/include \ - --mandir=/usr/man \ + --mandir=%{_mandir} \ --with-embedded-server \ --enable-thread-safe-client \ --with-comment=\"Official MySQL RPM\"; @@ -217,12 +203,9 @@ fi RBR=$RPM_BUILD_ROOT MBD=$RPM_BUILD_DIR/mysql-%{mysql_version} -if test -z "$RBR" -o "$RBR" = "/" -then - echo "RPM_BUILD_ROOT has stupid value" - exit 1 -fi -rm -rf $RBR + +# Clean up the BuildRoot first +[ "$RBR" != "/" ] && [ -d $RBR ] && rm -rf $RBR; mkdir -p $RBR # @@ -248,7 +231,7 @@ mv Docs/manual.ps Docs/manual.ps.save make distclean mv Docs/manual.ps.save Docs/manual.ps -#now build and save shared libraries +# now build and save shared libraries BuildMySQL "--enable-shared --enable-thread-safe-client --without-server " (cd libmysql/.libs; tar cf $RBR/shared-libs.tar *.so*) (cd libmysql_r/.libs; tar rf $RBR/shared-libs.tar *.so*) @@ -271,13 +254,14 @@ nm --numeric-sort sql/mysqld > sql/mysqld.sym %install -n mysql-%{mysql_version} RBR=$RPM_BUILD_ROOT MBD=$RPM_BUILD_DIR/mysql-%{mysql_version} + # Ensure that needed directories exists install -d $RBR/etc/{logrotate.d,rc.d/init.d} install -d $RBR/var/lib/mysql/mysql install -d $RBR/usr/share/sql-bench install -d $RBR/usr/share/mysql-test -install -d $RBR/usr/{sbin,share,man,include} -install -d $RBR/usr/doc/MySQL-%{mysql_version} +install -d $RBR%{_mandir} +install -d $RBR/usr/{sbin,share,include} install -d $RBR/usr/lib # Make install make install DESTDIR=$RBR benchdir_root=/usr/share/ @@ -296,18 +280,6 @@ install -m644 $MBD/sql/mysqld.sym $RBR/usr/lib/mysql/mysqld.sym install -m644 $MBD/support-files/mysql-log-rotate $RBR/etc/logrotate.d/mysql install -m755 $MBD/support-files/mysql.server $RBR/etc/rc.d/init.d/mysql -# Install docs -install -m644 $RPM_BUILD_DIR/mysql-%{mysql_version}/Docs/mysql.info \ - $RBR/usr/info/mysql.info -for file in README COPYING COPYING.LIB Docs/manual_toc.html Docs/manual.html \ - Docs/manual.txt Docs/manual.texi Docs/manual.ps \ - support-files/my-huge.cnf support-files/my-large.cnf \ - support-files/my-medium.cnf support-files/my-small.cnf -do - b=`basename $file` - install -m644 $MBD/$file $RBR/usr/doc/MySQL-%{mysql_version}/$b -done - %pre if test -x /etc/rc.d/init.d/mysql then @@ -375,32 +347,43 @@ fi # database files. %files -%attr(-, root, root) %doc /usr/doc/MySQL-%{mysql_version}/ +%doc %attr(644, root, root) COPYING COPYING.LIB README +%doc %attr(644, root, root) Docs/manual.{html,ps,texi,txt} Docs/manual_toc.html +%doc %attr(644, root, root) support-files/my-*.cnf + +%doc %attr(644, root, root) %{_infodir}/mysql.info* + +%doc %attr(644, root, man) %{_mandir}/man1/isamchk.1* +%doc %attr(644, root, man) %{_mandir}/man1/isamlog.1* +%doc %attr(644, root, man) %{_mandir}/man1/mysql_zap.1* +%doc %attr(644, root, man) %{_mandir}/man1/mysqld.1* +%doc %attr(644, root, man) %{_mandir}/man1/mysqld_multi.1* +%doc %attr(644, root, man) %{_mandir}/man1/mysqld_safe.1* +%doc %attr(644, root, man) %{_mandir}/man1/perror.1* +%doc %attr(644, root, man) %{_mandir}/man1/replace.1* %attr(755, root, root) /usr/bin/isamchk %attr(755, root, root) /usr/bin/isamlog -%attr(755, root, root) /usr/bin/pack_isam +%attr(755, root, root) /usr/bin/my_print_defaults %attr(755, root, root) /usr/bin/myisamchk %attr(755, root, root) /usr/bin/myisamlog %attr(755, root, root) /usr/bin/myisampack -%attr(755, root, root) /usr/bin/mysql_fix_privilege_tables %attr(755, root, root) /usr/bin/mysql_convert_table_format +%attr(755, root, root) /usr/bin/mysql_explain_log +%attr(755, root, root) /usr/bin/mysql_fix_privilege_tables %attr(755, root, root) /usr/bin/mysql_install_db %attr(755, root, root) /usr/bin/mysql_setpermission %attr(755, root, root) /usr/bin/mysql_zap %attr(755, root, root) /usr/bin/mysqlbug -%attr(755, root, root) /usr/bin/mysqltest +%attr(755, root, root) /usr/bin/mysqld_multi +%attr(755, root, root) /usr/bin/mysqld_safe %attr(755, root, root) /usr/bin/mysqlhotcopy -%attr(755, root, root) /usr/bin/mysql_explain_log +%attr(755, root, root) /usr/bin/mysqltest +%attr(755, root, root) /usr/bin/pack_isam %attr(755, root, root) /usr/bin/perror %attr(755, root, root) /usr/bin/replace -%attr(755, root, root) /usr/bin/resolveip -%attr(755, root, root) /usr/bin/mysqld_safe %attr(755, root, root) /usr/bin/resolve_stack_dump -%attr(755, root, root) /usr/bin/mysqld_multi -%attr(755, root, root) /usr/bin/my_print_defaults - -%attr(644, root, root) /usr/info/mysql.info* +%attr(755, root, root) /usr/bin/resolveip %attr(755, root, root) /usr/sbin/mysqld %attr(644, root, root) /usr/lib/mysql/mysqld.sym @@ -413,28 +396,20 @@ fi %files client %attr(755, root, root) /usr/bin/msql2mysql %attr(755, root, root) /usr/bin/mysql +%attr(755, root, root) /usr/bin/mysql_find_rows %attr(755, root, root) /usr/bin/mysqlaccess %attr(755, root, root) /usr/bin/mysqladmin +%attr(755, root, root) /usr/bin/mysqlbinlog %attr(755, root, root) /usr/bin/mysqlcheck -%attr(755, root, root) /usr/bin/mysql_find_rows %attr(755, root, root) /usr/bin/mysqldump %attr(755, root, root) /usr/bin/mysqlimport %attr(755, root, root) /usr/bin/mysqlshow -%attr(755, root, root) /usr/bin/mysqlbinlog -%attr(644, root, man) %doc /usr/man/man1/mysql.1* -%attr(644, root, man) %doc /usr/man/man1/isamchk.1* -%attr(644, root, man) %doc /usr/man/man1/isamlog.1* -%attr(644, root, man) %doc /usr/man/man1/mysql_zap.1* -%attr(644, root, man) %doc /usr/man/man1/mysqlaccess.1* -%attr(644, root, man) %doc /usr/man/man1/mysqladmin.1* -%attr(644, root, man) %doc /usr/man/man1/mysqld.1* -%attr(644, root, man) %doc /usr/man/man1/mysqld_multi.1* -%attr(644, root, man) %doc /usr/man/man1/mysqldump.1* -%attr(644, root, man) %doc /usr/man/man1/mysqlshow.1* -%attr(644, root, man) %doc /usr/man/man1/perror.1* -%attr(644, root, man) %doc /usr/man/man1/replace.1* -%attr(644, root, man) %doc /usr/man/man1/mysqld_safe.1* +%doc %attr(644, root, man) %{_mandir}/man1/mysql.1* +%doc %attr(644, root, man) %{_mandir}/man1/mysqlaccess.1* +%doc %attr(644, root, man) %{_mandir}/man1/mysqladmin.1* +%doc %attr(644, root, man) %{_mandir}/man1/mysqldump.1* +%doc %attr(644, root, man) %{_mandir}/man1/mysqlshow.1* %post shared /sbin/ldconfig @@ -443,14 +418,30 @@ fi /sbin/ldconfig %files devel +%defattr(644 root, root) %attr(755, root, root) /usr/bin/comp_err -%attr(755, root, root) /usr/include/mysql/ -%attr(755, root, root) /usr/lib/mysql/*.a %attr(755, root, root) /usr/bin/mysql_config +%dir %attr(755, root, root) /usr/include/mysql +%dir %attr(755, root, root) /usr/lib/mysql +/usr/include/mysql/* +/usr/lib/mysql/libdbug.a +/usr/lib/mysql/libheap.a +/usr/lib/mysql/libmerge.a +/usr/lib/mysql/libmyisam.a +/usr/lib/mysql/libmyisammrg.a +/usr/lib/mysql/libmysqlclient.a +/usr/lib/mysql/libmysqlclient.la +/usr/lib/mysql/libmysqlclient_r.a +/usr/lib/mysql/libmysqlclient_r.la +/usr/lib/mysql/libmystrings.a +/usr/lib/mysql/libmysys.a +/usr/lib/mysql/libnisam.a +/usr/lib/mysql/libvio.a %files shared +%defattr(755 root, root) # Shared libraries (omit for architectures that don't support them) -%attr(755, root, root) /usr/lib/*.so* +/usr/lib/*.so* %files bench %attr(-, root, root) /usr/share/sql-bench @@ -464,10 +455,22 @@ fi %attr(644, root, root) /usr/lib/mysql/mysqld-max.sym %files embedded -%attr(755, root, root) /usr/lib/mysql/libmysqld.a +%attr(644, root, root) /usr/lib/mysql/libmysqld.a %changelog +* Fri May 03 2002 Lenz Grimmer <lenz@mysql.com> + +- Use more RPM macros (e.g. infodir, mandir) to make the spec + file more portable +- reorganized the installation of documentation files: let RPM + take care of this +- reorganized the file list: actually install man pages along + with the binaries of the respective subpackage +- don't include libmysqld.a in the devel subpackage as well, if we + have a special "embedded" subpackage +- reworked the package descriptions + * Mon Oct 8 2001 Monty - Added embedded server as a separate RPM |