python 动态渲染 mysql 配置文件的示例

时间:2021-05-22

背景

前段时间写了一个自动化安装 MySQL 的程序,其中有一个环节就是动态的渲染 my.cnf 文件;总的解决方案就是像 Django 渲染 html 页面一样,用渲染模板的方式来解决。

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

代码实现

我在渲染引擎的选择上使用了 jinja2 这个模板引擎,去掉其它逻辑一个最小化的代码如下。

#!/usr/bin/env python3from jinja2 import Environment,FileSystemLoaderdef 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 = 3306user = mysql3306

总结

通过模板引擎渲染 my.cnf 只要专参数就行了,非常的方便。

以上就是python 动态渲染 mysql 配置文件的示例的详细内容,更多关于python 动态渲染配置文件的资料请关注其它相关文章!

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章