Save the date - Google I/O returns May 18-20. Register to get the most out of the digital experience: Build your schedule, reserve space, participate in Q&As, earn Google Developer profile badges, and more. Register now
หน้านี้ได้รับการแปลโดย Cloud Translation API
Switch to English

ทริกเกอร์ Pub / Sub

Pub / Sub ของ Google Cloud คือบัสข้อความที่กระจายไปทั่วโลกซึ่งจะปรับขนาดโดยอัตโนมัติตามที่คุณต้องการ คุณสามารถสร้างฟังก์ชันที่จัดการกับเหตุการณ์ Pub / Sub โดยใช้ functions.pubsub

ทริกเกอร์ฟังก์ชัน pub / sub

คุณสามารถทริกเกอร์ฟังก์ชันได้ทุกครั้งที่มีการส่งข้อความ Pub / Sub ใหม่ไปยังหัวข้อใดหัวข้อหนึ่ง คุณต้องระบุชื่อหัวข้อ Pub / Sub ที่คุณต้องการเรียกใช้ฟังก์ชันของคุณและตั้งค่าเหตุการณ์ภายในตัวจัดการเหตุการณ์ onPublish() :

exports.helloPubSub = functions.pubsub.topic('topic-name').onPublish((message) => {
  // ...
});

เข้าถึงเพย์โหลดข้อความ pub / sub

เพย์โหลดสำหรับข้อความ Pub / Sub สามารถเข้าถึงได้จากวัตถุ Message ส่งกลับไปยังฟังก์ชันของคุณ สำหรับข้อความที่มี JSON ในเนื้อหาข้อความ Pub / Sub Firebase SDK for Cloud Functions มีคุณสมบัติตัวช่วยในการถอดรหัสข้อความ ตัวอย่างเช่นนี่คือข้อความที่เผยแพร่ด้วยเพย์โหลด JSON แบบธรรมดา:

gcloud pubsub topics publish topic-name --message '{"name":"Xenia"}'

คุณสามารถเข้าถึงเพย์โหลดข้อมูล JSON เช่นนี้ผ่านคุณสมบัติ json :

  // Get the `name` attribute of the PubSub message JSON body.
  let name = null;
  try {
    name = message.json.name;
  } catch (e) {
    functions.logger.error('PubSub message was not JSON', e);
  }

เพย์โหลดอื่นที่ไม่ใช่ JSON มีอยู่ในข้อความ Pub / Sub เป็นสตริงที่เข้ารหัส base64 ในออบเจ็กต์ข้อความ หากต้องการอ่านข้อความดังต่อไปนี้คุณต้องถอดรหัสสตริงที่เข้ารหัส base64 ดังที่แสดง:

gcloud pubsub topics publish topic-name --message 'MyMessage'

// Decode the PubSub Message body.
const messageBody = message.data ? Buffer.from(message.data, 'base64').toString() : null;

เข้าถึงแอตทริบิวต์ข้อความ

สามารถส่งข้อความ Pub / Sub พร้อมกับแอตทริบิวต์ข้อมูลที่ตั้งค่าในคำสั่งเผยแพร่ ตัวอย่างเช่นคุณสามารถเผยแพร่ข้อความที่มีแอตทริบิวต์ name :

gcloud pubsub topics publish topic-name --attribute name=Xenia

คุณสามารถอ่านแอตทริบิวต์ดังกล่าวได้จาก Message.attributes :

// Get the `name` attribute of the message.
const name = message.attributes.name;

คุณอาจสังเกตเห็นว่าข้อมูลพื้นฐานบางอย่างเช่นรหัสข้อความหรือเวลาเผยแพร่ข้อความไม่มีอยู่ใน Message.attributes การทำงานรอบนี้คุณสามารถเข้าถึงเหตุการณ์วิกฤติของ context.eventId และ context.timestamp ด้วยซึ่งคุณสามารถตรวจสอบเมื่อมีข้อความใด ๆ ที่ได้รับการตีพิมพ์และความแตกต่างหนึ่งข้อความจากที่อื่น ตัวอย่างเช่น:

exports.myFunction = functions.pubsub.topic('topic1').onPublish((message, context) => {
    console.log('The function was triggered at ', context.timestamp);
    console.log('The unique ID for the event is', context.eventId);
});