Zerg <a href="https://github.com/huichen/zerg#%E7%89%B9%E6%80%A7"></a>特性如何部署 基于docker的分布式爬虫服务

程序名称:Zerg <a href="https://github.com/huichen/zerg#%E7%89%B9%E6%80%A7"></a>特性如何部署

授权协议: Apache

操作系统: 跨平台

开发语言: Google Go

Zerg <a href="https://github.com/huichen/zerg#%E7%89%B9%E6%80%A7"></a>特性如何部署 介绍

zerg

基于docker的分布式爬虫服务

特性

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

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

  • 负载均衡

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

  • 可设置抓取超时

  • 支持 GET、HEAD、POST 方法

  • 支持自定义 header

如何部署

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

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

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

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

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

进入 service_container 子目录,然后运行

./build_docker_image.sh

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

docker run -d -P unmerged/zerg

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

进入 examples 目录,运行

go run zerg_crawl.go --endpoints http://<你的 etcd host:ip> --url http://taobao.com

1、重新生成 protobuf service

protoc protos/crawl.proto --go_out=plugins=grpc:protos -I protos/

2、本地测试

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

go run service.go

然后进入 examples 目录,运行

go run single_machine_crawl.go --url http://taobao.com

Zerg <a href="https://github.com/huichen/zerg#%E7%89%B9%E6%80%A7"></a>特性如何部署 官网

https://github.com/huichen/zerg

相关编程语言

Pacman 是一个软件包管理器, 作为 ArchLinux 发行版...
Smb4K 是KDE下的网络共享浏览器 更多屏幕截图请看:...
Wine (“Wine Is Not an Emulator” 的首字母缩写)...
虚拟桌面软件,可管理最多9个虚拟桌面,你可以用热键...
UNetbootin (Universal Netboot Installer)为一种跨...
Cobbler 可以用来快速建立 Linux 网络安装环境,它已...