欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Openstack 使用migrate進行數(shù)據(jù)庫升級實現(xiàn)方案詳細介紹

 更新時間:2016年12月04日 15:17:27   作者:Sylvernass  
這篇文章主要介紹了Openstack 使用migrate進行數(shù)據(jù)庫升級詳細介紹的相關(guān)資料,數(shù)據(jù)庫表或者增加字段等是必然的事情,如何比較容易的進行這些數(shù)據(jù)庫升級的適配和管理,這里提供實現(xiàn)方法,需要的朋友可以參考下

Openstack 使用migrate進行數(shù)據(jù)庫升級實現(xiàn)方案詳細介紹

OpenStack中隨著版本的切換,新版本加入一些數(shù)據(jù)庫表或者增加字段等是必然的事情,如何比較容易的進行這些數(shù)據(jù)庫升級的適配和管理,這里就要用到oslo_db中的migrate了,這里以為M版本的heat為例,講解一下migrate管理db的原理。

我們使用migrate需要用到的主要包含以下兩部分:1.versions里面的為版本號+數(shù)據(jù)庫適配腳本;2.migrate.cfg為migrate需要用到的配置文件,兩部分的命名是固定的。


使用migrate進行數(shù)據(jù)庫升級非常簡單,heat這邊提供了heat-manage db_sync, db_version的命令用來升級db以及查看當(dāng)前db的版本號,這里以執(zhí)行heat-manages db_sync,看下migrate的過程。



def db_sync(engine, version=None): 
  path = os.path.join(os.path.abspath(os.path.dirname(__file__)), 
            'migrate_repo') 
  return oslo_migration.db_sync(engine, path, version, 
                 init_version=INIT_VERSION) 

heat代碼的入口在這里,需要傳入engine用來連接db,version為我們需要升級到的版本,這里沒有傳,可以看到heat這邊是直接使用oslo_migrate的db_sync方法,我們看下三方庫中的這個方法。

def db_sync(engine, abs_path, version=None, init_version=0, sanity_check=True): 
  """Upgrade or downgrade a database. 
 
  Function runs the upgrade() or downgrade() functions in change scripts. 
 
  :param engine:    SQLAlchemy engine instance for a given database   //連接數(shù)據(jù)庫 
  :param abs_path:   Absolute path to migrate repository.         //migrate倉庫的絕對路徑 
  :param version:   Database will upgrade/downgrade until this version. //需要升級或者降級到的版本號,如果不傳則默認升級到最新版本 
             If None - database will update to the latest 
             available version. 
  :param init_version: Initial database version               //數(shù)據(jù)庫的初始版本號,會以該初始版本為起點升級 
  :param sanity_check: Require schema sanity checking for all tables    //合理性檢查 
  """ 
 
  if version is not None: 
    try: 
      version = int(version) 
    except ValueError: 
      raise exception.DBMigrationError(_("version should be an integer")) 
 
  current_version = db_version(engine, abs_path, init_version) 
  repository = _find_migrate_repo(abs_path) 
  if sanity_check: 
    _db_schema_sanity_check(engine) 
  if version is None or version > current_version: 
    migration = versioning_api.upgrade(engine, repository, version) 
  else: 
    migration = versioning_api.downgrade(engine, repository, 
                       version) 
  if sanity_check: 
    _db_schema_sanity_check(engine) 
 
  return migration 

代碼很清晰,簡潔??梢钥吹?,整個過程就是先查詢下當(dāng)前db的版本,然后聲明一個migrate倉庫示例,對db做合理性檢查(主要是針對mysql),然后根據(jù)傳入的version和當(dāng)前的version決定是升級或者降低,最后再次檢查,整個migrate就完成了。

首先是查詢當(dāng)前數(shù)據(jù)庫的版本,



def db_version(engine, abs_path, init_version): 
  """Show the current version of the repository. 
 
  :param engine: SQLAlchemy engine instance for a given database 
  :param abs_path: Absolute path to migrate repository 
  :param init_version: Initial database version 
  """ 
  repository = _find_migrate_repo(abs_path) 
  try: 
    return versioning_api.db_version(engine, repository) 
  except versioning_exceptions.DatabaseNotControlledError: 
    meta = sqlalchemy.MetaData() 
    meta.reflect(bind=engine) 
    tables = meta.tables 
    if len(tables) == 0 or 'alembic_version' in tables: 
      db_version_control(engine, abs_path, version=init_version) 
      return versioning_api.db_version(engine, repository) 
    else: 
      raise exception.DBMigrationError( 
        _("The database is not under version control, but has " 
         "tables. Please stamp the current version of the schema " 
         "manually.")) 

首先是根據(jù)傳入的絕對路徑,構(gòu)造一個倉庫對象的示例,這里比較關(guān)鍵,初始化方法如下,可以看到我們前面提到migrate.cfg和versions就是在這里被使用的,而且名字也是固定的,必須為migrate.cfg和versions。

class Repository(pathed.Pathed): 
  """A project's change script repository""" 
 
  _config = 'migrate.cfg' 
  _versions = 'versions' 
 
  def __init__(self, path): 
    log.debug('Loading repository %s...' % path) 
    self.verify(path) 
    super(Repository, self).__init__(path) 
    self.config = cfgparse.Config(os.path.join(self.path, self._config)) 
    self.versions = version.Collection(os.path.join(self.path, 
                           self._versions)) 
    log.debug('Repository %s loaded successfully' % path) 
    log.debug('Config: %r' % self.config.to_dict()) 

這里會驗證我們傳入的path下面是否存在versions和migrate.cfg,因此我們的代碼目錄結(jié)構(gòu)也必須按照這個放。self.config主要是用來管理migrate.cfg的配置,self.versions主要用來管理如何升級,repository對象另外還包含3個比較重要的屬性,latest:最新的版本(versions中版本號最大的),這里是73,version_table:用來記錄和管理migrate版本號的數(shù)據(jù)庫表,這里是migrate_version,id用來存放我們管理的數(shù)據(jù)庫標(biāo)示,這里是heat,后兩項都是從數(shù)據(jù)庫里面取。

@property 
  def latest(self): 
    """API to :attr:`migrate.versioning.version.Collection.latest`""" 
    return self.versions.latest 
 
  @property 
  def version_table(self): 
    """Returns version_table name specified in config""" 
    return self.config.get('db_settings', 'version_table') 
 
  @property 
  def id(self): 
    """Returns repository id specified in config""" 
    return self.config.get('db_settings', 'repository_id') 

回到之前的代碼

try: 
  return versioning_api.db_version(engine, repository) 
except versioning_exceptions.DatabaseNotControlledError: 
  meta = sqlalchemy.MetaData() 
  meta.reflect(bind=engine) 
  tables = meta.tables 
  if len(tables) == 0 or 'alembic_version' in tables: 
    db_version_control(engine, abs_path, version=init_version) 
    return versioning_api.db_version(engine, repository) 
  else: 
    raise exception.DBMigrationError( 
      _("The database is not under version control, but has " 
       "tables. Please stamp the current version of the schema " 
       "manually.")) 

這里會根據(jù)數(shù)據(jù)庫引擎和剛才的repository實例對象獲取當(dāng)前數(shù)據(jù)庫的版本號,其實就是從migrate本身所在數(shù)據(jù)表中去查找當(dāng)前的版本號(version_version),假如是第一次使用migrate,由于還沒有建立migrate_version表,所以引發(fā)異常。這里會去查一下當(dāng)前數(shù)據(jù)庫中的所有數(shù)據(jù)表,如果已有其他數(shù)據(jù)庫表,則會引發(fā)DBMigrationError的異常,因為migrate必須在建立其他數(shù)據(jù)表之前先建立才能管控所有的數(shù)據(jù)表,假如我們之前沒有使用migrate機制但是想在后面的db控制中使用起來,這里有2個思路:手動插入migrate_version數(shù)據(jù)表并配置合適的版本或者手動插入alebic_version。

繼續(xù)往下面看,如果是第一次使用migrate,



db_version_control(engine, abs_path, version=init_version) 

會建立migrate_version,并設(shè)置合適的初始值,也就是傳入的init_version,后續(xù)的數(shù)據(jù)庫升級等操作就可以通過migrate管控起來了。migrate_version表建立起來后,就回到了最初的流程,根據(jù)我們db_sync傳入的版本號和當(dāng)前的版本號,migrate會執(zhí)行versions里面每個版本的upgrade()方法直至升級完成并更新migrate_version中的版本號。

  使用migrate的好處在于,可以很方便的集中記錄和管理每次對數(shù)據(jù)庫的變動,在后續(xù)升級過程中,一鍵式完成對應(yīng)的適配操作,非常方便,并且不會出現(xiàn)重復(fù)增加字段等操作,在開發(fā)過程中,我們只要知道了migrate的原理,就能很方便的使用起來了。

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關(guān)文章

  • OpenStack 中的Nova組件詳解

    OpenStack 中的Nova組件詳解

    Nova是OpenStack云中的計算組織控制器。支持OpenStack云中實例(instances)生命周期的所有活動都由Nova處理。本文給大家介紹OpenStack 中的Nova組件,感興趣的朋友一起看看吧
    2016-11-11
  • Fuel 30 分鐘快速安裝OpenStack(圖文教程)

    Fuel 30 分鐘快速安裝OpenStack(圖文教程)

    這篇文章主要介紹了Fuel 30 分鐘快速安裝OpenStack(圖文教程),有興趣的同學(xué)可以了解一下。
    2016-11-11
  • openstack云計算keystone組件工作流程及服務(wù)關(guān)系

    openstack云計算keystone組件工作流程及服務(wù)關(guān)系

    這篇文章主要介紹了openstack云計算keystone組件工作流程及服務(wù)關(guān)系,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-04-04
  • OpenStack虛擬機快照和增量備份實現(xiàn)方法

    OpenStack虛擬機快照和增量備份實現(xiàn)方法

    快照針對要保存的數(shù)據(jù)分為內(nèi)存快照和磁盤快照,內(nèi)存快照就是保存當(dāng)前內(nèi)存的數(shù)據(jù),磁盤快照就是保存硬盤的數(shù)據(jù),這篇文章主要介紹了OpenStack虛擬機快照和增量備份實現(xiàn),需要的朋友可以參考下
    2022-04-04
  • CentOS系統(tǒng)中一鍵安裝Openstack圖文教程

    CentOS系統(tǒng)中一鍵安裝Openstack圖文教程

    最近在學(xué)習(xí)Openstack,一直想試試安裝一下,可是參考了很多資料,并不如人意。由于一直用的Linux版本為CentOS,大部分Openstack安裝都要求在Ubuntu上進行。本文介紹的是在CentOS系統(tǒng)中一鍵安裝Openstack的方法,有需要的朋友們可以參考學(xué)習(xí),下面來一起看看吧。
    2016-10-10
  • openstack云計算keystone架構(gòu)源碼分析

    openstack云計算keystone架構(gòu)源碼分析

    這篇文章主要為大家介紹了openstack云計算keystone架構(gòu)源碼分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-04-04
  • OpenStack Mitaka 版本中的 domain 和 admin詳解

    OpenStack Mitaka 版本中的 domain 和 admin詳解

    這篇文章主要介紹了OpenStack Mitaka 版本中的 domain 和 admin詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-03-03
  • OpenStack初始化淺析

    OpenStack初始化淺析

    OpenStack是一個開源的云計算管理平臺項目,由幾個主要的組件組合起來完成具體工作。OpenStack支持幾乎所有類型的云環(huán)境,項目目標(biāo)是提供實施簡單、可大規(guī)模擴展、豐富、標(biāo)準(zhǔn)統(tǒng)一的云計算管理平臺。
    2017-01-01
  • OpenStack Tempest的正確的打開方式

    OpenStack Tempest的正確的打開方式

    Tempest 是一個旨在為云計算平臺 OpenStack 提供集成測試的開源項目。它是基于 unittest2 和 nose 建立的靈活且易于擴展及維護的自動化測試框架,使得 OpenStack 相關(guān)測試效率得到大幅度提升。
    2017-01-01
  • Openstack安裝過程中遇到的問題匯總

    Openstack安裝過程中遇到的問題匯總

    本文給大家分享的是作者在Centos7中安裝openstack過程中出現(xiàn)的一些問題的匯總,以及解決的方法,有需要的小伙伴可以參考下
    2017-04-04

最新評論