Daftar Isi:
- Langkah 1: Masuk ke Akun AWS Anda
- Langkah 2: Memulai Dengan "sesuatu" AWS IOT
- Langkah 3: Mendaftarkan "sesuatu" AWS IOT
- Langkah 4: Mengaktifkan Sertifikat
- Langkah 5: Menambahkan Kebijakan ke Sertifikat Anda
- Langkah 6: Pengaturan Awal untuk AWS SNS Topic
- Langkah 7: Membuat File Iot-role.trust.json
- Langkah 8: Membuat File Iot-policy.json
- Langkah 9: Buat Topik SNS AWS (Bagian 1)
- Langkah 10: Buat Topik SNS AWS (Bagian 2)
- Langkah 11: Buat Topik SNS AWS (Bagian 3)
- Langkah 12: Buat Bucket di Amazon S3
- Langkah 13: Buat Kebijakan AWS (Bagian 1)
- Langkah 14: Buat Kebijakan AWS (Bagian 2)
- Langkah 15: Membuat Tabel untuk DynamoDB
- Langkah 16: Roomstatus.py
- Langkah 17: Rfid.py
- Langkah 18: Server.py
- Langkah 19: Telegram.py
- Langkah 20: Streaming langsung (camera_pi.py)
Video: Seroma: Manajer Ruang Server: 20 Langkah
2025 Pengarang: John Day | [email protected]. Terakhir diubah: 2025-01-13 06:57
Seroma adalah pengelola ruang server all-in-one yang memungkinkan pengguna untuk memeriksa status server (suhu dan kelembaban), log akses ruang server, serta memantau ruang server itu sendiri untuk setiap pelanggaran keamanan.
Langkah 1: Masuk ke Akun AWS Anda
- Untuk milik kami, kami masuk melalui gateway siswa AWS Educate karena kami memiliki akun aws siswa.
- Buka tab "Akun AWS" pada menu navigasi di kanan atas.
- Klik “Buka Akun Pemula AWS Educate Anda”
- Buka Konsol untuk mengakses AWS Management Console Anda.
Langkah 2: Memulai Dengan "sesuatu" AWS IOT
- Cari “AWS IoT” di bilah pencarian layanan AWS.
- Klik "Mulai" untuk melanjutkan ke dasbor Konsol AWS IoT tempat Anda dapat melihat semua perangkat IoT yang terdaftar di akun AWS Anda.
Langkah 3: Mendaftarkan "sesuatu" AWS IOT
- Di bilah navigasi, navigasikan untuk mengelola "Hal" IoT Anda.
- Klik "Daftar sesuatu" jika Anda belum memilikinya. (Jika Anda sudah memiliki sesuatu, klik tombol "Buat" di kanan atas layar di sebelah tab pencarian.)
- Klik pada tombol pertama yang disebut "Buat satu hal".
- Ketik "RaspberryPi" sebagai nama benda itu. Untuk langkah ini, tidak ada input selain "Nama" yang diperlukan. Setelah melakukannya, klik berikutnya.
Langkah 4: Mengaktifkan Sertifikat
- Pada langkah selanjutnya, klik tombol “buat sertifikat”.
- Unduh dan simpan 4 tautan unduhan di halaman berikutnya ke dalam direktori atau folder yang berfungsi. Untuk menyimpan file CA root, klik kanan dan save-as.
- Klik "Aktifkan" dan pesan sukses akan muncul.
- Gunakan nama yang ramah untuk file dengan menghapus nomor di depan setiap nama file, dan mengganti nama file CA root menjadi "rootca.pem".
- Klik "Lampirkan kebijakan" untuk melanjutkan.
Langkah 5: Menambahkan Kebijakan ke Sertifikat Anda
- Di halaman berikutnya, jika Anda tidak memiliki kebijakan, mereka akan meminta Anda untuk membuatnya di tombol "Buat Kebijakan".
- Jika Anda sudah memiliki kebijakan, klik tombol “Buat kebijakan baru” di bawah.
-
Masukkan informasi berikut ke dalam formulir pembuatan kebijakan.
Nama: RaspberryPiSecurityPolicy
Tindakan: bodoh:*
Sumber Daya ARN: *
Efek: Izinkan
- Kebijakan Anda kemudian akan muncul di tab "Kebijakan" di bawah "Keamanan".
- Selanjutnya, buka tab “Sertifikat” yang juga berada di bawah “Keamanan”, dan lampirkan kebijakan Anda ke sertifikat yang Anda buat sebelumnya.
- Pada halaman berikutnya, klik pada kebijakan Anda dan kemudian klik "Lampirkan".
- Di halaman Detail dari hal yang Anda buat, di bawah tab "Berinteraksi", ada titik akhir REST API yang harus disalin dan disimpan.
- AWS sekarang harus memiliki Hal yang dilampirkan pada kebijakan dan memiliki sertifikat.
Langkah 6: Pengaturan Awal untuk AWS SNS Topic
SSH ke Raspberry Pi dan instal AWS CLI menggunakan perintah pip berikut:
sudo pip install awscli
AWS CLI menyertakan fitur penyelesaian perintah tetapi tidak diinstal secara default. Gunakan perintah berikut untuk menginstal fitur penyelesaian perintah pada antarmuka CLI Raspberry Pi:
lengkap -C aws_completer aws
Konfigurasikan AWS CLI dengan ID Kunci Akses, Kunci Akses Rahasia, Nama Wilayah AWS, dan format Output Perintah menggunakan perintah berikut:
konfigurasi aws
Konsol kemudian akan meminta Anda untuk mengisi informasi berikut:
pi@raspberrypi:~ $ aws konfigurasi
AWS Access Key ID [None]: "Let your User's Access Key ID here" AWS Secret Access Key [None]: "Let your User's Secret Access Key here" Nama wilayah default [None]: eu-central-1 Format output default [Tidak ada]: json pi@raspberrypi:~ $
Langkah 7: Membuat File Iot-role.trust.json
- Buat file JSON dengan kebijakan IAM di atas dengan nama file iot-role.trust.json.
- Buat peran menggunakan AWS CLI menggunakan perintah berikut
aws iam create-role --role-name my-iot-role --assume-role-policy-document file://iot-role-trust.json
Langkah 8: Membuat File Iot-policy.json
- Buat file JSON dengan kebijakan di atas dengan nama file iot-policy.json.
- Buat kebijakan peran menggunakan AWS CLI menggunakan perintah berikut:
aws iam put-role-policy --role-name IoTRole --policy-name iot-policy --policy-document file://iot-policy.json
Langkah 9: Buat Topik SNS AWS (Bagian 1)
- Di bilah pencarian layanan AWS, Cari layanan “SNS” atau kunjungi
- Karena Anda tidak memiliki topik sekarang, klik "Buat topik baru" untuk membuat topik.
- Ketik nama topik dan nama tampilan Anda dan klik "Buat topik" dan topik baru akan muncul ketika semua langkah berhasil.
- Klik tombol tarik-turun "Tindakan" dan "Edit kebijakan topik".
Langkah 10: Buat Topik SNS AWS (Bagian 2)
- Tetapkan kebijakan untuk mengizinkan semua orang memublikasikan dan berlangganan, karena ini adalah batasan akun AWSEducate.
- Berlangganan topik ini untuk menerima pembaruan yang dipublikasikan untuk topik ini.
-
Ubah protokol menjadi "Email" dan masukkan email Anda di titik akhir.
- Buka email tempat Anda mengetik titik akhir, klik tautan konfirmasi untuk mengonfirmasi langganan email Anda untuk berlangganan topik tersebut.
- Arahkan ke layanan “AWS IoT”, pada menu navigasi di sebelah kiri, klik “Act”. Halaman ini adalah tempat aturan Anda ditampilkan dan tersedia untuk Anda lihat dan edit. Saat ini, tidak ada aturan untuk hal IoT Anda, klik "Buat aturan".
Langkah 11: Buat Topik SNS AWS (Bagian 3)
- Ketik nama di bidang Nama untuk aturan Anda. Di bidang Deskripsi, ketikkan deskripsi untuk aturan Anda. Melanjutkan ke bagian Sumber pesan, kami akan memilih versi SQL terbaru di bagian "Menggunakan versi SQL". Ketik * di atribut untuk memilih seluruh pesan MQTT dari topik, dalam kasus kami topik kami adalah "TempHumid".
- Kemudian tambahkan tindakan notifikasi "SNS" untuk aturan Anda. Kemudian, klik "Konfigurasikan tindakan".
- Di halaman "Konfigurasi tindakan", pilih topik SNS yang baru saja Anda buat dan format pesan sebagai RAW. Setelah itu, pilih peran yang baru saja Anda buat menggunakan AWS CLI dan klik “Tambahkan tindakan”.
- Tindakan Anda akan dikonfigurasi dan kembali ke "Buat aturan".
- Klik edit jika Anda ingin mengedit aturan.
Langkah 12: Buat Bucket di Amazon S3
- Cari S3 di bilah pencarian AWS.
- Di halaman Amazon S3, klik tombol “Buat Bucket” untuk memulai.
-
Isi formulir pop-up yang muncul dengan informasi berikut:
- Nama Bucket: seroma-bucket (ini harus unik di semua bucket Amazon S3 yang ada)
- Wilayah: AS Barat (Oregon)
- Pengaturan Salin: (Abaikan)
- Untuk langkah 2 hingga 3, lewati saja dengan mengklik "Berikutnya" karena tidak ada yang perlu diubah. Pada langkah 4, klik "Buat ember".
- Setelah pembuatan, Anda akan melihat ember Anda di halaman beranda.
Langkah 13: Buat Kebijakan AWS (Bagian 1)
- Klik pada keranjang yang Anda buat untuk masuk ke halaman di atas, lalu lanjutkan ke "Kebijakan Bucket" di bawah tab "Izin".
- Selanjutnya, klik tautan “Pembuat Kebijakan” di bagian bawah halaman untuk membuat kebijakan AWS Anda.
-
Dalam formulir, masukkan nilai-nilai berikut:
- Jenis Kebijakan: Kebijakan Bucket S3
- Efek: Izinkan
- Kepala sekolah: *
- Layanan AWS: Amazon S3
- Tindakan: GetObject
- Nama Sumber Daya Amazon (ARN): arn:aws:s3:::seroma-bucket
- Setelah mengisi informasi, klik Tambah Pernyataan.
- Klik tombol "Hasilkan Kebijakan".
Langkah 14: Buat Kebijakan AWS (Bagian 2)
- Salin kode yang dihasilkan dan klik tutup.
- Kembali ke editor Amazon S3 Bucket Policy dan tempelkan kode yang disalin sebelumnya.
- Tambahkan “/*” ke dalam kode tepat di belakang kode Resource, seperti pada gambar di atas, lalu klik simpan.
- Setelah melakukannya, ember Anda akan berhasil disiapkan dan siap digunakan.
Langkah 15: Membuat Tabel untuk DynamoDB
- Cari DynamoDB di bilah pencarian Layanan AWS
-
Klik "Buat tabel" dan buat 3 tabel dengan informasi di bawah ini: (Hanya "nama tabel" dan "kunci utama" yang diubah)
- accesslog, pk datetimevalue
- roomstatus, pk datetimevalue
- data staf, nama pengguna pk
Langkah 16: Roomstatus.py
Bagian ini berisi kode untuk roomstatus.py, yang menulis semua data tentang ruang server itu sendiri setiap menit. Ini termasuk suhu, kelembaban, gerakan (gambar dan video jika benar), dan log akses. Itu juga menulis data ke Google Spreadsheet, data ke DynamoDB, gambar dan video (jika ada) ke S3, menampilkan informasi di layar LCD, mengirim SMS dan Email ketika ada dugaan pelanggaran, atau ketika suhu atau kelembapan tidak teratur.
Untuk menjalankan file python, ubah direktori ke tempat file berada dan ketik konsol: "sudo python"
Pic 2: Fungsi yang dideklarasikan untuk memungkinkan peringatan SMS dan Email, dan mengunggah ke S3
Pic 3: Variabel dideklarasikan agar fungsi dan RPi berfungsi
Pic 4: Mulai dari loop yang mendapatkan nilai suhu dan kelembaban dari RPi. Itu juga menulis data ke spreadsheet Google
Pic 5: Bagian keamanan dari loop. Ini hanya akan aktif dari jam 7 malam sampai jam 7 pagi (off hours). Ini akan memeriksa gerakan dalam rentang satu menit. Jika gerakan terdeteksi, ia akan mengambil gambar dan video, mengunggahnya ke S3, sambil juga menulis informasi ke DynamoDB untuk referensi nanti. Setelah itu, akan mengirimkan SMS dan Email jika ada yang tidak wajar.
Pic 6: Akhir dari loop. Itu juga menulis data ke DynamoDB dan mengirimkan peringatan yang sesuai. Baris terakhir dari loop akan membuat skrip tidur hingga menit berikutnya tercapai.
Langkah 17: Rfid.py
Bagian ini berisi kode untuk rfid.py, yang menambahkan fungsi untuk melacak ketika seorang anggota staf mengakses ruang server. Ini juga merupakan bagian dari aspek keamanan Seroma, di mana seorang anggota staf tidak diperbolehkan mengakses ruang server setelah jam kantor, untuk mencegah pelanggaran data. Itu juga mengirim Email dan SMS ke semua staf jika ada dugaan pelanggaran.
Pic 2: Mulai dari logika pembaca RFID. Setiap kali kartu dipindai terhadap pembaca, id unik (uid) kartu diambil. Setelah itu, kami mencoba mencari nilai uid kartu di tabel data staf untuk melihat apakah kartu itu milik salah satu staf. Gambar 3: Jika uid kartu ada di database, itu akan memeriksa apakah itu selama kantor di luar jam kerja. Jika ya, ia akan memberi tahu karyawan lainnya melalui SMS dan Email ke alamat email yang dilanggan. Jika masih pada jam kantor, maka akan menulis baris ke tabel accesslog di database dengan data yang relevan. Ini juga akan menampilkan pesan selamat datang di layar LCD.
Langkah 18: Server.py
Ini adalah file server.py. Kami akan menggunakan kerangka Flask untuk portal web. File HTML untuk dimasukkan ke dalam /template juga dilampirkan.
Gambar 1: Rute pertama untuk Flask ditentukan. Ini akan mengarahkan pengguna ke halaman login jika mereka tidak login, dan halaman dasbor jika mereka login. Juga mendefinisikan fungsi yang akan digunakan dalam fitur streaming langsung
Gambar 2, 3, 4: Rute untuk Flask. Itu mendapatkan data dari tabel DynamoDB dan kemudian mengembalikannya ke file HTML sehingga bisa digunakan di sana.
Pic 5: 2 rute terakhir untuk Flask. Ini menangani fungsi logout dan fungsi streaming langsung. Ini juga menentukan port yang akan dijalankan situs web.
Langkah 19: Telegram.py
Bagian ini berisi kode untuk bot telegram Seroma. Ini menggunakan perpustakaan telepot untuk mengetuk Bot API Telegram. Ia bekerja dengan menerima kueri yang didapatnya dan menampilkan informasi masing-masing kepada pengguna. Pengguna dapat mengetik 'bantuan' untuk daftar lengkap perintah.
Pic 1, 2: Untuk mengatur bot telegram, Anda perlu menggunakan BotFather. Jalankan saja instruksi untuk mendapatkan HTTP API yang kita butuhkan dalam kode kita.
Gambar 4: Contoh fungsi yang mengambil sejumlah baris data dari database berdasarkan permintaan pengguna
Gambar 5: Bagaimana kami menerima masukan pengguna dan memutuskan apa yang harus dijalankan.
Langkah 20: Streaming langsung (camera_pi.py)
Kami telah menerapkan fitur baru untuk sistem pemantauan ruang server kami, streaming langsung dari apa yang terjadi di Ruang Server, ini dapat diakses kapan saja, di mana saja. Cara kerja streaming langsung ini: Ini adalah fitur yang dilakukan di Flask, bersama dengan Pi Camera. Bingkai video diunduh seperti yang terjadi dalam kehidupan nyata, sehingga Anda benar-benar dapat melihat bahwa ada sedikit penundaan (1-2 detik) saat bingkai video diunduh dan disatukan. Ini tidak dapat dilakukan tanpa threading, karena thread latar belakang membaca frame dari kamera dan menyimpan frame saat ini. Menggabungkan semua bingkai ini akan menghasilkan streaming langsung.
Pic 2: Ini adalah file terpisah di mana semua frame video disimpan dan seperti yang Anda lihat, kami menggunakan modul picamera untuk mengakses kamera raspberry pi kami karena itulah yang paling kami kenal. Kami memiliki Kamera kelas sehingga kami dapat mengimpor fungsi seolah-olah itu adalah streaming langsung dan bukan beberapa gambar yang disatukan, maka dalam file aplikasi utama akan menganggapnya sebagai streaming langsung tanpa harus khawatir tentang apa yang terjadi di balik layar.
Pic 3: Ini adalah bagian dari file server.py kami di mana bagian streaming langsung dikodekan. Kelas utama yang kami impor untuk ini adalah Kamera dari file camera_pi.py kami di bagian atas file server.py kami. Kami mendefinisikan fungsi di direktori root kami, gen, namun itu hanya mulai digunakan ketika kami menuju ke /video_feed tempat streaming langsung kami berada, di mana ia akan mengulang fungsi ini dan mengembalikan streaming langsung di halaman web.