/vakap/components/mysql.py

https://github.com/ombu/vakap · Python · 33 lines · 28 code · 5 blank · 0 comment · 3 complexity · 8145ac207f4c76ee5a6cf598bb3529e3 MD5 · raw file

  1. from time import gmtime, strftime
  2. from fabric.api import task, settings, cd, hide, run, env
  3. from base import Component, s3_upload, s3_file_exists, s3_latest_file_in_bucket
  4. class MysqlComponent(Component):
  5. def __init__(self, site_name, raw_data):
  6. super(type(self), self).__init__(site_name, raw_data)
  7. def backup(self):
  8. with settings(host_string=self.host_string):
  9. backup_mysql(self.site_name, self.db_name, self.db_user)
  10. def status(self):
  11. date = s3_latest_file_in_bucket(env.s3_bucket, self.site_name)
  12. print("%s last backed up: %s" % (self.__class__.__name__, date))
  13. @task
  14. def backup_mysql(site_name, dbname, dbuser):
  15. date = strftime("%Y.%m.%d", gmtime())
  16. gpg_file = 'sql-%s.sql.gz.gpg' % date
  17. local_file = "%s/vakap-%s" % ('/tmp', gpg_file)
  18. s3_dest = "s3://%s/%s/%s" % (env.s3_bucket, site_name, gpg_file)
  19. if s3_file_exists(s3_dest):
  20. print " - File exists: %s. Skipping." % s3_dest
  21. return
  22. else:
  23. print " - Dumping and encrypting database: %s" % dbname
  24. run("""mysqldump -u {dbuser} --add-drop-table {dbname} \
  25. | gzip | gpg --encrypt --recipient {key} > {local_file}"""
  26. .format(dbuser=dbuser, dbname=dbname, key=env.gpg_key,
  27. local_file=local_file))
  28. s3_upload(local_file, s3_dest)