troveupgrade源码阅读-创新互联
trove upgrade 用于将数据库从一个版本更新到另一个版本,如:将mysql5.5更换到mysql5.6
创新互联于2013年开始,先为武川等服务建站,武川等地企业,进行企业商务咨询服务。为武川企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。trove/taskmanager/manager.py 368行
def upgrade(self, context, instance_id, datastore_version_id): instance_tasks = models.BuiltInstanceTasks.load(context, instance_id) datastore_version = DatastoreVersion.load_by_uuid(datastore_version_id) with EndNotification(context): instance_tasks.upgrade(datastore_version)instance_tasks.upgrade(datastore_version)调用
trove/taskmanager/models.py 1501行
def upgrade(self, datastore_version): ... try: upgrade_info = self.guest.pre_upgrade() ... self.server.rebuild(datastore_version.p_w_picpath_id, files=injected_files) ... if volume: upgrade_info['device'] = volume_device self.guest.post_upgrade(upgrade_info) self.reset_task_status() ...upgrade instance 主要是以下几步完成:
self.guest.pre_upgrade:更新前的一些操作,主要是将mysql的配置文件保存在cinder volume中
self.server.rebuild:用新的数据库基础镜像重建trove的nova实例
self.guest.post_upgrade:重建nova instance後的一些操作,主要操作是从cinder volume中恢复mysql配置文件,启动mysql
self.guest.pre_upgrade,self.guest.post_upgrade 通过rcp方式调用运行在nova instance上的trove-guestagent的中对应方法
trove/guestagent/datastore/mysql/_common/manager.py 245行
pre_upgrade备份数据库的配置文件、guestagent位于trove home 目录下的配置信息,返回包含备份信息的一个字典
trove/guestagent/datastore/mysql/_common/manager.py 275行
post_upgrade恢复备份中的配置文件,不对老数据库的任何文件作修改,直接使用老数据库的配置文件与数据文件启动数据库
另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
分享标题:troveupgrade源码阅读-创新互联
网页网址:http://ybzwz.com/article/hjcdi.html