SigFox ถึง AWS: 29 ขั้นตอน
SigFox ถึง AWS: 29 ขั้นตอน

สารบัญ:

Anonim
SigFox เป็น AWS
SigFox เป็น AWS
SigFox เป็น AWS
SigFox เป็น AWS
SigFox เป็น AWS
SigFox เป็น AWS
SigFox เป็น AWS
SigFox เป็น AWS

I. บทนำ

1.ผู้เขียน

ฉันชื่อ Hooi Yong Hua และฉันมาจาก Singapore Polytechnic อนุปริญญาสาขาวิศวกรรมคอมพิวเตอร์

ฉันเป็นส่วนหนึ่งของกลุ่มที่ประกอบด้วยสมาชิก 3 คน; Low Jun Qian, Takuma kabeta และตัวฉันเอง

คำแนะนำนี้เป็นส่วนหนึ่งของโครงการเพื่อส่งข้อมูลจากเซ็นเซอร์ผ่านอินเทอร์เน็ตไปยังอุปกรณ์ปลายทางและการดำเนินการ

การวิเคราะห์ธุรกิจ ผู้ดูแลโครงการของเราคือ Mr Teo Shin Jen

2. วัตถุประสงค์

ส่งข้อมูลอะนาล็อกจากเซ็นเซอร์ (DS18B20) โดยใช้ Arduino พร้อม Sigfox Shield ทางอินเทอร์เน็ตไปยังเซิร์ฟเวอร์ sigfox จากนั้นส่งข้อมูลไปยัง AWS (Amazon Web Services Cloud) และจัดเก็บไว้ใน AWS Dynamo DataBase (DynamoDB)

3. วัตถุประสงค์

เพื่อลดความซับซ้อนของคำแนะนำในการทดสอบ Sensor to Arduino ไปยัง Sigfox ไปยัง AWS data transfer และเปรียบเทียบข้อมูลทั้งหมดในที่เดียว สำหรับรายละเอียดเพิ่มเติม โดยเฉพาะเกี่ยวกับ sigfox กับ AWSIot Connectivity ขอแนะนำให้อ่านบทความต้นฉบับโดย AWS

3. ทักษะที่จำเป็น:

1. คุ้นเคยกับ Arduino IDE รวมถึงการเพิ่มไลบรารี่และการอัพโหลดโค้ดไปยังบอร์ด Arduino 2. ความรู้พื้นฐานเกี่ยวกับ Amazon Web Service โดยเฉพาะการสร้าง Stack, DynamoDB และการสร้างกฎ

3. เปิดใช้งานการสมัครสมาชิก Sigfox แล้วและสามารถส่งข้อความ (ข้อมูล) จาก Sigfox Device ไปยัง SigFox Cloud

ครั้งที่สอง ติดตั้ง

ก.ฮาร์ดแวร์

1. Arduino Uno x1

2. Sigfox Arduino Shield: UnaShield_RC1692HP-SIG (รุ่น 1A) x1

3. วิทยุ Antannae x1

4. USB B to A Cable (เพื่อเชื่อมต่อ Arduino กับ PC) x1

5. การตั้งค่าเซนเซอร์ (BreadBoard, Temp Sensor DS18B20, 3x Male to Male Connectors; 1 voltage [red] 1 Ground [Black] 1 Data [White])

ข.ซอฟต์แวร์

1. Arduino IDE (เวอร์ชัน 1.8.1 ถูกใช้ในบทช่วยสอนนี้)

2. Arduino Library ชื่อ Unabiz Arduino Master Library พร้อมติดตั้ง Send - Light - Level แล้ว

C.บัญชี (ออนไลน์) & การสมัครสมาชิก

1. การสมัครสมาชิกเซิร์ฟเวอร์ Sigfox (มาพร้อมกับอุปกรณ์ Sigfox)

2. บัญชี Amazon AWS ที่เข้าถึงรูปแบบคลาวด์ (Stack Creation) & DynamoDB

การอ้างอิง IV:

aws.amazon.com/blogs/iot/connect-your-dev….

ขั้นตอนที่ 1: ตั้งค่า Arduino

Arduino ตั้งค่า
Arduino ตั้งค่า
Arduino ตั้งค่า
Arduino ตั้งค่า

A. ขั้นตอนแรกคือการอัปโหลดภาพร่างตัวอย่างส่งระดับแสงไปยัง Arduino

ในการทำเช่นนั้นให้เปิด arduino IDE คลิกที่คำต่อไปนี้ตามลำดับ: File > Example > unabiz-arduino-master (ภายใต้ส่วนย่อย Custom Libraries) > send-light-level อ้างถึงรูปที่ 5 หากมีคำใด ๆ ที่จำเป็นต้องคลิกดังกล่าวหายไป ให้ติดตั้ง unabiz arduino master library ใหม่ (ขั้นตอนในภาคผนวก 1) ทำซ้ำขั้นตอนที่ 1

B. เปลี่ยนรหัสอุปกรณ์เป็นอุปกรณ์ sigfox ของคุณ

บรรทัดของรหัสที่จะเปลี่ยนคือ (แสดงในรูปภาพ)

อุปกรณ์สตริงคงที่คงที่ = "xxxx"; // ตั้งค่านี้เป็นชื่ออุปกรณ์ของคุณหากคุณใช้ UnaBiz Emulator

C. ตรวจสอบและอัปโหลดรหัสไปยังอุปกรณ์ Arduino Sigfox

(อย่าลืมเลือกบอร์ดที่ถูกต้อง (ในกรณีนี้คือ arduino uno) และ Serial Port)

ขั้นตอนที่ 2:

ขั้นตอนที่ 3: Arduino Serial Monitor

Arduino Serial Monitor
Arduino Serial Monitor

ที่ Arduino IDE ให้เลือกเครื่องมือตามด้วย Serial Monitor ควรแสดง Message.addfield และ Radiocrafts.sendmessage: Radiocrafts.sendmessage: ตามด้วย sigfox deviceid

ขั้นตอนที่ 4: เข้าสู่ระบบ Sigfox

เข้าสู่ระบบ Sigfox
เข้าสู่ระบบ Sigfox

1. เข้าสู่ระบบที่

ขั้นตอนที่ 5: หน้าอุปกรณ์ Sigfox

หน้าอุปกรณ์ Sigfox
หน้าอุปกรณ์ Sigfox

2. คลิกที่แท็บอุปกรณ์ ประการที่สอง ตรวจสอบคอลัมน์ที่เห็นล่าสุด (C) เพื่อให้แน่ใจว่า sigfox ยังคงส่งข้อมูลอย่างแข็งขัน

หากผ่านไปประมาณ 15-20 นาที ความคลาดเคลื่อนระหว่างเวลาปัจจุบันกับเวลาที่แสดงไม่ลดลง แสดงว่า sigfox อาจมีปัญหา

จากนั้นคลิกที่อุปกรณ์ Sigfox ที่ใช้งานภายใต้คอลัมน์ประเภทอุปกรณ์ (B)

คุณจะถูกนำไปที่ส่วนประเภทอุปกรณ์

ขั้นตอนที่ 6: Sigfox Callback

Sigfox โทรกลับ
Sigfox โทรกลับ

เลือก Callback จากบานหน้าต่างด้านซ้ายสีม่วง (วงกลมสีแดง)

ขั้นตอนที่ 7: Sigfox โทรกลับใหม่

Sigfox โทรกลับใหม่
Sigfox โทรกลับใหม่

คลิกคำว่า New ที่มุมขวาบน ด้านล่างปุ่มออกจากระบบ (วงกลมสีแดง)

ขั้นตอนที่ 8: Sigfox สร้างประเภทการโทรกลับ

Sigfox สร้างประเภทการโทรกลับ
Sigfox สร้างประเภทการโทรกลับ

5. เลือก AWS IOT จากรายการประเภทการโทรกลับที่มี (ตำแหน่งที่สอง). คุณจะถูกนำไปที่หน้าถัดไป

ขั้นตอนที่ 9: Sigfox ไปยัง AWS CloudFormation

Sigfox ไปยัง AWS CloudFormation
Sigfox ไปยัง AWS CloudFormation

เลือกปุ่ม Launch Stack (A)

คุณจะถูกเปลี่ยนเส้นทางไปยังส่วนย่อยของ AWS CloudFormation Create Stack Page (สร้างเทมเพลต)

(หากคุณยังไม่ได้ลงชื่อเข้าใช้ aws ก่อนหน้านี้ คุณจะต้องทำตอนนี้)

จดบันทึก ID ภายนอก (B) เนื่องจากจะใช้ในภายหลัง

Region(C) สำหรับสิงคโปร์คือ ap-southeast-1 โปรดดูที่ https://docs.aws.amazon.com/general/latest/gr/ran… สำหรับภูมิภาคอื่นๆ

ขั้นตอนที่ 10: การสร้างสแต็ค AWS 1

AWS Stack Creation 1
AWS Stack Creation 1

ตรวจสอบให้แน่ใจว่าปุ่มข้าง ระบุ URL เทมเพลต Amazon S3 (A)

เลือกคำว่า NEXT ที่มุมล่างขวา (B)

คุณจะถูกนำไปที่หน้าถัดไป (ระบุรายละเอียดย่อย)

ขั้นตอนที่ 11: การสร้าง AWS Stack 2

AWS Stack Creation 2
AWS Stack Creation 2

ในหน้านี้ (ระบุรายละเอียด) คุณต้องกรอก 5 ช่อง ได้แก่ Stack Name, AWSAcountID, ExternalID, Region และ TopicName

คำแนะนำโดยละเอียดอยู่ด้านล่าง คลิกถัดไปหลังจากที่คุณทำเสร็จแล้ว (ที่มุมล่างขวา)

ประการแรกสำหรับ Stackname ให้ใช้ SigFoxIotConnector

ประการที่สองสำหรับ ID ภายนอก ใช้ข้อมูลที่จดบันทึกไว้ในขั้นตอนที่ 6 ID ภายนอก ใช้ข้อมูลที่จดบันทึกในขั้นตอนที่ 6

ประการที่สามสำหรับภูมิภาค ใช้ Ap-Southeast-1 (สำหรับสิงคโปร์) หรือดูที่ลิงค์นี้:

ประการที่สี่สำหรับ TopicName ใช้ sigfox

สุดท้ายสำหรับรหัสบัญชี AWS จะกล่าวถึงในขั้นตอนต่อไป

ขั้นตอนที่ 12: ตำแหน่งหมายเลขบัญชี AWS

ตำแหน่งหมายเลขบัญชี AWS
ตำแหน่งหมายเลขบัญชี AWS

เปิด AWS Console ในหน้าแยกโดยคลิกลิงก์นี้: https://ap-southeast-1.console.aws.amazon.com/con… (หรือด้วยวิธีอื่นใด)

คลิกปุ่มสนับสนุนที่มุมขวาบนทำให้เมนูเลื่อนลง

จากนั้นคลิกศูนย์บริการที่อยู่ในเมนูดรอปดาวน์

ขั้นตอนที่ 13: ตำแหน่งหมายเลขบัญชี AWS

ตำแหน่งหมายเลขบัญชี AWS
ตำแหน่งหมายเลขบัญชี AWS

ซึ่งจะนำคุณไปยังหน้าศูนย์สนับสนุน ซึ่งแสดง ID บัญชีที่มุมบนขวามือ ใต้ปุ่มสนับสนุน

ย้ายหมายเลข (หมายเลขบัญชี AWS) เป็น AWS AccountID ในขั้นตอนที่ 9 แล้วคลิกถัดไปที่มุมขวาล่างในหน้านั้น

ขั้นตอนที่ 14: การสร้าง AWS Stack

9. หน้านี้ (ตัวเลือก) ไม่จำเป็นสำหรับบทช่วยสอนนี้ คลิกถัดไปที่มุมล่างขวาจะนำคุณไปยังหน้ารีวิว

ขั้นตอนที่ 15: การสร้างสแต็ค AWS รอบชิงชนะเลิศ

AWS Stack Creation Final
AWS Stack Creation Final

ที่หน้าตรวจสอบ ตรวจสอบว่าการป้อนข้อมูลทั้งหมดถูกต้อง และภายใต้ความสามารถส่วนย่อย ให้ทำเครื่องหมายที่ช่องข้าง

ประโยค " ฉันรับทราบว่า AWS CloudFormation อาจสร้างทรัพยากร IAM"

สุดท้ายให้กดปุ่มสร้าง (มุมล่างขวาของหน้าจอ) เพื่อสร้าง stack

คุณจะกลับไปที่ Cloud Formation Management Console

ขั้นตอนที่ 16: รายละเอียดกอง AWS

รายละเอียดกอง AWS
รายละเอียดกอง AWS

t คอนโซลการจัดการ Cloudformation กองที่สร้างขึ้นใหม่ควรแสดง CREATE_COMPLETE ในคอลัมน์สถานะหลังจาก 2-10 นาที

คลิกชื่อกองเพื่อดูรายละเอียดเกี่ยวกับมัน

ขั้นตอนที่ 17: รายละเอียดกอง AWS 2

รายละเอียดกอง AWS 2
รายละเอียดกอง AWS 2

ค้นหาส่วนผลลัพธ์และคลิกลูกศรที่อยู่ข้างหน้า

คัดลอกคอลัมน์ค่าของ ARN Role และตรวจสอบว่าค่าอื่นๆ ถูกต้อง

ขั้นตอนที่ 18: การสร้างการโทรกลับ Sigfox รอบชิงชนะเลิศ

Sigfox Callback Creation Final
Sigfox Callback Creation Final
Sigfox Callback Creation Final
Sigfox Callback Creation Final

สลับกลับไปที่การตั้งค่าการโทรกลับของเว็บไซต์ SigFox (ขั้นตอนที่ 7; จากตำแหน่งที่ปุ่มสแต็ก llaunch อยู่) และกรอกข้อมูลในช่องที่เหลือทั้งหมด ยกเว้น custom payload config

คัดลอกบทบาท ARN ดังกล่าวไปยังบทบาทนี้

สำหรับ Json Body ให้คัดลอกและวางโค้ดด้านล่าง

หลังจากทั้งหมดที่ทำเสร็จแล้ว เลือกตกลง หน้าถัดไปแสดงการเชื่อมต่อการโทรกลับสำหรับอุปกรณ์ sigfox ที่เลือก

ขั้นตอนที่ 19: ตรวจสอบการสร้างการโทรกลับ Sigfox

การตรวจสอบการสร้างการโทรกลับ Sigfox
การตรวจสอบการสร้างการโทรกลับ Sigfox

ตรวจสอบให้แน่ใจว่าไม่มีข้อผิดพลาดและลิงก์ [POST] ใต้ส่วนข้อมูลจะคล้ายกับรูปภาพ

ขั้นตอนที่ 20: การสร้างตาราง DynamoDB ของ AWS

AWS-สร้างตาราง DynamoDB
AWS-สร้างตาราง DynamoDB
AWS-สร้างตาราง DynamoDB
AWS-สร้างตาราง DynamoDB

เลือก DynamDB ในเมนู amazon จากนั้นคลิกสร้างตาราง

ขั้นตอนที่ 21: AWS- การสร้างตาราง DynamoDB 2

AWS- การสร้างตาราง DynamoDB 2
AWS- การสร้างตาราง DynamoDB 2

เติมช่องว่างทั้งหมด

สำหรับ Table Name ให้ใส่ sigfox; สำหรับคีย์พาร์ติชั่น ให้ใส่ deviceid ตามด้วยกาเครื่องหมายที่กล่องคีย์การเรียงลำดับและใส่การประทับเวลา

คลิกสร้างเพื่อเสร็จสิ้น (อย่าแตะต้องการตั้งค่าใด ๆ ที่ไม่ได้กล่าวถึง) รอสักครู่เพื่อให้ตารางถูกสร้างขึ้นอย่างสมบูรณ์

ขั้นตอนที่ 22: การเข้าถึง AWSIot Console

การเข้าถึงคอนโซล AWSIot
การเข้าถึงคอนโซล AWSIot
การเข้าถึงคอนโซล AWSIot
การเข้าถึงคอนโซล AWSIot

เปิดคอนโซล AWS เลือก AWS Iot เลือก Rule จากนั้นเลือกสร้าง Rule

ขั้นตอนที่ 23: กฎการสร้าง AWS DynamoDB

กฎการสร้าง AWS DynamoDB
กฎการสร้าง AWS DynamoDB
กฎการสร้าง AWS DynamoDB
กฎการสร้าง AWS DynamoDB

4. กำหนดชื่อ Sigfox, * ให้กับแอตทริบิวต์และสุดท้ายใส่ sigofox ที่ตัวกรองหัวข้อ

ขั้นตอนที่ 24: AWS DynamoDB เพิ่มการดำเนินการ

AWS DynamoDB เพิ่มการดำเนินการ
AWS DynamoDB เพิ่มการดำเนินการ
AWS DynamoDB เพิ่มการดำเนินการ
AWS DynamoDB เพิ่มการดำเนินการ

ถัดไปคุณต้องสร้างการกระทำ เลือก เพิ่มการดำเนินการ แล้วเลือก " แทรกข้อความลงใน DynamoDB"

ขั้นตอนที่ 25: AWS DynamoDB เพิ่มการดำเนินการ 2

AWS DynamoDB เพิ่มการดำเนินการ 2
AWS DynamoDB เพิ่มการดำเนินการ 2

ใช้ชื่อเดียวกัน (sigfox) เพื่อกรอก Table Name

คีย์ Hash และ Rain ควรสร้างขึ้นเองโดยอัตโนมัติ

กรอก Hash Key Value ด้วย ${device} และ RangeKeyData Value ด้วย ${ timestamp()} ใต้ข้อความเขียน

สุดท้าย ให้กรอกข้อมูลลงในช่อง "เขียนข้อมูลข้อความลงในคอลัมน์นี้" พร้อมเพย์โหลด (ไม่อยู่ในวงกลม)

รูปภาพแสดงอยู่ด้านล่าง

ขั้นตอนที่ 26:

ขั้นตอนที่ 27: การสร้างบทบาท AWS DynamoDB

การสร้างบทบาท AWS DynamoDB
การสร้างบทบาท AWS DynamoDB

ถัดไปคือการสร้างบทบาทใหม่ ภายใต้ชื่อบทบาท IAM ให้ป้อน dynamodbsifox คลิกสร้างบทบาท จากนั้นคลิกเพิ่มการกระทำ

ขั้นตอนที่ 28: สิ้นสุดการสร้างบทบาท AWS DynamoDB

สิ้นสุดการสร้างบทบาท AWS DynamoDB
สิ้นสุดการสร้างบทบาท AWS DynamoDB

สุดท้าย คลิกสร้างกฎเพื่อสรุป (เพิ่มมุมขวาล่าง)

ขั้นตอนที่ 29:

ภาพ
ภาพ

กลับไปที่ตาราง DynamoDB และดูตารางที่เต็มไป

หมายเหตุ: หากไม่มีสิ่งใดปรากฏขึ้นในตาราง ปัญหาที่อาจเกิดขึ้น 1 ปัญหาอาจเป็นเพราะคอนโซล AWS อยู่ผิดภูมิภาค ตรวจสอบให้แน่ใจว่าภูมิภาคที่คอนโซล aws ตั้งอยู่นั้นเหมือนกับภูมิภาคที่ระบุในการสร้างสแต็ค