如何解决SaltStack:MySQL 返回器将较少的数据保存到数据库表列中
我正在尝试修改现有的 SaltStack MySQL 返回器以仅保存少量数据而不是默认列
(| fun | jid | return | id | success | full_ret)
之类的
(| fun | jid | return | id | success)
我正在处理的文件是这样的: https://github.com/saltstack/salt/blob/master/salt/returners/mysql.py
我安装了这个 python 模块 python3-mysqldb
以便 Salt 可以与 MySQL v8.0.25 通信
我修改的部分(313行)
try:
with _get_serv(ret,commit=True) as cur:
sql = """INSERT INTO `salt_returns`
(`fun`,`jid`,`id`,`success`)
VALUES (%s,%s,%s)"""
但是我在运行类似的东西时遇到这个错误
salt '*' test.ping --return mysql
Traceback (most recent call last):
File "/usr/lib/python3/dist-packages/MySQLdb/cursors.py",line 238,in execute
query = query % args
TypeError: not all arguments converted during string formatting
During handling of the above exception,another exception occurred:
Traceback (most recent call last):
File "/usr/lib/python3/dist-packages/salt/minion.py",line 2044,in _thread_return
minion_instance.returners[returner_str](ret)
File "/usr/lib/python3/dist-packages/salt/loader.py",line 1235,in __call__
return self.loader.run(run_func,*args,**kwargs)
File "/usr/lib/python3/dist-packages/salt/loader.py",line 2268,in run
return self._last_context.run(self._run_as,_func_or_method,line 2283,in _run_as
return _func_or_method(*args,**kwargs)
File "/usr/lib/python3/dist-packages/salt/returners/mysql.py",line 327,in returner
salt.utils.json.dumps(ret),File "/usr/lib/python3/dist-packages/MySQLdb/cursors.py",line 240,in execute
self.errorhandler(self,ProgrammingError,str(m))
File "/usr/lib/python3/dist-packages/MySQLdb/connections.py",line 52,in defaulterrorhandler
raise errorclass(errorvalue)
_mysql_exceptions.ProgrammingError: not all arguments converted during string formatting
我猜这归结为表中每一列的定义方式,但我不确定在何处进行进一步修改以仅在这些列中写入数据。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。