python 動(dòng)態(tài)渲染 mysql 配置文件的示例
背景
前段時(shí)間寫了一個(gè)自動(dòng)化安裝 MySQL 的程序,其中有一個(gè)環(huán)節(jié)就是動(dòng)態(tài)的渲染 my.cnf 文件;總的解決方案就是像 Django 渲染 html 頁面一樣,用渲染模板的方式來解決。
[mysqld]
basedir = {{basedir}}
datadir = {{datadir}}
port = {{port}}
user = {{user}}

代碼實(shí)現(xiàn)
我在渲染引擎的選擇上使用了 jinja2 這個(gè)模板引擎,去掉其它邏輯一個(gè)最小化的代碼如下。
#!/usr/bin/env python3
from jinja2 import Environment,FileSystemLoader
def render_mysql_config_file():
#通過文件系統(tǒng)加載器,加載當(dāng)前目錄下的 my.cnf.jinja 模板文件
env = Environment(loader=FileSystemLoader(searchpath='./'))
tmpl = env.get_template('my.cnf.jinja')
#給要渲染的參數(shù)指定值
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()
運(yùn)行效果如下
python3 cnfs.py
[mysqld] basedir = /usr/local/mysql/ datadir = /database/mysql/data/3306/ port = 3306 user = mysql3306
總結(jié)
通過模板引擎渲染 my.cnf 只要專參數(shù)就行了,非常的方便。
以上就是python 動(dòng)態(tài)渲染 mysql 配置文件的示例的詳細(xì)內(nèi)容,更多關(guān)于python 動(dòng)態(tài)渲染配置文件的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
OpenCV+python實(shí)現(xiàn)實(shí)時(shí)目標(biāo)檢測功能
這篇文章主要介紹了OpenCV+python實(shí)現(xiàn)實(shí)時(shí)目標(biāo)檢測功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06
Windows下安裝python MySQLdb遇到的問題及解決方法
這篇文章主要介紹了Windows下安裝python MySQLdb遇到的問題及解決方法,需要的朋友可以參考下2017-03-03
PyQt5實(shí)現(xiàn)QLineEdit添加clicked信號(hào)的方法
今天小編就為大家分享一篇PyQt5實(shí)現(xiàn)QLineEdit添加clicked信號(hào)的方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-06-06
Python使用正則表達(dá)式實(shí)現(xiàn)爬蟲數(shù)據(jù)抽取
這篇文章主要介紹了Python使用正則表達(dá)式實(shí)現(xiàn)爬蟲數(shù)據(jù)抽取,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08

