广告
返回顶部
首页 > 资讯 > 数据库 >Python操作ES的方式及与Mysql数据同步的方法
  • 956
分享到

Python操作ES的方式及与Mysql数据同步的方法

2023-06-30 05:06:33 956人浏览 独家记忆
摘要

这篇文章主要介绍了python操作ES的方式及与Mysql数据同步的方法的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Python操作ES的方式及与Mysql数据同步的方法文章都会有所收获,下面我们一起来看看吧

这篇文章主要介绍了python操作ES的方式及与Mysql数据同步的方法的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Python操作ES的方式及与Mysql数据同步的方法文章都会有所收获,下面我们一起来看看吧。

Python操作elasticsearch的两种方式

# 官方提供的:Elasticsearch# pip install elasticsearch# GUI:pyhon能做图形化界面编程吗?-Tkinter  -pyQt# 使用(查询是重点)# pip3 install elasticsearchhttps://GitHub.com/elastic/elasticsearch-pyfrom elasticsearch import Elasticsearchobj = Elasticsearch(['127.0.0.1:9200','192.168.1.1:9200','192.168.1.2:9200'],)# 创建索引(Index)# body:用来干什么?mapping:{},setting:{}# result = obj.indices.create(index='user',ignore=400)# print(result)# 删除索引# result = obj.indices.delete(index='user', ignore=[400, 404])# 插入和查询数据(文档的增删查改),是最重要# 插入数据# POST news/politics/1# {'userid': '1', 'username': 'lqz','passWord':'123'}# data = {'userid': '1', 'username': 'lqz','password':'123'}# result = obj.create(index='news', doc_type='politics', id=1, body=data)# print(result)# 更新数据'''不用doc包裹会报错ActionRequestValidationException[Validation Failed: 1: script or doc is missing'''# data ={'doc':{'userid': '1', 'username': 'lqz','password':'123ee','test':'test'}}# result = obj.update(index='news', doc_type='politics', body=data, id=1)# print(result)# 删除数据# result = obj.delete(index='news', doc_type='politics', id=1)# 查询# 查找所有文档# query = {'query': {'match_all': {}}}#  查找名字叫做jack的所有文档# query = {'query': {'match': {'desc': '娇憨可爱'}}}# query = {'query': {'term': {'from': 'sheng'}}}query = {'query': {'term': {'name': '娘子'}}}# term和match的区别# term是短语查询,不会对term的东西进行分词# match 会多match的东西进行分词,再去查询# 查找年龄大于11的所有文档# allDoc = obj.search(index='lqz', doc_type='doc', body=query)allDoc = obj.search(index='lqz', doc_type='doc', body=query)print(allDoc)import JSONprint(json.dumps(allDoc))# print(allDoc['hits']['hits'][0]['_source'])# 如何集成到Django项目中:创建索引,提前创建好就行了# 插入数据,查询数据,修改数据# query = {'query': {'term': {'name': '娘子'}}}# allDoc = obj.search(index='lqz', doc_type='doc', body=query)# json格式直接返回# saas :软件即服务,不是用人家服务,而是写服务给别人用----》正常的开发# 舆情监测系统:(爬虫)# 只监控微博---》宜家:微博,百度贴吧,上市公司# 公安:负面的,---》追踪到哪个用户发的---》找上门了# qq群,微信群----》舆情监控(第三方做不了,腾讯出的舆情监控,第三方机构跟腾讯合作,腾讯提供接口,第三方公司做)# 平台开发出来,别人买服务---》买一年的微博关键字监控

ERP:公司财务,供应链

某个大公司,金蝶,用友,开发了软件----》你们公司自己买服务器---》软件跑在你服务器
saas模式:公司买服务,10年服务----》账号密码---》登进去就能操作---》出了问题找用友---》服务器在别人那---》政务云,各种云---所有东西上云

---政府花钱买的东西---》用友敢泄露吗?
---未来的云计算---》只能能上网---》计算机运算能力有限---》上云买服务---》计算1+。。。+100  ---》买了计算服务,直接拿到结果 

# 第二种使用方式# Https://github.com/elastic/elasticsearch-dsl-py# pip3 install elasticsearch-dslfrom datetime import datetimefrom elasticsearch_dsl import Document, Date, Nested, Boolean,analyzer, InnerDoc, Completion, Keyword, Text,Integerfrom elasticsearch_dsl.connections import connectionsconnections.create_connection(hosts=["localhost"])class Article(Document):    title = Text(analyzer='ik_max_word', search_analyzer="ik_max_word", fields={'title': Keyword()})    author = Text()    class Index:        name = 'myindex'  # 索引名    def save(self, ** kwargs):        return super(Article, self).save(** kwargs)if __name__ == '__main__':    # Article.init()  # 创建映射    # 保存数据    # article = Article()    # article.title = "测试数据"    # article.author = "eGon"    # article.save()  # 数据就保存了    #查询数据    # s=Article.search()    # s = s.filter('match', title="测试")    # results = s.execute()    # # 类比queryset对象,列表中一个个对象    # # es中叫Response,当成一个列表,列表中放一个个对象    # print(results)    #删除数据    # s = Article.search()    # s = s.filter('match', title="测试").delete()    #修改数据    s = Article().search()    s = s.filter('match', title="测试")    results = s.execute()    print(results[0])    results[0].title="xxx"    results[0].save()    # 其他操作,参见文档

mysql和Elasticsearch同步数据

# 只要article表插入一条数据,就自动同步到es中# 第一种方案:-每当aritcle表插入一条数据(视图类中,Article.objects.create(),update)  -往es中插入一条  -缺陷:代码耦合度高,改好多地方# 第二种方案:-重写create方法,重写update方法  -缺陷:同步操作---》es中插入必须返回结果才能继续往下走# 第三种方案:-用celery,做异步  -缺陷:引入celery,还得有消息队列。。。# 第四种方案:(用的最多)-重写create方法,重写update方法,用信号存入,异步操作  -缺陷:有代码侵入# 第五种方案:(项目不写代码,自动同步),第三方开源插件-https://github.com/siddontang/go-mysql-elasticsearch----go写  -你可以用python重写一个,放到git上给别人用(读了mysql的日志)  -跟平台无关,跟语言无关  -如何使用:  -源码下载---》交叉编译---》可执行文件--》运行起来--》配置文件配好,就完事了    # 配置文件    [[source]]    schema = "数据库名"    tables = ["article"]    [[rule]]    schema = "数据库名"    table = "表明"    index = "索引名"    type = "类型名"  # 缺陷:  -es跟mysql同步时,不希望把表所有字段都同步,mysql的多个表对着es的一个类型  # 话术升级:  -一开始同步    -用了开源插件(读取mysql日志,连接上es,进行同步)    -用信号自己写的    -再高端:仿着他的逻辑,用python自己写的,----》(把这个东西开源出来)

haystack的使用

  • django上的一个第三方模块 ---》你使用过的django第三方模块有哪些?

  • 可以在django上实现全文检索

  • 相当于ORM--》对接es,solr,whoosh

  • https://www.yisu.com/article/218631.htm

  • 不支持es,6以上版本

  • haystack+Elasticsearch实现全文检索

  • es的原生操作:ELasticsearch   Elasticsearch-dsl

Redis补充

#1  只有5种数据结构:-多种数据结构:字符串,hash,列表,集合,有序集合#2  单线程,速度为什么这么快?  -本质还是因为是内存数据库  -epoll模型(io多路复用)  -单线程,没有线程,进程间的通信#3 linux上 安装Redis#下载  https://redis.io/download/  #解压  tar -xzf redis-5.0.7.tar.gz  #建立软连接  ln -s redis-5.0.7 redis  cd redis  make&&make install  # bin路径下几个命令:redis-cli,redis-server,redis-sentinel  # 在任意位置能够执行redis-server 如何做?配置环境变量#4  启动redis的三种方式  -方式一:(一般不用,没有配置文件)    -redis-server    -方式二:(用的也很少)    redis-serve --port 6380    -方式三:(都用这种,配置文件)    daemonize yes #是否以守护进程启动      pidfile /var/run/redis.pid   #进程号的位置,删除      port 6379    #端口号      dir "/opt/soft/redis/data"  #工作目录      logfile 6379.log #日志位置        # 启动:redis-server redis.conf1#5 客户端连接  redis-cli -h 127.0.0.1 -p 6379#6 使用场景  -看md文档

关于“Python操作ES的方式及与Mysql数据同步的方法”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“Python操作ES的方式及与Mysql数据同步的方法”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网数据库频道。

您可能感兴趣的文档:

--结束END--

本文标题: Python操作ES的方式及与Mysql数据同步的方法

本文链接: https://www.lsjlt.com/news/327559.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Python操作ES的方式及与Mysql数据同步的方法
    这篇文章主要介绍了Python操作ES的方式及与Mysql数据同步的方法的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Python操作ES的方式及与Mysql数据同步的方法文章都会有所收获,下面我们一起来看看吧...
    99+
    2023-06-30
  • Python操作ES的方式及与Mysql数据同步过程示例
    目录Python操作Elasticsearch的两种方式mysql和Elasticsearch同步数据haystack的使用Redis补充Python操作Elasticsearch的...
    99+
    2022-11-13
  • 【ElasticSearch】ES与MySQL数据同步方案及Java实现
    文章目录 一、同步实现思路1、方案一:同步调用2、方案二:异步通知3、方案三:监听binlog 二、实现ES与MySQL数据同步1、导入hotel-admin工程2、项目分析3、SpringAMQP整合4、声明队列和交换机5、发...
    99+
    2023-08-30
    elasticsearch mysql java
  • PostgreSql与es的数据同步方案调研
    logstash 基于时间戳,或者id增量同步,且不能实时同步暂不考虑 pg-es-fdw   https://github.com/Mikulas/pg-es-fdwspm=a2c4e.10696291.0.0.4c7b19a49s...
    99+
    2021-04-29
    PostgreSql与es的数据同步方案调研
  • MySQL数据同步到ES的4种解决方案
    一、背景 大家应该都在各种电商网站检索过商品,检索商品一般都是通过什么实现呢?搜索引擎Elasticsearch。那么问题来了,商品上架,数据一般写入到MySQL的数据库中,那么用于检索的数据又是怎么同步到Elasticsearch的呢? ...
    99+
    2023-09-06
    intellij-idea java ide mysql 数据库
  • 配置mysql数据库主从同步交互式的操作方法
    下面一起来了解下配置mysql数据库主从同步交互式的操作方法,相信大家看完肯定会受益匪浅,文字在精不在多,希望配置mysql数据库主从同步交互式的操作方法这篇短内容是你想要的。一.my.cnf文件配置1.修...
    99+
    2022-10-18
  • 与第三方应用的数据库同步数据的方式
    与第三方应用的数据库同步数据的方式,抛开第三方开源服务和自编码java实现,仅从数据库层面考虑: ...
    99+
    2022-10-18
  • MySQL数据库的同步配置方法
    本篇内容主要讲解“MySQL数据库的同步配置方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL数据库的同步配置方法”吧!   &n...
    99+
    2022-10-18
  • docker实现MySQL数据同步的方法
    大家好,今天分享一下docker的一个实战 我们使用docker 实现MySQL 的数据同步 搜索mysql 镜像 [root@localhost ~]# docker search...
    99+
    2022-11-13
  • Java线程状态及同步锁的操作方法
    线程的生命历程 线程的五大状态 创建状态:简而言之,当创建线程对象的代码出现的时候,此时线程就进入了创建状态。这时候的线程只是行代码而已。只有调用线程的start()方法时...
    99+
    2022-11-12
  • python操作mysql数据库的方法介绍
    下面讲讲关于python操作mysql数据库的方法,文字的奥妙在于贴近主题相关。所以,闲话就不谈了,我们直接看下文吧,相信看完python操作mysql数据库的方法这篇文章你一定会有所受益。 &n...
    99+
    2022-10-18
  • 使用mongoshake实现mongodb数据同步的操作方法
    目录前言使用场景搭建步骤环境准备一、搭建mongodb复制集二、mongoshake配置前言 MongoShake是阿里云以Golang语言编写的通用平台型服务工具,它通过读取Mon...
    99+
    2022-11-13
  • MySQL数据库的备份与还原操作方法
    目录1、数据库备份2、数据还原1、数据库备份 备份的结果都是SQL指令 mysqldump:专门用于备份SQL的客户端 SQL备份:表结构 + 数据 缺点: 会产生的备份文件特别大不...
    99+
    2022-11-13
  • 同步MySQL数据至Elasticsearch的方式有哪些
    这篇文章主要介绍了同步MySQL数据至Elasticsearch的方式有哪些的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇同步MySQL数据至Elasticsearch的方式有哪些文章都会有所收获,下面我们一起...
    99+
    2023-06-05
  • python操作 hbase 数据的方法
    配置 thrift python使用的包 thrift 个人使用的python 编译器是pycharm community edition. 在工程中设置中,找到project interpreter, 在...
    99+
    2022-06-04
    操作 方法 数据
  • ASP中同步数组的操作方法及应用场景解析。
    ASP中同步数组的操作方法及应用场景解析 在ASP编程中,数组是一种非常常见的数据类型。数组是由一系列相同类型的元素组成的集合,这些元素可以按照一定的顺序访问。数组的使用可以使程序的编写更加简单、清晰,也可以提高程序的运行效率。然而,在实际...
    99+
    2023-11-04
    同步 数组 教程
  • pymysql操作mysql数据库的方法
    目录前言1、pymysql.connent2、conn.cursor()3、cursor.execute()4、cursor.executemany()5、cursor.fetchone()6、cursor.scroll...
    99+
    2023-04-19
    pymysql操作mysql数据库 pymysql操作mysql
  • MySQL数据库主从同步的实现方法
    这篇文章主要讲解了MySQL数据库主从同步的实现方法,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。安装环境说明系统环境:[root@~]# cat /etc/redhat-re...
    99+
    2022-10-18
  • Swoole和Workerman对PHP与MySQL的数据镜像和数据同步的优化方法
    概述:在现代应用程序开发中,数据的镜像和同步是至关重要的。特别是在PHP与MySQL的组合中,如何有效地进行数据镜像和数据同步,成为了一个关键问题。本文将介绍如何使用Swoole和Workerman来实现对PHP与MySQL的数据镜像和数据...
    99+
    2023-10-21
    swoole 数据同步 Workerman
  • python 操作sqlite数据库的方法
    目录前言简单介绍创建或连接数据库游标创建表插入查询查询总数查询所有查询第一条分页查询更新删除总结前言 sqlite的官网 sqlite.org/index.html SQLite 作为一个SQL数据库引擎,是由C语...
    99+
    2022-06-02
    python 操作sqlite python 操作数据库
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作