1. 程式人生 > 程式設計 >python 動態渲染 mysql 配置檔案的示例

python 動態渲染 mysql 配置檔案的示例

背景

前段時間寫了一個自動化安裝 MySQL 的程式,其中有一個環節就是動態的渲染 my.cnf 檔案;總的解決方案就是像 Django 渲染 html 頁面一樣,用渲染模板的方式來解決。

[mysqld]
basedir = {{basedir}}
datadir = {{datadir}}
port  = {{port}}
user  = {{user}}

python 動態渲染 mysql 配置檔案的示例

程式碼實現

我在渲染引擎的選擇上使用了 jinja2 這個模板引擎,去掉其它邏輯一個最小化的程式碼如下。

#!/usr/bin/env python3

from jinja2 import Environment,FileSystemLoader

def render_mysql_config_file():
  #通過檔案系統載入器,載入當前目錄下的 my.cnf.jinja 模板檔案
  env = Environment(loader=FileSystemLoader(searchpath='./'))
  tmpl = env.get_template('my.cnf.jinja')
  #給要渲染的引數指定值
  cnfs = {
    'basedir': '/usr/local/mysql/','datadir': '/database/mysql/data/3306/','port': 3306,'user'; 'mysql3306'
  }

  tmpl.globals=cnfs
  #不儲存到 /etc/my.cnf 了,直接輸出到 stdout
  print(tmpl.render())

if __name__ == "__main__":
  render_mysql_config_file()

執行效果如下

python3 cnfs.py 
[mysqld]
basedir = /usr/local/mysql/
datadir = /database/mysql/data/3306/
port  = 3306
user  = mysql3306

總結

通過模板引擎渲染 my.cnf 只要專引數就行了,非常的方便。

以上就是python 動態渲染 mysql 配置檔案的示例的詳細內容,更多關於python 動態渲染配置檔案的資料請關注我們其它相關文章!