python 动态渲染 mysql 配置文件的示例
(编辑:jimmy 日期: 2024/11/2 浏览:3 次 )
背景
前段时间写了一个自动化安装 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 动态渲染配置文件的资料请关注其它相关文章!
下一篇:接口自动化多层嵌套json数据处理代码实例