/[smecontribs]/rpms/smeserver-automysqlbackup/contribs9/smeserver-automysqlbackup.spec
ViewVC logotype

Diff of /rpms/smeserver-automysqlbackup/contribs9/smeserver-automysqlbackup.spec

Parent Directory Parent Directory | Revision Log Revision Log | View Revision Graph Revision Graph | View Patch Patch

Revision 1.1 by unnilennium, Tue Jun 17 19:01:17 2014 UTC Revision 1.5 by jcrisp, Wed Jul 11 23:03:52 2018 UTC
# Line 1  Line 1 
1  %define name smeserver-automysqlbackup  %define name smeserver-automysqlbackup
2  %define version 3.0.RC7  %define version 3.0.RC6
3  %define release 1  %define release 9
4  %define rpmver   3.0.RC6  %define rpmver   3.0.RC6
5    
6    epoch: 2
7  Summary:            automysqlbackup is a script to backup your msql database on sme8  Summary:            automysqlbackup is a script to backup your msql database on sme8
8  Name:               %{name}  Name:               %{name}
9  Version:            %{version}  Version:            %{version}
# Line 14  Source:             %{name}-%{version}.t Line 14  Source:             %{name}-%{version}.t
14  URL:                http://sourceforge.net/projects/automysqlbackup/  URL:                http://sourceforge.net/projects/automysqlbackup/
15  BuildRoot:          /var/tmp/%{name}-%{version}-%{release}-buildroot  BuildRoot:          /var/tmp/%{name}-%{version}-%{release}-buildroot
16  BuildArchitectures: noarch  BuildArchitectures: noarch
17  Requires:           e-smith-base, e-smith-release >= 8  Requires:           e-smith-base, e-smith-release >= 9
18  Requires:               pax  Requires:               pax
19  Requires: automysqlbackup  Requires: automysqlbackup
20  BuildRequires:      e-smith-devtools  BuildRequires:      e-smith-devtools
21    Patch0: smeserver-automysqlbackup-AdjustableCronJob.patch
22    Patch1: smeserver-automysqlbackup-enhanced-templates.patch
23  %description  %description
24  This RPM is an unofficial addon for the SME Server 8.x.    This RPM is an unofficial addon for the SME Server 9.x.  
25  The target audience is the Linux/E-smith administrator  The target audience is the Linux/E-smith administrator
26  who wants to backup their mysql databases with an automatic way.  who wants to backup their mysql databases with an automatic way.
27  This script is based on automysqlbackup V3.0  This script is based on automysqlbackup V3.0
# Line 28  This script is based on automysqlbackup Line 29  This script is based on automysqlbackup
29    
30    
31  %changelog  %changelog
32  * Mon Jun 16 2014 JP Pialasse <tests@pialasse.com> 3.0.RC7-1.sme  * Fri Jul 06 2018 John Crisp <jcrisp@safeandsoundit.co.uk> 3.0.RC6-9.sme
33  - initial import to SME9 contribs  - Template configuration files
34    - run automysqlbackup per conf directly from cron rather than runmysqlbackup
35    - Add extra DB keys for mysql53, mysql55, mysql57
36    
37    * Sun Apr 02 2017 stephane de Labrusse <stephdl@de-labrusse.fr> 3.0.RC6-8.sme
38    - Added smeserver-automysqlbackup-AdjustableCronJob.patch
39    - The time to run the Job is adjustable
40    
41    * Wed Sep 16 2015 stephane de Labrusse <stephdl@de-labrusse.fr> 3.0.RC6-6.sme
42    - Added 'epoch: 2'
43    
44    * Sat Aug 22 2015 stephane de Labrusse <stephdl@de-labrusse.fr> 3.0.RC6-5.sme
45    - Initial release to contribs9
46    
47    * Sun Aug 17 2014 Stephane de Labrusse <stephdl@de-labrusse.fr> 3.0.RC6-4
48    - added my own patch against the --events warning
49    --Warning: Skipping the data of table mysql.event. Specify the --events option explicitly.
50    
51  * Sun Oct 27 2013 Stephane de Labrusse <stephdl@de-labrusse.fr> 3.0.RC6.3  * Sun Oct 27 2013 Stephane de Labrusse <stephdl@de-labrusse.fr> 3.0.RC6.3
52  - split the contrib in two versions smeserver-automysqlbackup and automysqlbackup  - split the contrib in two versions smeserver-automysqlbackup and automysqlbackup
# Line 42  This script is based on automysqlbackup Line 59  This script is based on automysqlbackup
59  rm -rf $RPM_BUILD_ROOT  rm -rf $RPM_BUILD_ROOT
60    
61  %setup  %setup
62    %patch0 -p1
63    %patch1 -p1
64    
65  %build  %build
66    perl createlinks
67    
68  %install  %install
69  /bin/rm -rf $RPM_BUILD_ROOT  /bin/rm -rf $RPM_BUILD_ROOT
70  (/usr/bin/find . -depth -print | /bin/cpio -dump $RPM_BUILD_ROOT)  (cd root   ;/usr/bin/find . -depth -print | /bin/cpio -dump $RPM_BUILD_ROOT)
71  /bin/rm -f %{name}-%{version}-filelist  /bin/rm -f %{name}-%{version}-filelist
72  /sbin/e-smith/genfilelist $RPM_BUILD_ROOT > %{name}-%{version}-filelist  /sbin/e-smith/genfilelist $RPM_BUILD_ROOT \
73    --file /sbin/e-smith/runmysqlbackup 'attr(0750,root,root)' \
74    > %{name}-%{version}-filelist
75    
76    
77  %files -f %{name}-%{version}-filelist  %files -f %{name}-%{version}-filelist
# Line 66  SMEDB=automysqlbackup Line 88  SMEDB=automysqlbackup
88  MYSQLUSER=backupuser  MYSQLUSER=backupuser
89  # Expland template  # Expland template
90  /etc/e-smith/events/actions/initialize-default-databases  /etc/e-smith/events/actions/initialize-default-databases
91    /sbin/e-smith/expand-template /etc/cron.d/runmysqlbackup
92    
93  echo "========================================================================================="  echo "***********************************************************************"
94  echo "  Your Databases are saved in /root/backup/db "  echo "  "
95  echo "  only Root can access to these folders"                          echo "Creating backup user for default mysql53 database"
 echo "  a mail is send to Admin for all logs "  
 echo " "                                                                    
 echo "  Configuration file is /etc/automysqlbackup/myserver.conf"  
 echo " "  
 echo "  For a manual play you can use directly"  
 echo "  automysqlbackup /etc/automysqlbackup/myserver.conf "  
 echo "  else backups are done every night at 04H00 AM with /etc/cron.daily/runmysqlbackup"  
 echo "========================================================================================="  
 echo "  RESTORING"  
 echo "  In a root terminal"  
 echo "  cd /root/backup/db/ and choose your backup"  
 echo "  gunzip file-name.sql.gz"  
 echo "  Next you will need to use the mysql client to restore the DB from the sql file."  
 echo "  mysql database < /path/file.sql"  
 echo "  NOTE: Make sure you use < and not > in the above command because you are piping the file.sql"  
 echo "  to mysql and not the other way around"  
 echo "========================================================================================="  
 echo "  Some db configuration for handle this contrib"  
 echo "  Mailcontent (stdout/log/files/quiet)"  
 echo "  # What would you like to be mailed to you?"  
 echo "  # - log   : send only log file (default)"  
 echo "  # - files : send log file and sql files as attachments (see docs)"  
 echo "  #- stdout : will simply output the log to the screen if run manually."  
 echo "  #- quiet : Only send logs if an error occurs to the MAILADDR."  
 echo "  Sizemail=8000 (bytes)"  
 echo "  Mailto=root (or any other user@domaine.com)"  
 echo "  Backupdir=path to the folder where mysql files are saved"  
 echo " "  
 echo "  ex: config setprop automysqlbackup Mailcontent files"  
 echo "========================================================================================="  
   
   
   
96  #create backupuser and give rights  #create backupuser and give rights
97  MYSQLPASS=$(/sbin/e-smith/config getprop $SMEDB DbPassword)  MYSQLPASS=$(/sbin/e-smith/config getprop $SMEDB DbPassword)
98  mysql -e " GRANT SELECT,LOCK TABLES ON *.* TO $MYSQLUSER@'localhost' "  mysql -e " GRANT EVENT,SELECT,LOCK TABLES ON *.* TO $MYSQLUSER@'localhost' "
99  mysql -u root -e "SET PASSWORD FOR $MYSQLUSER@localhost = PASSWORD( '$MYSQLPASS' ) "  mysql -u root -e "SET PASSWORD FOR $MYSQLUSER@localhost = PASSWORD( '$MYSQLPASS' ) "
100  mysqladmin flush-privileges  mysqladmin flush-privileges
101  /etc/rc.d/init.d/mysql.init start  /etc/rc.d/init.d/mysql.init start
102    echo "done"
103    echo "*** If you add mysql55/mysql57 you must add a backup user ***"
104    echo "You can use the password from config show automysqlbackup"
105    echo "e.g.: "
106    echo "mysql55 -e \" GRANT EVENT,SELECT,LOCK TABLES ON *.* TO $MYSQLUSER@\'localhost\' \" "
107    echo "mysql55 -u root -e \"SET PASSWORD FOR $MYSQLUSER@localhost = PASSWORD( \'$MYSQLPASS\' ) \" "
108    echo "  "
109    echo "***********************************************************************"
110    
111  #protect the backup folder  #protect the backup folder
112  chmod -R 700 /root/backup/db  chmod -R 700 /root/backup/db
# Line 119  if [ $1 = 0 ] ; then Line 117  if [ $1 = 0 ] ; then
117  SMEDB=automysqlbackup  SMEDB=automysqlbackup
118  MYSQLUSER=backupuser  MYSQLUSER=backupuser
119  echo "======================================================================="  echo "======================================================================="
120  echo "  delete mysql user and revoque all permissions"  echo "  "
121    echo "  delete mysql user and revoke all permissions"
122  # This section deletes backupuser  # This section deletes backupuser
123  mysql -u root -e "REVOKE ALL PRIVILEGES ON *.* FROM '$MYSQLUSER'@'localhost';"  mysql -u root -e "REVOKE ALL PRIVILEGES ON *.* FROM '$MYSQLUSER'@'localhost';"
124  mysql -u root -e "DROP USER $MYSQLUSER@localhost;"  mysql -u root -e "DROP USER $MYSQLUSER@localhost;"
125  echo "  "  echo "  "
126    echo "Do that for each DB - e.g mysq55, mysql57 etc"
127    echo "  "
128  # Delete custom template fragment  # Delete custom template fragment
129  echo "  delete db configuration automysqlbackup"  echo "  delete db configuration automysqlbackup"
130    echo "  "
131  echo "======================================================================="  echo "======================================================================="
132    
133  /sbin/e-smith/config delete $SMEDB  /sbin/e-smith/config delete $SMEDB


Legend:
Removed lines/characters  
Changed lines/characters
  Added lines/characters

admin@koozali.org
ViewVC Help
Powered by ViewVC 1.2.1 RSS 2.0 feed