python 動態渲染 mysql 配置檔案的示例
阿新 • • 發佈:2020-11-23
背景
前段時間寫了一個自動化安裝 MySQL 的程式,其中有一個環節就是動態的渲染 my.cnf 檔案;總的解決方案就是像 Django 渲染 html 頁面一樣,用渲染模板的方式來解決。
[mysqld] basedir = {{basedir}} datadir = {{datadir}} port = {{port}} user = {{user}}
程式碼實現
我在渲染引擎的選擇上使用了 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 動態渲染配置檔案的資料請關注我們其它相關文章!