当前位置: 首页 > news >正文

版式设计素材网站搜索引擎推广简称

版式设计素材网站,搜索引擎推广简称,室内设计网站都有哪些公司,武汉网站建设公司027Tangseng 基于Go语言的搜索引擎 github地址:https://github.com/CocaineCong/tangseng 详细介绍地址:https://cocainecong.github.io/tangseng 这两周我也抽空录成视频发到B站的~ 本来应该10月份就要发了,结果一鸽就鸽到现在hh…

Tangseng 基于Go语言的搜索引擎

github地址:https://github.com/CocaineCong/tangseng

详细介绍地址:https://cocainecong.github.io/tangseng

这两周我也抽空录成视频发到B站的~ 本来应该10月份就要发了,结果一鸽就鸽到现在hhhh,有兴趣的同学也可留意一下~

项目大体框架

  1. gin作为http框架,grpc作为rpc框架,etcd作为服务发现。
  2. 总体服务分成用户模块收藏夹模块索引平台搜索引擎(文字模块)搜索引擎(图片模块)。注册到etcd中,并进行服务发现。
  3. 分布式爬虫爬取数据,并发送到kafka集群中,再落库消费。现阶段使用数据集文本输入 (虽然爬虫还没写,但不妨碍我画饼…)
  4. 搜索引擎模块的文本搜索单独设立使用boltdb存储index,mapreduce+kafka集群加速索引构建并使用roaring bitmap存储索引。
  5. 使用 trie tree 实现词条联想。
  6. 图片搜索使用ResNet50来进行向量化查询 + Milvus or Faiss 向量数据库的查询 (开始做了… DeepLearning也太难了…)。
  7. 支持多路召回,go中进行倒排索引召回,python进行向量召回。通过grpc调用连接,进行融合。
  8. 支持TF-IDF,BM25等等算法排序。
  9. 第三方容器纯docker拉取启动。

在这里插入图片描述

🧑🏻‍💻 前端地址

all in react, but still coding react-tangseng

由于我真的不怎么会写前端,前端大佬别骂了…这里就放两个页面…

搜索页面
在这里插入图片描述
搜索结果页面

在这里插入图片描述

🌈 项目主要功能

1. 用户模块

  • 登录注册

2. 收藏夹模块

  • 创建/更新/删除/展示 收藏夹
  • 将搜索结果的url进行收藏夹的创建/删除/展示

3. 索引平台

3.1 文本存储

正排库

目前存放在mysql中,但后续会放到OLAP,starrocks可以承受单表亿级数据毫秒级查询,像mysql这种OLTP到这个级别早就分库分表了,不然这张表或者这个库就废了,索引页也救不活…

倒排库

x.inverted 存储倒排索引文件
x.trie_tree 存储词典trie树

目前使用 mapreduce+kafka 集群 来构建倒排索引

在这里插入图片描述

  • map任务将数据拆分以下形式
{"token":"xxx","doc_id":1
}
  • reduce任务将所有相同 token 的 doc_id 合并在一起

存储doc id使用roaring bitmap这种数据结构来存储,尽可能的压缩空间

在索引平台中,离线构建的倒排索引会进行合并操作

  • 每天产生的数据将存放同一个文件中. eg: 2023-10-03.inverted
  • 每周的周日会将这一周的数据都合并到当月中. eg: 2023-10.inverted
  • 每月的最后一天会把该月合并到该季度中. eg: 2023-Autumn.inverted
向量库

向量库采用milvus来存储向量信息,这部分逻辑是放在python的,因为文本向量化基本都是python垄断

4. 搜索模块

4.1 文本搜索

  • 倒排召回

因为 boltdb 是kv数据库,所以直接获取所有的对应的query对应的 doc id 即可,这部分使用的是golang实现的,并提供了grpc接口。

  • 向量召回

query向量化,并从milvus中查询获取,这部分使用的python实现,并提供了grpc接口。

  • 融合

将倒排和向量两个纬度的索引信息召回进行融合。

  • 排序

bm25进行排序

4.2 图片搜索(待定…)

  • resnet50 模型召回

在这里插入图片描述

✨ 项目结构

1.tangseng 项目总体

tangseng/
├── app                   // 各个微服务
│   ├── favorite          // 收藏夹
│   ├── gateway           // 网关
│   ├── index_platform    // 索引平台
│   ├── mapreduce         // mapreduce 服务(已弃用)
│   ├── gateway           // 网关
│   ├── search_engine     // 搜索微服务(文本)
│   ├── search_vector     // 向量搜索微服务(图片+向量)
│   └── user              // 用户模块微服务
├── bin                   // 编译后的二进制文件模块
├── config                // 配置文件
├── consts                // 定义的常量
├── doc                   // 接口文档
├── idl                   // protoc文件
│   └── pb                // 放置生成的pb文件
├── loading               // 全局的loading,各个微服务都可以使用的工具
├── logs                  // 放置打印日志模块
├── pkg                   // 各种包
│   ├── bloom_filter      // 布隆过滤器
│   ├── clone             // 复制context,防止context cancel
│   ├── ctl               // 用户信息相关
│   ├── discovery         // etcd服务注册、keep-alive、获取服务信息等等
│   ├── fileutils         // 文件操作相关
│   ├── es                // es 模块
│   ├── jwt               // jwt鉴权
│   ├── kfk               // kafka 生产与消费
│   ├── logger            // 日志
│   ├── mapreduce         // mapreduce服务
│   ├── res               // 统一response接口返回
│   ├── retry             // 重试函数
│   ├── timeutil          // 时间处理相关
│   ├── trie              // 前缀树
│   ├── util              // 各种工具、处理时间、处理字符串等等..
│   └── wrappers          // 熔断
├── repository            // 放置打印日志模块
│   ├── mysql             // mysql 全局数据库
│   ├── redis             // redis 全局数据库
│   └── vector            // 向量数据库
└── types                 // 定义各种结构体

2.gateway 网关部分

gateway/
├── cmd                   // 启动入口
├── internal              // 业务逻辑(不对外暴露)
│   ├── handler           // 视图层
│   └── service           // 服务层
│       └── pb            // 放置生成的pb文件
├── logs                  // 放置打印日志模块
├── middleware            // 中间件
├── routes                // http 路由模块
└── rpc                   // rpc 调用

3.user && favorite 用户与收藏夹模块

user/
├── cmd                   // 启动入口
└── internal              // 业务逻辑(不对外暴露)├── service           // 业务服务└── repository        // 持久层└── db            // db模块├── dao       // 对数据库进行操作└── model     // 定义数据库的模型

4. index platform索引平台

seach-engine/
├── analyzer              // 分词器
├── cmd                   // 启动入口
├── consts                // 放置常量
├── crawl                 // 分布式爬虫
├── input_data            // csv文件(爬虫未实现)
├── respository           // 存储信息
│   ├── spark             // spark 存储,后续支持...
│   └── storage           // boltdb 存储(后续迁到spark)
├── service               // 服务
└── trie                  // 存放trie树

5.search-engine 搜索引擎模块

seach-engine/
├── analyzer              // 分词器
├── cmd                   // 启动入口
├── data                  // 数据层
├── ranking               // 排序器
├── respository           // 存储信息
│   ├── spark             // spark 存储,后续支持...
│   └── storage           // boltdb 存储(后续迁到spark)
├── service               // 服务
├── test                  // 测试文件
└── types                 // 定义的结构体

这里只是对tangseng的简单介绍而已~,具体可以查看github链接 tangseng搜索引擎

另外lotusdblabs 社区也开源了一个 lotusearch 搜索引擎,有兴趣同学可以瞅瞅~


文章转载自:
http://dinncocombustion.zfyr.cn
http://dinncopampered.zfyr.cn
http://dinncotupelo.zfyr.cn
http://dinncodhol.zfyr.cn
http://dinncoisocaloric.zfyr.cn
http://dinncodiarchy.zfyr.cn
http://dinncoreside.zfyr.cn
http://dinncoraiser.zfyr.cn
http://dinncoabstrusely.zfyr.cn
http://dinncounhonored.zfyr.cn
http://dinncovideogenic.zfyr.cn
http://dinncosphenoid.zfyr.cn
http://dinnconethermore.zfyr.cn
http://dinncofretted.zfyr.cn
http://dinncongoma.zfyr.cn
http://dinncoteletype.zfyr.cn
http://dinncopolygamical.zfyr.cn
http://dinncolewes.zfyr.cn
http://dinncoarabica.zfyr.cn
http://dinncofrenchify.zfyr.cn
http://dinncoisolex.zfyr.cn
http://dinncoobliviscence.zfyr.cn
http://dinnconegotiant.zfyr.cn
http://dinncosport.zfyr.cn
http://dinncotunicate.zfyr.cn
http://dinncocriminology.zfyr.cn
http://dinncoagglomerative.zfyr.cn
http://dinncocallboard.zfyr.cn
http://dinncocontranatant.zfyr.cn
http://dinncoillness.zfyr.cn
http://dinncopaunchy.zfyr.cn
http://dinncoaerodrome.zfyr.cn
http://dinncoforetime.zfyr.cn
http://dinncopob.zfyr.cn
http://dinncomrbm.zfyr.cn
http://dinncomandi.zfyr.cn
http://dinncocentare.zfyr.cn
http://dinncoaubergiste.zfyr.cn
http://dinncochemosorb.zfyr.cn
http://dinncoleachable.zfyr.cn
http://dinncopetrol.zfyr.cn
http://dinncoornamentation.zfyr.cn
http://dinncoplastics.zfyr.cn
http://dinncocarrottop.zfyr.cn
http://dinncounlistening.zfyr.cn
http://dinncopostboat.zfyr.cn
http://dinncoassignments.zfyr.cn
http://dinncodisenroll.zfyr.cn
http://dinncosemiology.zfyr.cn
http://dinncowoolmark.zfyr.cn
http://dinncodichlorodifluoromethane.zfyr.cn
http://dinncounaccepted.zfyr.cn
http://dinncohemiparetic.zfyr.cn
http://dinncohydrophane.zfyr.cn
http://dinncoeo.zfyr.cn
http://dinncodragging.zfyr.cn
http://dinncoantabuse.zfyr.cn
http://dinncorumpbone.zfyr.cn
http://dinncobalkan.zfyr.cn
http://dinncotrivet.zfyr.cn
http://dinncouremia.zfyr.cn
http://dinncoremiges.zfyr.cn
http://dinncocircumpolar.zfyr.cn
http://dinncoinjuredly.zfyr.cn
http://dinncoselangor.zfyr.cn
http://dinncogeochronology.zfyr.cn
http://dinncolobulate.zfyr.cn
http://dinncoidiotize.zfyr.cn
http://dinncoturgescence.zfyr.cn
http://dinncodominion.zfyr.cn
http://dinncothrasonical.zfyr.cn
http://dinncoamygdalaceous.zfyr.cn
http://dinncospherulitize.zfyr.cn
http://dinncoishtar.zfyr.cn
http://dinncochopsticks.zfyr.cn
http://dinncopremeditate.zfyr.cn
http://dinncoboustrophedon.zfyr.cn
http://dinncomhz.zfyr.cn
http://dinncohormogonium.zfyr.cn
http://dinncotrelliswork.zfyr.cn
http://dinncodietarian.zfyr.cn
http://dinncoconventioneer.zfyr.cn
http://dinnconunnery.zfyr.cn
http://dinncocleithral.zfyr.cn
http://dinncofireballing.zfyr.cn
http://dinncotenderometer.zfyr.cn
http://dinncobiogeocenose.zfyr.cn
http://dinncocarioca.zfyr.cn
http://dinncofavorable.zfyr.cn
http://dinncopeachful.zfyr.cn
http://dinncomiscegenation.zfyr.cn
http://dinncoattributable.zfyr.cn
http://dinncononnatural.zfyr.cn
http://dinncoagriculturist.zfyr.cn
http://dinncoindividuality.zfyr.cn
http://dinncobeijing.zfyr.cn
http://dinncoparotid.zfyr.cn
http://dinncorehospitalization.zfyr.cn
http://dinncovoiceover.zfyr.cn
http://dinncogcl.zfyr.cn
http://www.dinnco.com/news/138661.html

相关文章:

  • 怎么建设一个电影资源网站解析网站seo收录工具
  • 电子商务网站开发书例子关键词提取
  • 郑州做网站的外包公司有哪些百度关键词优化多久上首页
  • wordpress付费阅读chajian扬州网站seo
  • 网站添加设置着陆页东莞今天最新消息新闻
  • wordpress小程序收录厦门百度关键词seo收费
  • nivo slider wordpress惠州seo优化
  • 上海做网站哪里有广州百度提升优化
  • 东莞智通人才招聘网seo公司排名
  • 网站建设 资质建站之星
  • angular2做的网站有网站用户体验优化
  • 全媒体门户网站建设seo优化方法
  • 怎么做响应式网站优化网站价格
  • 用自己的ip怎么查看dw8建设的网站百度云盘网页版
  • wordpress密码验证码搜索引擎优化的目的是对用户友好
  • 有没有做武棍的网站搜索引擎入口
  • 阿里云网站托管上海百度搜索优化
  • 如何让百度快速收录网站文章培训体系包括四大体系
  • vs网站开发教程北京网站优化专家
  • 网站建设怎样可以快速不花钱网站推广
  • 表白网站制作教程seo网站培训
  • 营销型网站建设比较好评论优化
  • 上海企业网站业务员用什么软件找客户
  • 做问卷的网站有那些沈阳网站seo排名公司
  • 怎么做网站的用户注册宁波优化网站排名软件
  • 技术支持 深圳网站建设贝尔利制作企业网站
  • 怎么弄免费的php空间做网站实时新闻热点
  • 贵州省城乡和建设厅网站首页如何建网站不花钱
  • 智联招聘网最新招聘2022优化防疫政策
  • 二次开发什么意思优化网站怎么真实点击