mirror of
				https://github.com/apache/cloudstack.git
				synced 2025-10-26 08:42:29 +01:00 
			
		
		
		
	* DB : Add support for MySQL 8
- Splits commands to create user and grant access on database, the old
statement is no longer supported by MySQL 8.x
- `NO_AUTO_CREATE_USER` is no longer supported by MySQL 8.x so remove
that from db.properties conn parameters
For mysql-server 8.x setup the following changes were added/tested to
make it work with CloudStack in /etc/mysql/mysql.conf.d/mysqld.cnf and
then restart the mysql-server process:
    server_id = 1
    sql-mode="STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION,ERROR_FOR_DIVISION_BY_ZERO,NO_ZERO_DATE,NO_ZERO_IN_DATE,NO_ENGINE_SUBSTITUTION"
    innodb_rollback_on_timeout=1
    innodb_lock_wait_timeout=600
    max_connections=1000
    log-bin=mysql-bin
    binlog-format = 'ROW'
    default-authentication-plugin=mysql_native_password
Notice the last line above, this is to reset the old password based
authentication used by MySQL 5.x.
Developers can set empty password as follows:
    > sudo mysql -u root
    ALTER USER 'root'@'localhost' IDENTIFIED BY '';
In libvirt repository, there are two related commits
2019-08-23 13:13 Daniel P. Berrangé            ● rpm: don't enable socket activation in upgrade if --listen present
2019-08-22 14:52 Daniel P. Berrangé            ● remote: forbid the --listen arg when systemd socket activation
In libvirt.spec.in
        /bin/systemctl mask libvirtd.socket >/dev/null 2>&1 || :
        /bin/systemctl mask libvirtd-ro.socket >/dev/null 2>&1 || :
        /bin/systemctl mask libvirtd-admin.socket >/dev/null 2>&1 || :
        /bin/systemctl mask libvirtd-tls.socket >/dev/null 2>&1 || :
        /bin/systemctl mask libvirtd-tcp.socket >/dev/null 2>&1 || :
Co-authored-by: Wei Zhou <w.zhou@global.leaseweb.com>
Co-authored-by: Abhishek Kumar <abhishek.mrt22@gmail.com>
Co-authored-by: Rohit Yadav <rohit.yadav@shapeblue.com>
		
	
			
		
			
				
	
	
		
			234 lines
		
	
	
		
			9.0 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			234 lines
		
	
	
		
			9.0 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
| # Licensed to the Apache Software Foundation (ASF) under one
 | |
| # or more contributor license agreements.  See the NOTICE file
 | |
| # distributed with this work for additional information
 | |
| # regarding copyright ownership.  The ASF licenses this file
 | |
| # to you under the Apache License, Version 2.0 (the
 | |
| # "License"); you may not use this file except in compliance
 | |
| # with the License.  You may obtain a copy of the License at
 | |
| # 
 | |
| #   http://www.apache.org/licenses/LICENSE-2.0
 | |
| # 
 | |
| # Unless required by applicable law or agreed to in writing,
 | |
| # software distributed under the License is distributed on an
 | |
| # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 | |
| # KIND, either express or implied.  See the License for the
 | |
| # specific language governing permissions and limitations
 | |
| # under the License.
 | |
| from .utilities import Distribution, serviceOpsRedhat,serviceOpsUbuntu,serviceOpsRedhat7Later
 | |
| from .serviceConfig import *
 | |
| class sysConfigFactory:
 | |
|     @staticmethod
 | |
|     def getSysConfigFactory(glbEnv):
 | |
|         if glbEnv.mode == "Agent":
 | |
|             return sysConfigAgentFactory.getAgent(glbEnv)
 | |
|         elif glbEnv.mode == "Server":
 | |
|             return sysConfigServerFactory.getServer(glbEnv)
 | |
|         elif glbEnv.mode == "HttpsServer":
 | |
|             return sysConfigServerFactory.getServer(glbEnv)
 | |
|         elif glbEnv.mode == "Db":
 | |
|             return sysConfigDbFactory.getDb(glbEnv)
 | |
|         else:
 | |
|             raise CloudInternalException("Need to specify which mode are u running: Agent/Server/Db")
 | |
|         
 | |
| class sysConfigAgentFactory:
 | |
|     @staticmethod
 | |
|     def getAgent(glbEnv):
 | |
|         glbEnv.distribution = Distribution()
 | |
|         distribution = glbEnv.distribution.getVersion()
 | |
|         if distribution == "Ubuntu":
 | |
|             return sysConfigAgentUbuntu(glbEnv)
 | |
|         elif distribution == "Fedora" or distribution == "RHEL6":
 | |
|             return sysConfigRedhat6(glbEnv)
 | |
|         elif distribution == "CentOS" or distribution == "RHEL5":
 | |
|             return sysConfigRedhat5(glbEnv)
 | |
|         elif distribution == "RHEL7":
 | |
|             return sysConfigRedhat7(glbEnv)
 | |
|         elif distribution == "RHEL8":
 | |
|             return sysConfigRedhat8(glbEnv)
 | |
|         else:
 | |
|             print("Can't find the distribution version")
 | |
|             return sysConfig()
 | |
| 
 | |
| class sysConfigServerFactory:
 | |
|     @staticmethod
 | |
|     def getServer(glbEnv):
 | |
|         glbEnv.distribution = Distribution()
 | |
|         distribution = glbEnv.distribution.getVersion()
 | |
|         if distribution == "Ubuntu":
 | |
|             return sysConfigServerUbuntu(glbEnv)
 | |
|         elif distribution != "Unknown":
 | |
|             return sysConfigServerRedhat(glbEnv)
 | |
|         else:
 | |
|             print("Can't find the distribution version")
 | |
|             return sysConfig()
 | |
|     
 | |
| class sysConfigDbFactory:
 | |
|     @staticmethod
 | |
|     def getDb(glbEnv):
 | |
|         pass
 | |
| 
 | |
| class sysConfig(object):
 | |
|     def __init__(self, env):
 | |
|         self.env = env
 | |
|         self.services = []
 | |
|     
 | |
|     def registerService(self, service):
 | |
|         self.services.append(service(self))
 | |
|         
 | |
|     def config(self):
 | |
|         if not self.check():
 | |
|             return False
 | |
| 
 | |
|         for service in self.services:
 | |
|             if not service.configration():
 | |
|                 raise CloudInternalException("Configuration failed for service %s" % service.serviceName)
 | |
|     
 | |
|     def restore(self):
 | |
|         for service in self.services:
 | |
|             service.backup()
 | |
|     
 | |
|     def check(self):
 | |
|         return True
 | |
|     
 | |
| class sysConfigAgent(sysConfig):
 | |
|     def __init__(self, env):
 | |
|         super(sysConfigAgent, self).__init__(env)
 | |
| 
 | |
|     def check(self):
 | |
|         if self.env.debug:
 | |
|             return True
 | |
|  
 | |
|         if self.env.agentMode == "myCloud":
 | |
|             if self.env.distribution.getVersion() != "Ubuntu":
 | |
|                 raise CloudInternalException("Need to run myCloud agent on an Ubuntu machine\n")
 | |
|             elif self.env.distribution.getArch() != "x86_64":
 | |
|                 raise CloudInternalException("Need to run myCloud agent on an 64bit machine\n")
 | |
|             #check free disk space on the local disk 
 | |
|             if os.path.exists("/var/lib/libvirt/images"):
 | |
|                 size = -1
 | |
|                 try:
 | |
|                     size = int(bash("df -P /var/lib/libvirt/images | tail -1 |awk '{print $4}'").getStdout())
 | |
|                 except:
 | |
|                    pass
 | |
| 
 | |
|                 if size != -1 and size < (30 * 1024 * 1024):
 | |
|                     raise  CloudRuntimeException("Need at least 30G free disk space under /var/lib/libvirt/images")
 | |
| 
 | |
|             #check memory
 | |
|             mem = -1
 | |
|             try:
 | |
|                 mem = int(bash("free -g|grep Mem|awk '{print $2}'").getStdout())
 | |
|             except:
 | |
|                 pass
 | |
| 
 | |
|             if mem != -1 and mem < 1:
 | |
|                 raise  CloudRuntimeException("Need at least 1G memory")
 | |
| 
 | |
| 
 | |
|         if os.geteuid() != 0:
 | |
|             raise CloudInternalException("Need to execute with root permission\n")
 | |
|         
 | |
|         hostname = bash("hostname -f")
 | |
|         if not hostname.isSuccess():
 | |
|             raise CloudInternalException("Checking hostname ... [Failed]\nPlease edit /etc/hosts, add a Fully Qualified Domain Name as your hostname\n")
 | |
| 
 | |
|         kvmEnabled = self.svo.isKVMEnabled()
 | |
|         if not kvmEnabled:
 | |
|             raise CloudInternalException("Checking KVM...[Failed]\nPlease enable KVM on this machine\n")
 | |
|         
 | |
|         return True
 | |
| 
 | |
|     
 | |
| class sysConfigAgentRedhatBase(sysConfigAgent):
 | |
|     def __init__(self, env):
 | |
|         self.svo = serviceOpsRedhat()
 | |
|         super(sysConfigAgentRedhatBase, self).__init__(env)
 | |
| 
 | |
| class sysConfigAgentRedhat7Base(sysConfigAgent):
 | |
|     def __init__(self, env):
 | |
|         self.svo = serviceOpsRedhat7Later()
 | |
|         super(sysConfigAgentRedhat7Base, self).__init__(env)
 | |
| 
 | |
| class sysConfigAgentRedhat8Base(sysConfigAgent):
 | |
|     def __init__(self, env):
 | |
|         self.svo = serviceOpsRedhat7Later()
 | |
|         super(sysConfigAgentRedhat8Base, self).__init__(env)
 | |
| 
 | |
| class sysConfigAgentUbuntu(sysConfigAgent):
 | |
|     def __init__(self, glbEnv):
 | |
|         super(sysConfigAgentUbuntu, self).__init__(glbEnv)
 | |
|         self.svo = serviceOpsUbuntu()
 | |
| 
 | |
|         self.services = [securityPolicyConfigUbuntu(self),
 | |
|                          networkConfigUbuntu(self),
 | |
|                          libvirtConfigUbuntu(self),
 | |
|                          firewallConfigUbuntu(self),
 | |
|                          nfsConfig(self),
 | |
|                          cloudAgentConfig(self)]
 | |
| 
 | |
| #it covers RHEL6/Fedora13/Fedora14
 | |
| class sysConfigRedhat6(sysConfigAgentRedhatBase):
 | |
|     def __init__(self, glbEnv):
 | |
|         super(sysConfigRedhat6, self).__init__(glbEnv)
 | |
|         self.services = [cgroupConfig(self),
 | |
|                          securityPolicyConfigRedhat(self),
 | |
|                          networkConfigRedhat(self),
 | |
|                          libvirtConfigRedhat(self),
 | |
|                          firewallConfigAgent(self),
 | |
|                          nfsConfig(self),
 | |
|                          cloudAgentConfig(self)]
 | |
| 
 | |
| #It covers RHEL5/CentOS5, the mainly difference is that there is no cgroup
 | |
| class sysConfigRedhat5(sysConfigAgentRedhatBase):
 | |
|     def __init__(self, glbEnv):
 | |
|         super(sysConfigRedhat5, self).__init__(glbEnv)
 | |
|         self.services = [
 | |
|                          securityPolicyConfigRedhat(self),
 | |
|                          networkConfigRedhat(self),
 | |
|                          libvirtConfigRedhat(self),
 | |
|                          firewallConfigAgent(self),
 | |
|                          cloudAgentConfig(self)]
 | |
|         
 | |
| #it covers RHEL7
 | |
| class sysConfigRedhat7(sysConfigAgentRedhat7Base):
 | |
|     def __init__(self, glbEnv):
 | |
|         super(sysConfigRedhat7, self).__init__(glbEnv)
 | |
|         self.services = [securityPolicyConfigRedhat(self),
 | |
|                          networkConfigRedhat(self),
 | |
|                          libvirtConfigRedhat(self),
 | |
|                          firewallConfigAgent(self),
 | |
|                          nfsConfig(self),
 | |
|                          cloudAgentConfig(self)]
 | |
| 
 | |
| #it covers RHEL8
 | |
| class sysConfigRedhat8(sysConfigAgentRedhat8Base):
 | |
|     def __init__(self, glbEnv):
 | |
|         super(sysConfigRedhat8, self).__init__(glbEnv)
 | |
|         self.services = [securityPolicyConfigRedhat(self),
 | |
|                          networkConfigRedhat(self),
 | |
|                          libvirtConfigRedhat(self),
 | |
|                          firewallConfigAgent(self),
 | |
|                          nfsConfig(self),
 | |
|                          cloudAgentConfig(self)]
 | |
| 
 | |
| class sysConfigServer(sysConfig):
 | |
|     def check(self):
 | |
|         if os.geteuid() != 0:
 | |
|             raise CloudInternalException("Need to execute with root permission")
 | |
|         hostname = bash("hostname -f")
 | |
|         if not hostname.isSuccess():
 | |
|             raise CloudInternalException("Checking hostname ... [Failed]\nPlease edit /etc/hosts, add a Fully Qualified Domain Name as your hostname\n")
 | |
|         return True
 | |
|         
 | |
| class sysConfigServerRedhat(sysConfigServer):
 | |
|     def __init__(self, glbEnv):
 | |
|         super(sysConfigServerRedhat, self).__init__(glbEnv)
 | |
|         self.svo = serviceOpsRedhat()
 | |
|         self.services = [firewallConfigServer(self)]
 | |
|     
 | |
| class sysConfigServerUbuntu(sysConfigServer):
 | |
|     def __init__(self, glbEnv):
 | |
|         super(sysConfigServerUbuntu, self).__init__(glbEnv)
 | |
|         self.svo = serviceOpsUbuntu()
 | |
|         self.services = [ubuntuFirewallConfigServer(self)]
 |