python 動(dòng)態(tài)渲染 mysql 配置文件的示例
背景
前段時(shí)間寫了一個(gè)自動(dòng)化安裝 MySQL 的程序,其中有一個(gè)環(huán)節(jié)就是動(dòng)態(tài)的渲染 my.cnf 文件;總的解決方案就是像 Django 渲染 html 頁(yè)面一樣,用渲染模板的方式來(lái)解決。
[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(): #通過(guò)文件系統(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é)
通過(guò)模板引擎渲染 my.cnf 只要專參數(shù)就行了,非常的方便。
以上就是python 動(dòng)態(tài)渲染 mysql 配置文件的示例的詳細(xì)內(nèi)容,更多關(guān)于python 動(dòng)態(tài)渲染配置文件的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
詳解Python的hasattr() getattr() setattr() 函數(shù)使用方法
這篇文章主要介紹了詳解Python的hasattr() getattr() setattr() 函數(shù)使用方法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-07-07Python中對(duì)元組和列表按條件進(jìn)行排序的方法示例
這篇文章主要介紹了Python中對(duì)元組和列表按條件進(jìn)行排序的方法示例,需要的朋友可以參考下2015-11-11對(duì)Python中g(shù)ensim庫(kù)word2vec的使用詳解
今天小編就為大家分享一篇對(duì)Python中g(shù)ensim庫(kù)word2vec的使用詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-05-05Python實(shí)現(xiàn)識(shí)別手寫數(shù)字大綱
這篇文章主要為大家詳細(xì)介紹了Python實(shí)現(xiàn)識(shí)別手寫數(shù)字的大綱,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01Python提取轉(zhuǎn)移文件夾內(nèi)所有.jpg文件并查看每一幀的方法
今天小編就為大家分享一篇Python提取轉(zhuǎn)移文件夾內(nèi)所有.jpg文件并查看每一幀的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-06-06python使用BeautifulSoup與正則表達(dá)式爬取時(shí)光網(wǎng)不同地區(qū)top100電影并對(duì)比
這篇文章主要給大家介紹了關(guān)于python使用BeautifulSoup與正則表達(dá)式爬取時(shí)光網(wǎng)不同地區(qū)top100電影并對(duì)比的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用python具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04Python模塊學(xué)習(xí)之struct模塊詳解
這篇文章主要介紹了Python模塊學(xué)習(xí)之struct模塊詳解,該模塊作用是完成Python數(shù)值和C語(yǔ)言結(jié)構(gòu)體的Python字符串形式間的轉(zhuǎn)換,這可以用于處理存儲(chǔ)在文件中或從網(wǎng)絡(luò)連接中存儲(chǔ)的二進(jìn)制數(shù)據(jù),以及其他數(shù)據(jù)源,需要的朋友可以參考下2023-07-07利用Python繪制MySQL數(shù)據(jù)圖實(shí)現(xiàn)數(shù)據(jù)可視化
這篇文章主要介紹了利用Python繪制MySQL數(shù)據(jù)圖實(shí)現(xiàn)數(shù)據(jù)可視化,其中包括Python與MySQL的連接搭建、用Python執(zhí)行MySQL語(yǔ)句查詢等內(nèi)容,需要的朋友可以參考下2015-03-03