当前位置:淡墨SEO首页 > SEO软件 > flask-celery异步执行sitemap任务并生成文件

flask-celery异步执行sitemap任务并生成文件

淡墨SEO3年前 (2022-09-05)SEO软件9980

此次主要是将python生成的sitemap文件,转入到flask做出的api接口上,这样每次进行api请求就可以获取到网站的所有的url并生成sitemap文件。首先看看运行效果。

本地地址请求接口url:http://127.0.0.1:5100/sitemap?site=http://www.seoyiwu.com

运行命令:

1、宝塔服务器开启redis服务(安装一下redis就行了)

image.png

2、启动celery异步执行任务命令 : celery --app=run.celery worker -P eventlet -l INFO

image.png

3、启动flask命令 python run.py


image.png


接下来用postman进行测试看看。可以看到返回一个任务id,这个任务id代表任务执行的状态,是否执行完毕

image.png



如果没有执行完毕则返回 当前执行步骤

image.png

执行完毕后,就会返回执行终止状态以及返回了sitemap文件

image.png

然后我们在当前目录可以看到生成的sitemap文件,可以看到已经生成成功。

image.png

好了,接下来看看代码的实现流程:

一、flask创建任务,成功celery实例

创建celery队形,并配置好redis数据库


image.png


二、sitemap任务

这是celery异步执行的任务,放到一个方法里。

@celery.task(bind=True)
def proSitemap(self,urls):
    allUrls = set()
    rootUrl = urls[0]
    while True:
        with ThreadPoolExecutor(max_workers=10) as executor:
            urls = executor.map(getsitemap_url,urls)
            urls = [url for url in urls if url][0]
        urls = set(urls) - allUrls
        if not urls:break
        for url in urls:
            if url.find(rootUrl) == -1:continue
            allUrls.add(url)
            self.update_state(state='PROGRESS',meta={'status':f'正在抓取的url: {url}'})
        urls = list(urls)
       
    allUrls = sorted(list(allUrls),key=lambda url:len(url))
    print(allUrls)
    return {'rootUrl':rootUrl,'allUrls':allUrls,'status':200,'result':'生成完毕'}


三、请求接口

配置好请求接口,生成sitemap任务运行api

@app.route('/sitemap', methods=['GET'])
def sitemap():
    site = request.args.get('site','')
    urls = [site]
    task = proSitemap.apply_async(args=[urls])
    print(task.id)
    return jsonify({
        'Location':request.host_url  + url_for('taskstatus',task_id=task.id).replace('/status','status')
    })
       

@app.route('/status/<task_id>')
def taskstatus(task_id):
    task = proSitemap.AsyncResult(task_id)
    if task.state == 'PENDING':
        response = {
            'state':task.state,
            'status':'pending'
        }
    elif task.state != 'FAILURE':
        rootUrl = task.info.get('rootUrl',0)
        allUrls = task.info.get('allUrls',1)
       
        response = {
        'state':task.state,
        'status':task.info.get('status',100),
        'rootUrl':rootUrl,#rootUrl,
        'allUrls':allUrls,#allUrls,
    }
        if 'result' in task.info:
            makeSitemap(rootUrl,allUrls)
            response['result'] = task.info['result']
    else:
        response = {
            'state':task.state,
            'status':str(task.info)
        }
    return jsonify(response)


四、生成sitemap文件

def makeSitemap(rootUrl,allUrls):
    fw = open('sitemap.xml', 'w', encoding="utf-8")
    fw.write('<?xml version="1.0" encoding="UTF-8"?>')
    fw.write(
        '\n<urlset xmlns="http://video.sitemaps.org/schemas/sitemap/0.9">'
    )
    for url in allUrls:
        fw.write('\n\t<url>')
        fw.write('\n\t\t<loc>' + url + '</loc>')
        fw.write("\n\t\t<lastmod>" +time.strftime('%Y-%m-%d', time.localtime(time.time())) +
            "</lastmod>")
        fw.write('\n\t\t<changefreq>daily</changefreq>')
        if re.findall(rootUrl + "$", url) or re.findall(
                rootUrl + "/$", url):
            fw.write('\n\t\t<priority>1.0</priority>')
        elif re.findall(rootUrl + "[^/]*/$",
                        url) or re.findall(
                            rootUrl + "/[^/]*/$", url):
            fw.write('\n\t\t<priority>0.8</priority>')
        elif re.findall(rootUrl + "[^/]*/[^/]*$",
                        url) or re.findall(
                            rootUrl + "/[^/]*/[^/]*$", url):
            fw.write('\n\t\t<priority>0.6</priority>')
        else:
            fw.write('\n\t\t<priority>0.4</priority>')

        fw.write('\n\t</url>')
    fw.write('\n</urlset>')


整体的核心步骤就这些了,接下来我们就可以将代码上传到服务器中,然后就可以在服务器调用,方便随意使用,也可以在服务器里开启一个定时任务进行定时更新sitemap文件。如果需要生成sitemap的朋友,可以私信我,获取免费接口生成!

扫描二维码推送手机访问

文章内容均为原创,禁止转载!

本文链接:http://www.danmoseo.com/news/13.html

相关文章

api内容智能伪原创并保存到mongodb中

api内容智能伪原创并保存到mongodb中

这次为了产生伪原创内容更加方便以及大批量生产,将制作伪原创内容的接口放到了请求接口中,这样在获取伪原创内容,我们只需要从接口中进行参数设置然后请求获取就可以了。下面讲解一下api制作原理,以及需要此接口的朋友可以向我获取免费token进行智能伪原创测试。首先接口是通过post请求,每次请求只需要设置...

某讯视频用python解析数据并下载视频mp4格式

某讯视频用python解析数据并下载视频mp4格式

国庆祝福祖国生日快乐。偶尔间,想做做视频剪辑,需要下载视频素材,但是在平台上的视频似乎不支持手动下载。自然学了python,可以试着用代码去下载视频,在这块找到相应的教学内容,本次内容主要是分享用python如何去获取下载某讯视频。下面为大家讲解一下。就拿最近比较火的昆仑神宫来做下视频解析下载,首先...

逆向百度旋转验证码,并自动提交链接

逆向百度旋转验证码,并自动提交链接

前面说了逆向百度旋转验证码后,大家可以在找前面的文章了解了解,这次主要是通过逆向旋转验证码后进行实战操作。本次主要是对百度链接提交界面进行一个链接提交操作,可以批量提交我们网站的链接,从而优化收录网站链接。封装软件发货传送门》》百度链接提交软件视频演示:内容介绍:如果是手动提交的话,需要手动旋转一下...

摆渡模拟点击关键词排名优化介绍

摆渡模拟点击关键词排名优化介绍

模拟点击的原理在于模拟用户打开浏览器,搜索关键词,后面进行一系列的模拟行为操作。在python代码中,用到的浏览器框架是selenium库,然后进行模拟点击整个过程的代码执行。源码商城》》》摆渡快排软件含源码教程视频演示:本次代码已经进行封包了,在运行的时候,只需要一键运行即可在安装方面导入数据库就...

百度站长平台js逆向登录解析

百度站长平台js逆向登录解析

在我们使用百度站长平台看看网站数据信息的时候,肯定要先登录才能获取,那么就需要在网页上进行登录,然后才能看到网站一些信息以及做一些操作比如二级域名绑定,抓取诊断、关键词查看等。那如果要代码进行这些操作的话,要解决逆向登录的问题,或者不解决登录的话,在网页上获取cookie进行复制再进行代码操作。本次...