V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
xiaojieluoff
V2EX  ›  Python

Python : 爬取所有 ip 数据并存入 mongodb,支持中断恢复执行

  •  
  •   xiaojieluoff · 2017-05-27 17:47:10 +08:00 · 1620 次点击
    这是一个创建于 2542 天前的主题,其中的信息可能已经有所发展或是发生改变。

    数据采集自 ip-api.com

    在 celery 队列中获取数据并存入 mongodb 数据库

    支持程序中断后从上次停下的地方继续采集

    支持 python3+

    Github 地址: https://github.com/xiaojieluo/ip-database

    下面截图是我在本地电脑爬的,开了 4 个 worker,celery 很容易横向拓展,如果多加几台服务器,做成分布式爬虫,速度应该还是可以的

    截图

    安装

    $ pip install -r requirements.txt
    

    使用

    1. 配置 mongodb 连接信息

    ip-database 会将采集的数据存储到 mongodb 中,所以需要在 db.py 中配置 mongodb 的连接信息

    2. 启动 redis-server 和 celery

    celery 使用 redis 存储任务队列,需要启动 redis-server

    
    $ redis-server
    
    $ celery -A task worker --loglevel=info
    

    3. 启动主程序

    
    $ python ip.py
    
    
    目前尚无回复
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2781 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 11:06 · PVG 19:06 · LAX 04:06 · JFK 07:06
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.