Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(199)

Unified Diff: tools/telemetry/third_party/gsutil/third_party/boto/boto/pyami/installers/ubuntu/mysql.py

Issue 1260493004: Revert "Add gsutil 4.13 to telemetry/third_party" (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: tools/telemetry/third_party/gsutil/third_party/boto/boto/pyami/installers/ubuntu/mysql.py
diff --git a/tools/telemetry/third_party/gsutil/third_party/boto/boto/pyami/installers/ubuntu/mysql.py b/tools/telemetry/third_party/gsutil/third_party/boto/boto/pyami/installers/ubuntu/mysql.py
deleted file mode 100644
index 5b0792ba9da9ebe0485db68ed2b3c6796b100d57..0000000000000000000000000000000000000000
--- a/tools/telemetry/third_party/gsutil/third_party/boto/boto/pyami/installers/ubuntu/mysql.py
+++ /dev/null
@@ -1,108 +0,0 @@
-# Copyright (c) 2006-2009 Mitch Garnaat http://garnaat.org/
-#
-# Permission is hereby granted, free of charge, to any person obtaining a
-# copy of this software and associated documentation files (the
-# "Software"), to deal in the Software without restriction, including
-# without limitation the rights to use, copy, modify, merge, publish, dis-
-# tribute, sublicense, and/or sell copies of the Software, and to permit
-# persons to whom the Software is furnished to do so, subject to the fol-
-# lowing conditions:
-#
-# The above copyright notice and this permission notice shall be included
-# in all copies or substantial portions of the Software.
-#
-# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
-# OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABIL-
-# ITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT
-# SHALL THE AUTHOR BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
-# WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
-# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
-# IN THE SOFTWARE.
-#
-"""
-This installer will install mysql-server on an Ubuntu machine.
-In addition to the normal installation done by apt-get, it will
-also configure the new MySQL server to store it's data files in
-a different location. By default, this is /mnt but that can be
-configured in the [MySQL] section of the boto config file passed
-to the instance.
-"""
-from boto.pyami.installers.ubuntu.installer import Installer
-import os
-import boto
-from boto.utils import ShellCommand
-from boto.compat import ConfigParser
-import time
-
-ConfigSection = """
-[MySQL]
-root_password = <will be used as MySQL root password, default none>
-data_dir = <new data dir for MySQL, default is /mnt>
-"""
-
-class MySQL(Installer):
-
- def install(self):
- self.run('apt-get update')
- self.run('apt-get -y install mysql-server', notify=True, exit_on_error=True)
-
-# def set_root_password(self, password=None):
-# if not password:
-# password = boto.config.get('MySQL', 'root_password')
-# if password:
-# self.run('mysqladmin -u root password %s' % password)
-# return password
-
- def change_data_dir(self, password=None):
- data_dir = boto.config.get('MySQL', 'data_dir', '/mnt')
- fresh_install = False
- is_mysql_running_command = ShellCommand('mysqladmin ping') # exit status 0 if mysql is running
- is_mysql_running_command.run()
- if is_mysql_running_command.getStatus() == 0:
- # mysql is running. This is the state apt-get will leave it in. If it isn't running,
- # that means mysql was already installed on the AMI and there's no need to stop it,
- # saving 40 seconds on instance startup.
- time.sleep(10) #trying to stop mysql immediately after installing it fails
- # We need to wait until mysql creates the root account before we kill it
- # or bad things will happen
- i = 0
- while self.run("echo 'quit' | mysql -u root") != 0 and i < 5:
- time.sleep(5)
- i = i + 1
- self.run('/etc/init.d/mysql stop')
- self.run("pkill -9 mysql")
-
- mysql_path = os.path.join(data_dir, 'mysql')
- if not os.path.exists(mysql_path):
- self.run('mkdir %s' % mysql_path)
- fresh_install = True
- self.run('chown -R mysql:mysql %s' % mysql_path)
- fp = open('/etc/mysql/conf.d/use_mnt.cnf', 'w')
- fp.write('# created by pyami\n')
- fp.write('# use the %s volume for data\n' % data_dir)
- fp.write('[mysqld]\n')
- fp.write('datadir = %s\n' % mysql_path)
- fp.write('log_bin = %s\n' % os.path.join(mysql_path, 'mysql-bin.log'))
- fp.close()
- if fresh_install:
- self.run('cp -pr /var/lib/mysql/* %s/' % mysql_path)
- self.start('mysql')
- else:
- #get the password ubuntu expects to use:
- config_parser = ConfigParser()
- config_parser.read('/etc/mysql/debian.cnf')
- password = config_parser.get('client', 'password')
- # start the mysql deamon, then mysql with the required grant statement piped into it:
- self.start('mysql')
- time.sleep(10) #time for mysql to start
- grant_command = "echo \"GRANT ALL PRIVILEGES ON *.* TO 'debian-sys-maint'@'localhost' IDENTIFIED BY '%s' WITH GRANT OPTION;\" | mysql" % password
- while self.run(grant_command) != 0:
- time.sleep(5)
- # leave mysqld running
-
- def main(self):
- self.install()
- # change_data_dir runs 'mysql -u root' which assumes there is no mysql password, i
- # and changing that is too ugly to be worth it:
- #self.set_root_password()
- self.change_data_dir()

Powered by Google App Engine
This is Rietveld 408576698