0

0

GAE 任务跨服务执行:Python 到 NodeJS 的任务调度

DDD

DDD

发布时间:2025-07-14 15:36:36

|

565人浏览过

|

来源于php中文网

原创

gae 任务跨服务执行:python 到 nodejs 的任务调度

本文旨在解决 Google App Engine (GAE) 应用中,任务需要在不同服务之间调度执行的问题。假设你有一个使用 Python3 编写的默认服务和一个使用 NodeJS18 编写的服务。现在需要从 Python3 服务提交一个任务,并让 NodeJS18 服务来执行这个任务。

在使用 google.cloud.tasks_v2 Python 客户端提交任务时,虽然可以指定任务队列,但并没有直接的方法来指定哪个 GAE 服务应该处理该任务。下面将介绍两种可行的方案来实现跨服务任务调度。

方案一:利用 dispatch.yaml 路由规则

如果你的 dispatch.yaml 文件仅基于路径进行路由,而没有涉及域名,那么你可以通过设置 relative_uri 属性来将任务路由到目标服务。

dispatch.yaml 文件定义了如何将传入的 HTTP 请求路由到不同的服务。例如:

立即学习Python免费学习笔记(深入)”;

- url: "*/mobile/*"
  service: mobile-frontend

- url: "*/work/*"
  service: static-backend

在这种情况下,如果你想让 mobile-frontend 服务处理一个任务,只需将 relative_uri 设置为 /mobile/mobile_task。即使任务是从 /work/page-1 发起的,它也会被路由到 mobile-frontend 服务。

注意: 这种方法未经实际验证,请谨慎使用,并在测试环境中进行充分测试。

方案二:通过 HTTP 调用触发目标服务提交任务

如果你的 dispatch.yaml 文件包含基于域名或子域名的路由规则,那么可以先向目标服务的 URL 发送一个 HTTP 请求(例如 POST 请求),然后让目标服务自身提交任务。

Cursor
Cursor

一个新的IDE,使用AI来帮助您重构、理解、调试和编写代码。

下载

例如,假设你有一个可以通过 blog.example.com 访问的服务,并且希望这个服务处理一个从默认服务提交的任务。

  1. 从默认服务向 blog.example.com/prep_task_invocation/ 发送一个 HTTP 请求,并将需要执行的任务数据作为参数传递。

  2. blog.example.com/prep_task_invocation/ 接收到请求后,将任务提交到自身,即 blog.example.com 服务。假设 relative_uri 不会将任务路由到其他服务。

示例代码 (Python3 - 默认服务):

import requests
import json

def submit_task_to_node_service(task_data):
  """
  向 NodeJS 服务发送 HTTP 请求,触发其提交任务。
  """
  url = "https://blog.example.com/prep_task_invocation/"
  headers = {'Content-type': 'application/json'}
  response = requests.post(url, data=json.dumps(task_data), headers=headers)
  return response

# 示例任务数据
task_data = {"payload": "This is the task payload"}

# 提交任务
response = submit_task_to_node_service(task_data)

if response.status_code == 200:
  print("Task submission request successful")
else:
  print(f"Task submission request failed with status code: {response.status_code}")

示例代码 (NodeJS18 - 目标服务):

const { CloudTasksClient } = require('@google-cloud/tasks');
const express = require('express');
const bodyParser = require('body-parser');

const app = express();
app.use(bodyParser.json());

const client = new CloudTasksClient();
const project = process.env.GOOGLE_CLOUD_PROJECT;
const location = 'your-location'; // e.g., 'us-central1'
const queue = 'default';

app.post('/prep_task_invocation/', async (req, res) => {
  const payload = req.body.payload;

  const task = {
    httpRequest: {
      httpMethod: 'POST',
      url: 'https://blog.example.com/process_task/', // 任务处理的 URL
      headers: {
        'Content-Type': 'application/json',
      },
      body: Buffer.from(JSON.stringify({payload: payload})).toString('base64'),
    },
  };

  const queuePath = client.queuePath(project, location, queue);

  const request = {
    parent: queuePath,
    task: task,
  };

  try {
    const [response] = await client.createTask(request);
    console.log(`Created task ${response.name}`);
    res.status(200).send('Task created successfully');
  } catch (error) {
    console.error('Error creating task:', error);
    res.status(500).send('Error creating task');
  }
});

app.post('/process_task/', (req, res) => {
  const payload = JSON.parse(Buffer.from(req.body.payload, 'base64').toString());
  console.log(`Processing task with payload: ${payload.payload}`);
  // 在这里处理任务
  res.status(200).send('Task processed');
});


const port = process.env.PORT || 8080;
app.listen(port, () => {
  console.log(`Server listening on port ${port}`);
});

注意事项:

  • 确保 NodeJS 服务具有创建 Cloud Tasks 的权限。
  • 根据实际情况修改 location 和 queue 变量。
  • process_task 路由负责实际的任务处理逻辑。
  • HTTP body 需要进行 base64 编码,以便在任务中传输。

总结

本文介绍了两种在 GAE 中实现跨服务任务调度的方法。第一种方法利用 dispatch.yaml 路由规则,适用于仅基于路径进行路由的情况。第二种方法通过 HTTP 调用触发目标服务提交任务,适用于包含域名或子域名路由规则的情况。选择哪种方法取决于你的应用架构和 dispatch.yaml 文件的配置。在实际应用中,建议进行充分的测试,以确保任务能够正确地路由到目标服务并成功执行。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
location.assign
location.assign

在前端开发中,我们经常需要使用JavaScript来控制页面的跳转和数据的传递。location.assign就是JavaScript中常用的一个跳转方法。通过location.assign,我们可以在当前窗口或者iframe中加载一个新的URL地址,并且可以保存旧页面的历史记录。php中文网为大家带来了location.assign的相关知识、以及相关文章等内容,供大家免费下载使用。

226

2023.06.27

http500解决方法
http500解决方法

http500解决方法有检查服务器日志、检查代码错误、检查服务器配置、检查文件和目录权限、检查资源不足、更新软件版本、重启服务器或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

434

2023.11.09

http请求415错误怎么解决
http请求415错误怎么解决

解决方法:1、检查请求头中的Content-Type;2、检查请求体中的数据格式;3、使用适当的编码格式;4、使用适当的请求方法;5、检查服务器端的支持情况。更多http请求415错误怎么解决的相关内容,可以阅读下面的文章。

420

2023.11.14

HTTP 503错误解决方法
HTTP 503错误解决方法

HTTP 503错误表示服务器暂时无法处理请求。想了解更多http错误代码的相关内容,可以阅读本专题下面的文章。

2388

2024.03.12

http与https有哪些区别
http与https有哪些区别

http与https的区别:1、协议安全性;2、连接方式;3、证书管理;4、连接状态;5、端口号;6、资源消耗;7、兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2119

2024.08.16

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

9

2026.01.30

c++ 字符串格式化
c++ 字符串格式化

本专题整合了c++字符串格式化用法、输出技巧、实践等等内容,阅读专题下面的文章了解更多详细内容。

9

2026.01.30

java 字符串格式化
java 字符串格式化

本专题整合了java如何进行字符串格式化相关教程、使用解析、方法详解等等内容。阅读专题下面的文章了解更多详细教程。

10

2026.01.30

python 字符串格式化
python 字符串格式化

本专题整合了python字符串格式化教程、实践、方法、进阶等等相关内容,阅读专题下面的文章了解更多详细操作。

3

2026.01.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
快速入门Node.JS全套完整版
快速入门Node.JS全套完整版

共83课时 | 8.5万人学习

nodejs开发基础教程
nodejs开发基础教程

共15课时 | 4.5万人学习

JavaScript设计模式视频教程
JavaScript设计模式视频教程

共28课时 | 5.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号