คุณกำลังดูเอกสารประกอบของ Apigee Edge
ไปที่เอกสารประกอบของ Apigee X ข้อมูล
คุณควรตรวจสอบว่าโค้ด Node.js ที่คุณเพิ่มลงในพร็อกซีใช้งานได้ก่อนที่จะทำให้ใช้งานได้ใน Edge หัวข้อนี้จะกล่าวถึงวิธีต่างๆ ในการแก้ไขข้อบกพร่องและแก้ปัญหาพร็อกซีที่มีแอปพลิเคชัน Node.js หลังจากทำให้ใช้งานได้แล้ว
การเพิ่มขนาดพูลการเชื่อมต่อเพื่อปรับปรุงประสิทธิภาพ
หากสังเกตเห็นว่าประสิทธิภาพช้า คุณอาจแก้ไขปัญหาได้โดยเพิ่มขนาดพูลการเชื่อมต่อ Node.js เริ่มต้นด้วย maxSockets หรือปิดใช้ Socket Pool ทั้งหมด ดูข้อมูลเพิ่มเติมและโค้ดตัวอย่างได้ที่ Node.js Performance Tips: Socket Pooling ในชุมชน Apigee
การดูบันทึกของ Node.js
หากต้องการดูข้อมูลบันทึกเกี่ยวกับแอปพลิเคชัน Node.js ให้ทำดังนี้
- ในหน้าพร็อกซี API หลัก ให้คลิกพร็อกซีที่ต้องการดู
- ในหน้าสรุปของพร็อกซีที่เลือก ให้คลิกบันทึกของ Node.js ที่ด้านขวาของแถบเครื่องมือ
ในหน้าบันทึก คุณสามารถเลือกช่วงเวลาของบันทึกที่ต้องการดู ตามที่แสดงด้านล่าง บันทึกจะบันทึกการเรียกใช้เมธอด HTTP, การเรียกใช้ที่สำเร็จหรือล้มเหลว, ข้อความ console.log และอื่นๆ ป้อนสตริงการค้นหาในช่องค้นหาเพื่อแสดงรายการบันทึกทั้งหมดที่มีสตริงดังกล่าว
การใช้เครื่องมือติดตาม
เครื่องมือติดตามมีประโยชน์สำหรับการแก้ไขข้อบกพร่องของพร็อกซีทั่วไป ดูข้อมูลอย่างละเอียดเกี่ยวกับการใช้เครื่องมือติดตามได้ที่การใช้เครื่องมือติดตาม
เอาต์พุตของคอนโซลการพิมพ์
คุณสามารถฝังคำสั่ง console.log ในโค้ด Node.js และดูเอาต์พุตในเครื่องมือติดตามได้ เช่น คำสั่งต่อไปนี้จะพิมพ์ค่าของตัวแปร config.user
console.log('Logging in as %s', config.username);
หากต้องการดูเอาต์พุตของข้อความ console.log ในเครื่องมือติดตาม ให้เรียกใช้ API ในเครื่องมือติดตามแล้วคลิกเอาต์พุตจากธุรกรรมทั้งหมด เพื่อเปิดแผงเอาต์พุต
สมมติว่าคุณเรียกใช้โค้ดต่อไปนี้...
var http = require('http'); console.log('node.js application starting...'); var svr = http.createServer(function(req, resp) { resp.end('Hello, World!'); }); svr.listen(9000, function() { console.log('Node HTTP server is listening'); });
... คำสั่งคอนโซลจะปรากฏในแผง:
การกำหนดการตั้งค่าระยะหมดเวลาเป้าหมาย Nginx
หากคุณใช้ Nginx เป็นพร็อกซีและเห็นข้อผิดพลาด "เกตเวย์ไม่ถูกต้อง" ให้ลองเพิ่มการกำหนดค่าระยะหมดเวลาของพร็อกซี Nginx ตามที่อธิบายไว้ที่นี่
เช่น
proxy_connect_timeout 60; proxy_read_timeout 120;
การกำหนดค่าระยะหมดเวลาที่เหมาะสมขึ้นอยู่กับระยะเวลาที่เซิร์ฟเวอร์ใช้ในการตอบสนอง เช่น ระยะหมดเวลาการอ่าน 45-60 วินาทีอาจเป็นวิธีที่ดีที่สุดที่จะมอบบัฟเฟอร์ที่สมเหตุสมผล
การกำหนดการตั้งค่าระยะหมดเวลาเป้าหมายของ Apigee
นอกจากนี้ คุณยังกำหนดค่าระยะหมดเวลาเริ่มต้นของ Apigee ในองค์ประกอบ HttpTargetConnection ใน TargetEndpoint ได้ด้วย ค่าเริ่มต้นมีดังนี้
connect.timeout.millis - 60 seconds io.timeout.millis - 120 seconds
<HTTPTargetConnection> <Properties> <Property name="connect.timeout.millis">5000</Property> <Property name="io.timeout.millis">5000</Property> </Properties> <URL>http://www.google.com</URL> </HTTPTargetConnection>
โปรดดูข้อมูลอ้างอิงพร็อพเพอร์ตี้ปลายทางเพิ่มเติม
สำหรับข้อมูลเพิ่มเติม
ดูข้อมูลเพิ่มเติมเกี่ยวกับการแก้ไขข้อบกพร่องได้ที่
- การใช้เครื่องมือติดตาม
- การใช้เมตริกประสิทธิภาพ
- ข้อมูลเบื้องต้นเกี่ยวกับการแก้ปัญหา
- การตรวจสอบ: ประวัติ API, ผลิตภัณฑ์ และองค์กร
ขั้นตอนถัดไป
ดูข้อมูลเกี่ยวกับการรองรับโมดูล Node.js ใน Apigee Edge รวมถึงข้อมูลเกี่ยวกับการรองรับ HTTP/HTTPS, TLS และหัวข้อขั้นสูงอื่นๆ ได้ที่การทำความเข้าใจการรองรับ Edge สำหรับโมดูล Node.js