文章详情页
redis - 如何给轻量python程序、脚本制作缓存?
浏览:152日期:2022-06-30 14:23:37
问题描述
运维菜鸟,最近在做公司日志进行简单处理之后,按一定数量加入一个list,然后使用ES的接口将数据批量添加到另外一台ElasticSearch上,再通过一些方式进行展示。这里遇到一个问题,如果数据插入时,发生异常。比如要插入的es主机崩溃等,但是数据源没有问题。这样就应该把已经处理完的数据移到缓存中,然后停止程序。(数据源是kafka,即便停止了程序,重新启动后仍可以消费之前没有消费的)那么想问一下,对于比较轻量的python程序或者脚本,应该使用怎样的方式存储这些异常状况发生时要先存储下来的数据呢?
问题解答
回答1:可以在es异常时, py脚本捕获到异常后, 使用cPickle或者pickle 将处理好的数据序列化后保存到一个文件上(你可以理解成写入一个文件, 不同在于cPickle和pickle能够将字典或者列表这样的对象直接写入文件), 然后等你es恢复了, 重新启动该py脚本, 那么该脚本优先去检测是否存在这个临时文件, 如果有, 并非空, 则把里面的数据取出, 写入es
上一条:python函数根据概率返回值下一条:两个python的语法问题
相关文章:
1. android - 为 AppBarLayout 设置的背景图片 TransitionDrawable 为什么只在第一次打开的时候有效?2. nginx - 关于javaweb项目瘦身问题,前期开发后,发现项目占用存贮空间太大,差不多1.2个G,怎么实现瘦身,动态页面主要是jsp。3. java - 请教一个IO的问题4. java - 一个泛型标签问题5. 这是什么问题6. jquery - 移动端如何写弹性效果7. 不知道原因是啥8. node.js - 问个问题 Uncaught (in promise)9. node.js - 安装puer前端服务器不成功10. 这一年从入门到认识PHP的过程
排行榜

网公网安备