Zerg 基于docker的分布式爬虫服务

开源网站开源项目 24-04-10 10:12:02

zerg

基于docker的分布式爬虫服务

特性

多机多 IP,充分利用 IP 资源

服务自动发现和注册(基于 etcd 和 registrator)

负载均衡

服务端客户端通信基于 gRPC,支持多种编程语言的客户端

可设置抓取超时

支持 GET、HEAD、POST 方法

支持自定义 header

如何部署第一步:配置 etcd

我把 etcd 容器化了,并开发了脚本使得部署 etcd cluster 非常容易,见 github.com/huichen/etcd_docker

为了容灾,请至少在三台服务器上运行 etcd 实例。为了方便调用,你可以固定 etc endpoint 的端口号,并在所有机器上手工添加 etcd host 的 hostname。

第二步:启动 registrator 服务发现程序

你需要在集群的每一台服务器上都运行 registrator,这使得我们可以自动发现和注册分布式服务

dockerrun-d--name=registrator--net=host--volume=/var/run/docker.sock:/tmp/docker.sock\gliderlabs/registratoretcd://<etcd接入点的ip:port>/services

请把上面的 etcd 接入点换成你的 etcd 地址。

第三步:部署 zerg 服务

进入 service_container 子目录,然后运行

./build_docker_image.sh

这会生成 unmerged/zerg 容器。然后在集群的每台服务器上启动容器:

dockerrun-d-Punmerged/zerg

registrator 会自动注册这些服务到 etcd。如果单机有多个 IP,你可以单机启动多个容器,并在 -P 中分别指定 IP。

第四步:调用样例代码

进入 examples 目录,运行

gorunzerg_crawl.go--endpointshttp://<你的etcdhost:ip>--urlhttp://taobao.com

可选步骤

1、重新生成 protobuf service

protocprotos/crawl.proto--go_out=plugins=grpc:protos-Iprotos/

2、本地测试

启动本地服务。进入 service_container 目录,然后运行

gorunservice.go

然后进入 examples 目录,运行

gorunsingle_machine_crawl.go--urlhttp://taobao.com
[Zerg 基于docker的分布式爬虫服务]相关推荐

notty 虚拟终端

notty 是个类似 xterm,GNOME-vte,sh 和 rxvt 的终端模拟器。跟那些程序不一样的地方是,notty 不是为了……...

ipex 网络启动固件

iPXE 是开源的网络启动固件。它提供了完整的 PXE 实施,并增强了其他功能,例如: 通过 HTTP 从 Web 服务……...

Twig PHP 模板语言

Twig 是一个灵活、快速、安全的 PHP 模板语言。它将模板编译成经过优化的原始PHP代码。Twig拥有一个Sandb……...

PuTTY 远程登录客户端

PuTTY 远程登录客户端

PuTTY是一个Telnet/SSH/rlogin/纯TCP以及串行阜连线软件。较早的版本仅支援Windows平台,在最近的版本中……...

今日开源
  1. BBX ASP.Net 4.5 论坛源码

    BBX ASP.Net 4.5 论坛源码

    ASP.Net 4.5 论坛源码,支持多数据库

    开源软件 2024-05-11

  2. iCircuit 电路设计软件

    iCircuit 电路设计软件

    很强大一个款电路设计软件,有各种数据分析,波形测试功能:

    开源软件 2024-05-11

  3. PyPy Python 解释器

    PyPy Python 解释器

    PyPy 是用 Python 实现的 Python 解释器。PyPy 是 Python开发者为了更好的Hack Python创建的项目。此外,PyPy比CPython是更加灵活,易于使用和试验,以制定具体的功能在不同情况的实现方法,可以很容易实施。 该项……

    开源软件 2024-05-11

返回顶部小火箭