linux crontab scrapy,python3 scrapy+Crontab部署过程

背景

最近有时间想学习下python3+scrapy,于是决定写一个小程序来练练手。

开发环境:MacOS High Sierra(10.13.1)+python3+scrapy。

开发工具:PyCharm。

开发过程很简单按照网上的例子可以很好的开发完成。具体为采集新闻网站新闻。

部署

生产环镜:CentOS7.4+Python3.6

由于是在Python3上开发的,所以在部署的过程中遇到很多问题,本文就不在记录那些坑了。

直接记录我的方案:在虚拟环境中运行scrapy。

1、首先安装Python3、pip3。这个是基础。可以直接从官网上下载安装。

# python -V # 查看python 版本

# cd /home/centos/Downloads # 进入存放目录

# wget https://www.python.org/ftp/python/3.6.1/Python-3.6.1.tar.xz # 获取新版的 python

# tar xvf Python-3.6.1.tar.xz # 解压文件

# cd ./Python-3.6.1 # 进入解压后的文件目录

# mkdir /usr/local/python3 # 创建编译安装目录

# ./configure --prefix=/usr/local/python3 # 配置编译安装目录

# make && make install # 编译安装

2、安装Python3虚拟环境(虚拟环境可以与真实环镜完全分离开,不受python2相关影响。

#定位到python程序目录

cd /data/application/python3

#安装虚拟环境包

pip3 install virtualenv

#创建python3虚拟环境(虚拟环境为目录:python3env)

virtualenv -p python3 --no-site-packages python3env

#进入指定环镜

source python3env/bin/activate

#退出环镜

deactivate

3、虚拟环境安装相关包

# 安装Twisted

wget https://pypi.python.org/packages/a2/37/298f9547606c45d75aa9792369302cc63aa4bbcf7b5f607560180dd099d2/Twisted-17.9.0.tar.bz2#md5=6dbedb918f0c7288a4c670f59393ecf8

tar -xjvf Twisted-17.9.0.tar.bz2

cd Twisted-17.9.0

python3 setup.py install

# 安装scrapy

pip3 install scrapy

#其他的包就自行安装吧....

4、启动程序

#定位目录

cd /data/application/python3

#进入python3虚拟环境

source python3env/bin/activate

#定位程序目录

cd news_spiders/news/spiders/

#执行scrapy,采集数据 sina为我开发的蜘蛛的名称,使用时换成自己的蜘蛛名称

scrapy crawl sina

#退出环镜

deactivate

升级:每次想执行一次脚本比较麻烦还需要切换虚拟环境,于下我写了以下脚本。每次直接执行脚本即可。

脚本:/data/application/python3/news_spiders/run.sh

source ../python3env/bin/activate

scrapy crawl $1

deactivate

于是每次执行的脚本就简单了许多:

cd /data/application/python3/news_spiders/

#sina为蜘蛛的名称

./run.sh sina

5、定时执行

简单点采用Linux定时任务Crontab来执行脚本。

#编辑cron文件,我使用root用户。

vim /var/spool/cron/root

/var/spool/cron/root文件内容如下:

MAILTO=""

10 * * * * cd /data/application/python3/news_spiders/ && ./run.sh sina

40 * * * * cd /data/application/python3/news_spiders/ && ./run.sh baidu

注:直接执行/data/application/python3/news_spiders/run.sh sina会报错,会提示找不到crawl。因为我的scrapy.cfg文件在news_spiders目录下。所以需要定位到news_spiders目录。

1.Python3.6环境部署

标题:Python3.6环境部署文档 作者:刘耀 内容 Linux部署Python3.6环境 Mac部署Python3.6环境 Window10部署Python3.6环境 Pycharm安装 1. L ...

Python3 Scrapy 安装方法

Python3 Scrapy 安装方法 (一脸辛酸泪) 写在前面 最近在学习爬虫,在熟悉了Python语言和BeautifulSoup4后打算下个爬虫框架试试. 没想到啊,这坑太深了... 看了看相关 ...

python3.6环境部署文档

python3.6环境部署文档   内容 Linux部署Python3.6环境 Mac部署Python3.6环境 Window10部署Python3.6环境 Pycharm安装 1. Linux部署P ...

django+uWSGI+nginx的工作原理流程与部署过程

django+uWSGI+nginx的工作原理流程与部署过程 一.前言 知识的分享,不应该只是展示出来,还应该解释这样做是为什么... 献给和我一样懵懂中不断汲取知识,进步的人们. 授人与鱼,不如授人 ...

hudson部署过程

hudson部署过程: java安装 http://developer.51cto.com/art/201504/470683.htm tomcat安装 http://blog.csdn.net/hu ...

SCCM 2012 R2安装部署过程和问题(三)

上篇 SCCM 2012 R2安装部署过程和问题(二) 个人认为对于使用SCCM 2012的最重要的经验是耐心. SCCM采用分布式部署的架构,不同的站点角色可以部署在不同的服务器上,站点角色之间的通 ...

SCCM 2012 R2安装部署过程和问题(二)

上篇:SCCM 2012 R2安装部署过程和问题(一) 在上篇我们已经完成了SCCM 2012 R2安装前的准备,其中有许多细节,关于数据库的准备和权限的设置是需要特别注意的.那么接下来我们开始安装S ...

SCCM 2012 R2安装部署过程和问题(一)

在进行Windows Server 2012 R2虚拟化测试前,由于需要安装,部署和管理很多的服务器,自然会想到该如何提高效率和有效的管理.在Windows Server 2008的时代微软已经提供称 ...

BeX5平台简明部署过程

http://wex5.com/cn/concise-deployment/ BeX5平台简明部署过程 该文章主要介绍BeX5平台开发完成后,资源部署至正式环境的过程. 一. 获取BeX5企业快速开发 ...

随机推荐

day8

作业要求:     1.用socket写一个 ftp服务端与客户端     2.支持get put命令 作业下载地址:ftp://www.wudonghang.com/oldboy/day8.zip ...

json,pickle

json  将python基本数据类型转换成字符串形式 import json dict = {'k1':'v1'} result = json.dumps(dict) print(result,ty ...

Ibm-jQuery教程学习笔记

一.概述 1.虽然 jQuery 本身并非一门新的语言.但是,学习其语法有助于我们熟练.灵活地使用它.回顾下我们熟悉的 CSS 语法,不难发现 jQuery 的语法与 CSS 有相似之处. jQuer ...

【转】windows c++获取文件信息——_stat函数的使用

_stat函数的功能 _stat函数用来获取指定路径的文件或者文件夹的信息. 函数声明 int _stat( const char *path, struct _stat *buffer ); 参数: ...

oauth与openid

转自http://desert3.iteye.com/blog/1701626 OAuth(开放授权)是一个开放标准,允许用户让第三方应用访问该用户在某一网站上存储的私密的资源(如照片,视频,联系人列 ...

linux 内核协议栈收报流程(二)Netfilter全貌

ip层分片整理 int ip_local_deliver(struct sk_buff *skb){ /* * Reassemble IP fragments. */ if (ip_is_fragme ...

TPYBoard v102 DIY照相机(视频和制作流程)

前段时间的帖子,利用TPYBoard v102做的DIY照相机,周末实物终于做出来了,加了两个按键模块和一个5110,做的有点糙啊----望大家勿怪,哈哈哈.拍出来图片还算清晰,串口摄像头模块用的30 ...

从三个开源项目认识OpenFlow交换机 - OVS

在SDN/NFV的网络革新技术浪潮的引领下,催生了诸多数据面开源方案的诞生.业界知名度较高的有OVS(Open vSwitch).FD.io (Fast Data I/O).ODP(Open Data ...

SpringBoot学习之SpringBoot执行器

在以往的分布式开发当中,各个服务节点的监控必不可少.监控包含有很多方面,比如说:内存占用情况,节点是否健康等.在spring-boot会给我们提供相关资源监控叫做spring-boot-actuato ...

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值