时间: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邮箱联系删除。
mysql之通过配置文件链接数据库配置文件jdbc.properties##MySQLdriver=com.mysql.jdbc.Driverurl=jdbc\
相对于其他方法实现MySQL的读写分离来说,采用Thinkphp框架实现MySQL的读写分离简单易用,其配置文件示例代码如下:'DB_TYPE'=>'mysql
1、关于#{}占位符先来看以下的示例,该示例是MyBatis中的SQL映射配置文件(Mapper配置文件),在该配置中使用了#{}占位符。SELECT*FROM
python配置文件有.conf,.ini,.txt等多种python集成的标准库的ConfigParser模块提供一套API来读取和操作配置文件我的配置文件如
设置mysql服务允许外网访问,修改mysql的配置文件,有的是my.ini,有的是my.cnf【linux】.1:设置mysql的配置文件/etc/mysql