您的位置:首页技术文章
文章详情页

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

【字号: 日期:2022-07-04 16:27:23浏览:4作者:猪猪

背景

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

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

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

代码实现

我在渲染引擎的选择上使用了 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 动态渲染配置文件的资料请关注好吧啦网其它相关文章!

标签: Python 编程
相关文章: