Seroma: Serverio kambario tvarkyklė: 20 žingsnių
Seroma: Serverio kambario tvarkyklė: 20 žingsnių

Video: Seroma: Serverio kambario tvarkyklė: 20 žingsnių

Video: Seroma: Serverio kambario tvarkyklė: 20 žingsnių
Video: Умное окно - автоматизация проветривания комнаты, интеграция в Home Assistant 2025, Sausis
Anonim
Seroma: serverio kambario valdytojas
Seroma: serverio kambario valdytojas

„Seroma“yra „viskas viename“serverių kambario tvarkyklė, leidžianti vartotojams patikrinti serverių būseną (temperatūrą ir drėgmę), serverio patalpos prieigos žurnalus, taip pat stebėti pačią serverio patalpą, ar nėra saugumo pažeidimų.

1 veiksmas: prisijunkite prie savo AWS paskyros

Prisijunkite prie savo AWS paskyros
Prisijunkite prie savo AWS paskyros
Prisijunkite prie savo AWS paskyros
Prisijunkite prie savo AWS paskyros
Prisijunkite prie savo AWS paskyros
Prisijunkite prie savo AWS paskyros
Prisijunkite prie savo AWS paskyros
Prisijunkite prie savo AWS paskyros
  1. Mūsų atveju mes prisijungėme per AWS švietimo studentų vartus, nes turime studentų aws paskyrą.
  2. Eikite į skirtuką „AWS paskyra“naršymo meniu viršuje dešinėje.
  3. Spustelėkite „Eiti į„ AWS Educate Starter “paskyrą“
  4. Atidarykite „Console“, kad pasiektumėte AWS valdymo pultą.

2 veiksmas: pradėkite nuo AWS IOT „dalykų“

Darbo su AWS IOT pradžia
Darbo su AWS IOT pradžia
Darbo su AWS IOT pradžia
Darbo su AWS IOT pradžia
  1. AWS paslaugų paieškos juostoje ieškokite „AWS IoT“.
  2. Spustelėkite „Pradėti“, kad pereitumėte į „AWS IoT Console“prietaisų skydelį, kuriame galėsite peržiūrėti visus jūsų AWS paskyroje registruotus „IoT“įrenginius.

3 žingsnis: užregistruokite AWS IOT „dalyką“

AWS IOT registravimas
AWS IOT registravimas
AWS IOT registravimas
AWS IOT registravimas
AWS IOT registravimas
AWS IOT registravimas
  1. Naršymo juostoje pereikite prie savo daiktų interneto „dalykų“tvarkymo.
  2. Spustelėkite „Užregistruoti daiktą“, jei to dar neturite. (Jei jau turite ką nors, spustelėkite mygtuką „Sukurti“, esantį viršutiniame dešiniajame ekrano kampe šalia paieškos skirtuko.)
  3. Spustelėkite pirmąjį mygtuką „Sukurti vieną dalyką“.
  4. Įveskite „RaspberryPi“kaip daikto pavadinimą. Atliekant šį veiksmą, nereikia jokių kitų įėjimų, išskyrus „Pavadinimą“. Tai padarę spustelėkite „Kitas“.

4 žingsnis: suaktyvinkite sertifikatą

Sertifikato aktyvinimas
Sertifikato aktyvinimas
Sertifikato aktyvinimas
Sertifikato aktyvinimas
  1. Kitame žingsnyje spustelėkite mygtuką „sukurti sertifikatą“.
  2. Atsisiųskite ir išsaugokite 4 atsisiuntimo nuorodas kitame puslapyje į darbinį katalogą ar aplanką. Norėdami išsaugoti pagrindinį CA failą, dešiniuoju pelės mygtuku spustelėkite ir išsaugokite kaip.
  3. Spustelėkite „Aktyvinti“ir pasirodys sėkmės pranešimas.
  4. Naudokite draugiškus failų pavadinimus, pašalindami skaičius prieš kiekvieno failo pavadinimą ir pervadindami šakninį CA failą į „rootca.pem“.
  5. Norėdami tęsti, spustelėkite „Pridėti politiką“.

5 veiksmas: pridėkite politiką prie sertifikato

Politikos pridėjimas prie sertifikato
Politikos pridėjimas prie sertifikato
Politikos pridėjimas prie sertifikato
Politikos pridėjimas prie sertifikato
Politikos pridėjimas prie sertifikato
Politikos pridėjimas prie sertifikato
  1. Kitame puslapyje, jei neturite politikos, jie paragins ją sukurti mygtuke „Sukurti politiką“.
  2. Jei jau turite politiką, spustelėkite žemiau esantį mygtuką „Sukurti naują politiką“.
  3. Įveskite šią informaciją į politikos kūrimo formą.

    Pavadinimas: RaspberryPiSecurityPolicy

    Veiksmas: iot:*

    Šaltinis ARN: *

    Poveikis: leiskite

  4. Tada jūsų politika turėtų būti rodoma skirtuko „Politika“skiltyje „Sauga“.
  5. Tada eikite į skirtuką „Sertifikatai“, kuris taip pat yra skiltyje „Sauga“, ir pridėkite savo politiką prie anksčiau sukurto sertifikato.
  6. Kitame puslapyje spustelėkite savo politiką, tada spustelėkite „Pridėti“.
  7. Jūsų sukurto daikto išsamios informacijos puslapyje, skirtuke „Sąveika“, yra REST API galinis taškas, kurį reikia nukopijuoti ir išsaugoti.
  8. AWS dabar turėtų turėti dalyką, pridėtą prie politikos ir turintį sertifikatą.

6 veiksmas: pradinis AWS SNS temos nustatymas

Pradinė AWS SNS temos sąranka
Pradinė AWS SNS temos sąranka
Pradinė AWS SNS temos sąranka
Pradinė AWS SNS temos sąranka

SSH į Raspberry Pi ir įdiekite AWS CLI naudodami šią komandą pip:

sudo pip įdiegti awscli

AWS CLI apima komandų užbaigimo funkciją, tačiau ji nėra įdiegta pagal numatytuosius nustatymus. Naudokite šią komandą, kad įdiegtumėte komandų užbaigimo funkciją „Raspberry Pi“CLI sąsajoje:

baigti -C aws_completer aws

Konfigūruokite AWS CLI naudodami prieigos rakto ID, slaptą prieigos raktą, AWS regiono pavadinimą ir komandos išvesties formatą naudodami šią komandą:

aws konfigūruoti

Tada konsolė paragins įvesti šią informaciją:

pi@raspberrypi: ~ $ aws konfigūruoti

AWS prieigos rakto ID [Nėra]: „Įdėkite savo vartotojo prieigos rakto ID čia“AWS slaptas prieigos raktas [Nėra]: „Įdėkite savo vartotojo slaptą prieigos raktą čia“Numatytasis regiono pavadinimas [Nėra]: eu-central-1 Numatytasis išvesties formatas [Nėra]: json pi@raspberrypi: ~ $

7 veiksmas: sukurkite failą „Iot-role.trust.json“

Kuriamas failas „Iot-role.trust.json“
Kuriamas failas „Iot-role.trust.json“
Kuriamas failas „Iot-role.trust.json“
Kuriamas failas „Iot-role.trust.json“
  1. Sukurkite JSON failą naudodami aukščiau pateiktą IAM politiką su failo pavadinimu iot-role.trust.json.
  2. Sukurkite vaidmenį naudodami AWS CLI naudodami šią komandą

aws iam create-role --role-name my-iot-role-tarkime-role-policy-document file: //iot-role-trust.json

8 veiksmas: sukurkite failą „Iot-policy.json“

„Iot-policy.json“failo kūrimas
„Iot-policy.json“failo kūrimas
„Iot-policy.json“failo kūrimas
„Iot-policy.json“failo kūrimas
  1. Sukurkite JSON failą naudodami aukščiau nurodytą politiką su failo pavadinimu iot-policy.json.
  2. Sukurkite vaidmenų politiką naudodami AWS CLI naudodami šią komandą:

aws iam put-role-policy --role-name IoTRole --policy-name iot-policy --policy-document file: //iot-policy.json

9 veiksmas: sukurkite AWS SNS temą (1 dalis)

Sukurkite AWS SNS temą (1 dalis)
Sukurkite AWS SNS temą (1 dalis)
Sukurkite AWS SNS temą (1 dalis)
Sukurkite AWS SNS temą (1 dalis)
Sukurkite AWS SNS temą (1 dalis)
Sukurkite AWS SNS temą (1 dalis)
  1. AWS paslaugų paieškos juostoje ieškokite „SNS“paslaugos arba eikite į
  2. Kadangi dabar neturite temų, spustelėkite „Sukurti naują temą“, kad sukurtumėte temą.
  3. Įveskite temos pavadinimą ir rodomą pavadinimą ir spustelėkite „Sukurti temą“, o kai visi veiksmai bus sėkmingi, pasirodys nauja tema.
  4. Spustelėkite išskleidžiamąjį mygtuką „Veiksmai“ir „Redaguoti temos politiką“.

10 veiksmas: sukurkite AWS SNS temą (2 dalis)

Sukurkite AWS SNS temą (2 dalis)
Sukurkite AWS SNS temą (2 dalis)
Sukurkite AWS SNS temą (2 dalis)
Sukurkite AWS SNS temą (2 dalis)
Sukurkite AWS SNS temą (2 dalis)
Sukurkite AWS SNS temą (2 dalis)
  1. Nustatykite politiką, kad visi galėtų skelbti ir prenumeruoti, nes tai yra AWSEducate paskyros apribojimai.
  2. Prenumeruokite šią temą, kad gautumėte naujinius, paskelbtus šia tema.
  3. Pakeiskite protokolą į „Email“ir įveskite savo el.

  4. Eikite į savo el. Paštą, kuriame įvedėte galutinį tašką, spustelėkite patvirtinimo nuorodą, kad patvirtintumėte savo el. Pašto prenumeratą, kad galėtumėte užsiprenumeruoti temą.
  5. Eikite į „AWS IoT“paslaugas, kairėje esančiame naršymo meniu spustelėkite „Veikti“. Šiame puslapyje rodomos jūsų taisyklės, kurias galite peržiūrėti ir redaguoti. Šiuo metu jūsų daiktų interneto dalykui nėra taisyklių, spustelėkite „Sukurti taisyklę“.

11 veiksmas: sukurkite AWS SNS temą (3 dalis)

Sukurkite AWS SNS temą (3 dalis)
Sukurkite AWS SNS temą (3 dalis)
Sukurkite AWS SNS temą (3 dalis)
Sukurkite AWS SNS temą (3 dalis)
Sukurkite AWS SNS temą (3 dalis)
Sukurkite AWS SNS temą (3 dalis)
  1. Įveskite savo taisyklės pavadinimą lauke Pavadinimas. Lauke Aprašymas įveskite savo taisyklės aprašymą. Tęsdami pranešimų šaltinio skyrių, skyriuje „SQL versijos naudojimas“pasirinktume naujausią SQL versiją. Įveskite * į atributą, kad pasirinktumėte visą MQTT pranešimą iš temos, mūsų atveju mūsų tema yra „TempHumid“.
  2. Tada prie taisyklės pridėkite „SNS“pranešimo veiksmą. Tada spustelėkite „Konfigūruoti veiksmą“.
  3. Puslapyje „Konfigūruoti veiksmą“pasirinkite ką tik sukurtą SNS temą ir pranešimo formatą kaip RAW. Po to pasirinkite vaidmenį, kurį ką tik sukūrėte naudodami AWS CLI, ir spustelėkite „Pridėti veiksmą“.
  4. Jūsų veiksmas bus sukonfigūruotas ir grįš į „Sukurti taisyklę“.
  5. Jei norite redaguoti taisyklę, spustelėkite Redaguoti.

12 veiksmas: sukurkite kibirą „Amazon S3“

Sukurkite kibirą „Amazon S3“
Sukurkite kibirą „Amazon S3“
Sukurkite kibirą „Amazon S3“
Sukurkite kibirą „Amazon S3“
Sukurkite kibirą „Amazon S3“
Sukurkite kibirą „Amazon S3“
  1. Ieškokite S3 AWS paieškos juostoje.
  2. Norėdami pradėti, „Amazon S3“puslapyje spustelėkite mygtuką „Sukurti kibirą“.
  3. Užpildykite pasirodžiusią iššokančią formą, nurodydami šią informaciją:

    • Kaušo pavadinimas: seroma-kibiras (jis turi būti unikalus visuose esamuose „Amazon S3“kibiruose)
    • Regionas: JAV vakarai (Oregonas)
    • Kopijavimo nustatymai: (ignoruoti)
  4. Norėdami atlikti 2–3 veiksmus, tiesiog praleiskite jį spustelėdami „Kitas“, nes nieko nereikia keisti. 4 veiksme spustelėkite „Sukurti grupę“.
  5. Sukūrę pagrindiniame puslapyje turėtumėte pamatyti savo grupę.

13 veiksmas: sukurkite AWS politiką (1 dalis)

Sukurkite AWS politiką (1 dalis)
Sukurkite AWS politiką (1 dalis)
Sukurkite AWS politiką (1 dalis)
Sukurkite AWS politiką (1 dalis)
Sukurkite AWS politiką (1 dalis)
Sukurkite AWS politiką (1 dalis)
  1. Spustelėkite sukurtą grupę, kad patektumėte į aukščiau esantį puslapį, tada skirtuke „Leidimai“pereikite prie „Bucket Policy“.
  2. Tada puslapio apačioje spustelėkite nuorodą „Politikos generatorius“, kad sukurtumėte AWS politiką.
  3. Formoje įveskite šias reikšmes:

    • Politikos tipas: S3 kibiro politika
    • Poveikis: leiskite
    • Pagrindinis: *
    • AWS paslauga: „Amazon S3“
    • Veiksmai: „GetObject“
    • „Amazon“išteklių pavadinimas (ARN): arn: aws: s3::: seroma-bucket
  4. Užpildę informaciją, spustelėkite Pridėti pareiškimą.
  5. Spustelėkite mygtuką „Sukurti politiką“.

14 veiksmas: sukurkite AWS politiką (2 dalis)

Sukurkite AWS politiką (2 dalis)
Sukurkite AWS politiką (2 dalis)
Sukurkite AWS politiką (2 dalis)
Sukurkite AWS politiką (2 dalis)
Sukurkite AWS politiką (2 dalis)
Sukurkite AWS politiką (2 dalis)
Sukurkite AWS politiką (2 dalis)
Sukurkite AWS politiką (2 dalis)
  1. Nukopijuokite sugeneruotus kodus ir spustelėkite uždaryti.
  2. Grįžkite į „Amazon S3 Bucket Policy“redaktorių ir įklijuokite anksčiau nukopijuotus kodus.
  3. Įtraukite „/*“į kodus iškart po išteklių kodais, kaip parodyta aukščiau esančiame paveikslėlyje, tada spustelėkite išsaugoti.
  4. Tai padarius, kibiras bus sėkmingai nustatytas ir paruoštas naudoti.

15 veiksmas: lentelių kūrimas „DynamoDB“

Lentelių kūrimas „DynamoDB“
Lentelių kūrimas „DynamoDB“
Lentelių kūrimas „DynamoDB“
Lentelių kūrimas „DynamoDB“
  1. Ieškokite „DynamoDB“AWS paslaugų paieškos juostoje
  2. Spustelėkite „Sukurti lentelę“ir sukurkite 3 lenteles su toliau pateikta informacija: (keičiami tik „lentelės pavadinimas“ir „pagrindinis raktas“)

    • accesslog, pk datetimevalue
    • kambario būsena, pk datetimevalue
    • staffdata, pk vartotojo vardas

16 žingsnis: Roomstatus.py

Roomstatus.py
Roomstatus.py
Roomstatus.py
Roomstatus.py
Roomstatus.py
Roomstatus.py
Roomstatus.py
Roomstatus.py

Šiame skyriuje yra roomstatus.py kodas, kuris kiekvieną minutę įrašo visus duomenis apie patį serverio kambarį. Tai apima temperatūrą, drėgmę, judesį (vaizdai ir vaizdo įrašai, jei tai tiesa) ir prieigos žurnalus. Ji taip pat įrašo duomenis į „Google“skaičiuoklę, duomenis į „DynamoDB“, vaizdus ir vaizdo įrašus (jei yra) į S3, pateikia informaciją LCD ekrane, siunčia SMS ir el. Laišką, kai įtariamas pažeidimas arba kai temperatūra ar drėgmė yra nereguliari.

Norėdami paleisti „Python“failus, pakeiskite katalogą į failo vietą ir įveskite konsolėje: „sudo python“

2 pav. Deklaruojamos funkcijos, leidžiančios gauti SMS ir el. Pašto įspėjimus ir įkelti į S3

3 pav. Kintamieji, nurodyti funkcijoms ir RPi veikti

4 nuotrauka: ciklo pradžia, kuri iš RPi gauna temperatūros ir drėgmės vertes. Ji taip pat įrašo duomenis į „Google“skaičiuoklę

5 pav. Saugos dalis. Jis bus aktyvuotas tik nuo 19:00 iki 7:00 (ne darbo valandomis). Jis patikrins judesį per minutę. Jei aptinkamas judesys, jis nufotografuos vaizdą ir vaizdo įrašą, įkels jį į S3, o taip pat įrašys informaciją į „DynamoDB“, kad vėliau galėtų ją peržiūrėti. Vėliau ji atsiųs SMS ir el. Laišką, jei kas nors bus ne taip.

6 nuotrauka: ciklo pabaiga. Ji taip pat rašo duomenis į „DynamoDB“ir atitinkamai siunčia įspėjimus. Paskutinė ciklo eilutė privers scenarijų užmigti, kol bus pasiekta kita minutė.

17 veiksmas: Rfid.py

Rfid.py
Rfid.py
Rfid.py
Rfid.py
Rfid.py
Rfid.py
Rfid.py
Rfid.py

Šiame skyriuje yra „rfid.py“kodas, kuris prideda funkcijų, skirtų stebėti, kai darbuotojas pasiekia serverio kambarį. Tai taip pat yra „Seroma“saugumo aspekto dalis, kai darbuotojui neleidžiama patekti į serverio kambarį po darbo valandų, kad būtų išvengta duomenų pažeidimo. Įtarus pažeidimą, ji taip pat siunčia el. Laišką ir SMS žinutes visiems darbuotojams.

2 pav. RFID skaitytuvo logikos pradžia. Kai kortelė nuskenuojama prieš skaitytuvą, imamas unikalus kortelės ID (uid). Vėliau mes stengiamės surasti kortelės uid vertę personalo duomenų lentelėje, kad pamatytume, ar kortelė priklauso kokiam nors personalui. 3 paveikslas: jei kortelės uid yra duomenų bazėje, ji patikrins, ar ji yra biure ne darbo valandomis. Jei taip, ji įspės likusius darbuotojus SMS žinute ir el. Jei jis vis dar yra darbo valandomis, jis įrašys eilutę į prieigos žurnalo lentelę duomenų bazėje su atitinkamais duomenimis. Taip pat LCD ekrane bus rodomas pasveikinimo pranešimas.

18 veiksmas: Server.py

Server.py
Server.py
Server.py
Server.py
Server.py
Server.py

Tai yra server.py failas. Interneto portale naudosime kolbos sistemą. Taip pat pridedami HTML failai /šablonai.

1 pav. Apibrėžtas pirmasis kolbos maršrutas. Jis nukreipia vartotoją į prisijungimo puslapį, jei jis nėra prisijungęs, ir prietaisų skydelio puslapį, jei jis yra. Taip pat apibrėžia funkciją, kuri turi būti naudojama tiesioginio srauto funkcijoje

2, 3, 4 pav. Kolbos maršrutai. Jis gauna duomenis iš „DynamoDB“lentelės ir grąžina juos į HTML failus, kad juos būtų galima ten naudoti.

5 nuotrauka: paskutiniai 2 „Flask“maršrutai. Jis tvarko atsijungimo ir tiesioginio srauto funkciją. Jame taip pat nurodomas prievadas, kuriuo svetainė veiks.

19 veiksmas: Telegram.py

Telegram.py
Telegram.py
Telegram.py
Telegram.py
Telegram.py
Telegram.py

Šiame skyriuje yra Seromos telegramos roboto kodas. Jis naudoja telepoto biblioteką, kad bakstelėtų „Telegram“„Bot“API. Jis veikia priimdamas gautas užklausas ir vartotojui rodydamas atitinkamą informaciją. Norėdami gauti visą komandų sąrašą, vartotojas gali įvesti „help“.

1, 2 pav. Norėdami nustatyti telegramos robotą, turite naudoti „BotFather“. Tiesiog vykdykite instrukcijas, kad gautumėte HTTP API, kurios mums reikia mūsų kode.

4 pav. Funkcijos pavyzdys, pagal vartotojo pageidavimą paimantis tam tikrą duomenų eilučių skaičių iš duomenų bazės

5 pav. Kaip mes imamės vartotojo indėlio ir atitinkamai nusprendžiame, ką paleisti.

20 veiksmas: tiesioginė transliacija (camera_pi.py)

Tiesioginė transliacija (camera_pi.py)
Tiesioginė transliacija (camera_pi.py)
Tiesioginė transliacija (camera_pi.py)
Tiesioginė transliacija (camera_pi.py)
Tiesioginė transliacija (camera_pi.py)
Tiesioginė transliacija (camera_pi.py)

Įdiegėme naują savo serverių kambario stebėjimo sistemos funkciją - tiesioginį srautą apie tai, kas vyksta serverių kambaryje, prie kurio galima prisijungti bet kuriuo metu ir bet kur. Kaip veikia šis tiesioginis srautas: tai funkcija, kuri atliekama naudojant kolbą kartu su „Pi“kamera. Vaizdo įrašų kadrai atsisiunčiami taip, kaip vyksta realiame gyvenime, todėl iš tikrųjų galite pastebėti, kad vaizdo įrašų kadrai atsisiunčiami ir sujungiami šiek tiek (1–2 sekundės). To nebūtų galima padaryti be siūlų, nes foninis siūlas skaito kadrus iš fotoaparato ir išsaugo esamą kadrą. Sujungus visus šiuos kadrus, būtų išvestas tiesioginis srautas.

2 nuotrauka: Tai yra atskiras failas, kuriame saugomi visi vaizdo įrašų kadrai, ir kaip matote, mes naudojame „picamera“modulį, kad pasiektume savo aviečių pi kamerą, nes tai yra labiausiai mums žinoma. Turime klasės fotoaparatą, kad galėtume importuoti funkciją taip, tarsi tai būtų tiesioginė transliacija, o ne keli vaizdai, susidedantys kartu, todėl pagrindiniame programos faile jis būtų priimamas kaip tiesioginis srautas, nesijaudinant dėl to, kas vyksta užkulisiuose.

3 pav. Tai yra mūsų server.py failo dalis, kurioje yra užkoduota tiesioginio srauto dalis. Pagrindinė klasė, kurią mes importavome, yra „Camera“iš failo „camera_pi.py“, esančio mūsų server.py failo viršuje. Funkciją apibrėžėme savo pagrindiniame kataloge, gen, tačiau ji naudojama tik tada, kai pereiname į /video_feed, kur yra mūsų tiesioginis srautas, kur ji pakartos šią funkciją ir grąžins tiesioginį srautą tinklalapyje.