Įdiekite „Plesk“ „CentOS 7“.
Naudojate kitą sistemą? Plesk yra patentuotas žiniatinklio prieglobos valdymo skydelis, leidžiantis vartotojams administruoti savo asmenines ir (arba) klientų svetaines, duomenų bazes
RabbitMQ yra atvirojo kodo pranešimų brokeris, palaikantis AMQP, STOMP ir kitas komunikacijos technologijas. Jis plačiai naudojamas įmonės programose ir šiuolaikinėse mikro paslaugų architektūrose, kur veikia kaip asinchroninis pranešimų kanalas tarp skirtingų mikro paslaugų. Šiame vadove aprašoma, kaip galite sugrupuoti RabbitMQ keliuose CentOS 7 serveriuose, kad sudarytumėte didelio pasiekiamumo pranešimų tarpininką. Šioje pamokoje vienas serveris veiks kaip pagrindinis serveris, o kiti serveriai veiks kaip veidrodiniai serveriai, jei pagrindinis serveris taptų nepasiekiamas.
„CentOS“ ugniasienė ( firewalld
) pagal numatytuosius nustatymus neleidžia jokio įeinančio srauto. Kad RabbitMQ būtų prieinama kitoms sistemoms tinkle ir už jo ribų, ir kad galėtume pasiekti valdymo konsolę, pirmiausia turime atidaryti kai kuriuos prievadus.
RabbitMQ žiniatinklio sąsajos valdymo konsolė pagal numatytuosius nustatymus klausosi prievado 15672
. Norėtume padaryti valdymo pultą viešai prieinamą, kad galėtume ją pasiekti iš savo kompiuterio. Todėl nurodysime firewalld
visam laikui atidaryti prievadą 15672
viešoje zonoje (kuri yra numatytoji ir aktyvi zona Vultr egzemplioriuje).
sudo firewall-cmd --zone=public --add-port=15672/tcp --permanent
RabbitMQ mazgai turi turėti galimybę bendrauti vienas su kitu. Norėtume atidaryti reikiamus prievadus, bet tik per vidinį tinklą. Nenorime, kad kas nors internete galėtų administruoti arba tiesiogiai susisiekti su mūsų serveriais. Šios komandos daro prielaidą, kad mūsų serveriai yra 192.168.0.100/24
potinklyje.
Pirmoji paslauga yra epmd
lygiavertės paieškos paslauga, kuri pagal numatytuosius nustatymus klausosi prievado 4369
.
sudo firewall-cmd --permanent --zone=public --add-rich-rule='
rule family="ipv4"
source address="192.168.0.100/24"
port protocol="tcp" port="4369" accept'
Norint palaikyti ryšį tarp mazgų ir CLI, RabbitMQ turi turėti galimybę bendrauti per prievadą 25672
.
sudo firewall-cmd --permanent --zone=public --add-rich-rule='
rule family="ipv4"
source address="192.168.0.100/24"
port protocol="tcp" port="25672" accept'
CLI įrankiai bendrauja per prievadų diapazoną 35672-35682
.
sudo firewall-cmd --permanent --zone=public --add-rich-rule='
rule family="ipv4"
source address="192.168.0.100/24"
port protocol="tcp" port="35672-35682" accept'
Jei jūsų programoms reikalingas AMQP protokolas, taip pat turėsite atidaryti prievadus 5671
ir 5672
. Jei jums reikia turėti galimybę bendrauti per kitą protokolą, reikiamos informacijos apie RabbitMQ tinklo reikalavimus galite rasti oficialioje RabbitMQ dokumentacijoje .
sudo firewall-cmd --permanent --zone=public --add-rich-rule='
rule family="ipv4"
source address="192.168.0.100/24"
port protocol="tcp" port="5672" accept'
sudo firewall-cmd --permanent --zone=public --add-rich-rule='
rule family="ipv4"
source address="192.168.0.100/24"
port protocol="tcp" port="5671" accept'
Dabar, kai firewalld
sukonfigūruota, turime nurodyti jai iš naujo įkelti konfigūraciją.
sudo firewall-cmd --reload
Pakartokite šio skyriaus veiksmus visuose serveriuose.
rabbitmqadmin
Valdymo papildinys pateikiamas su Python įrankiu, rabbitmqadmin
kurį galima lengvai įdiegti sistemoje, kai valdymo papildinys įjungtas.
sudo wget http://localhost:15672/cli/rabbitmqadmin
sudo mv rabbitmqadmin /usr/local/bin/
sudo chmod +x /usr/local/bin/rabbitmqadmin
Norėdami identifikuoti serverius klasterizuodami, turite naudoti serverio prieglobos pavadinimus. Pagal numatytuosius nustatymus serveriams nepriskirtas DNS įrašas ir nepavyks prisijungti. Norėdami greitai tai įveikti, pridėkite pagrindinį ir veidrodinį pagrindinio kompiuterio pavadinimą prie /etc/hosts
failo naudodami mėgstamą redaktorių.
Pavyzdžiui, jūsų pagrindinio kompiuterio failas gali atrodyti taip. Atkreipkite dėmesį į du paskutinius įrašus, kurie leidžia serveriams identifikuoti vienas kitą pagal pagrindinio kompiuterio pavadinimą. Būtinai pakeiskite IP adresus į savo.
127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
::1 localhost localhost.localdomain localhost6 localhost6.localdomain6
127.0.0.1 guest
::1 guest
127.0.0.1 YOUR_MASTER_SERVER_HOST_NAME
::1 YOUR_MASTER_SERVER_HOST_NAME
192.168.0.101 YOUR_MASTER_SERVER_HOST_NAME
192.168.0.102 YOUR_MIRROR_SERVER_HOST_NAME
Būtina importavimo sąlyga, kad mazgai galėtų prisijungti vienas prie kito, yra ta, kad visų mazgų Erlang slapukas yra identiškas. Pagal numatytuosius nustatymus kiekvienam mazgui bus priskirtas unikalus Erlang slapukas, todėl turite jį iš naujo sukonfigūruoti visuose mazguose.
Ši komanda nustatys „Erlang“ slapuką į „ WE<3COOKIES
“, tačiau galite tai pakeisti pagal savo skonį. Atlikite tai visuose serveriuose.
sudo sh -c "echo 'WE<3COOKIES' > /var/lib/rabbitmq/.erlang.cookie"
Iš naujo paleiskite RabbitMQ visuose serveriuose, kad įsitikintumėte, jog Erlang slapukas tinkamai įkeltas iš naujo.
sudo systemctl restart rabbitmq-server.service
Vykdykite šias komandas visuose serveriuose, išskyrus pagrindinį serverį. Tai leis mazgams prisijungti prie pagrindinio serverio ir sudaryti klasterį.
sudo rabbitmqctl stop_app
sudo rabbitmqctl join_cluster "rabbit@<YOUR_MASTER_SERVER_HOST_NAME>"
sudo rabbitmqctl start_app
Patikrinkite, ar mazgai prisijungė prie klasterio, vykdydami šią komandą.
sudo rabbitmqctl cluster_status
Visi jūsų mazgai bus rodomi išvesties nodes
ir running_nodes
skiltyje. Nuo šiol jums nebereikia kartoti veiksmų kiekviename serveryje, konfigūracija bus automatiškai atspindėta kituose mazguose.
Dabar, kai turime RabbitMQ mazgų grupę, galime ją naudoti kurdami didelio pasiekiamumo eiles ir mainus, nustatydami naują politiką. Šią politiką galima pridėti naudojant RabbitMQ valdymo pultą arba komandų eilutės sąsają.
sudo rabbitmqctl set_policy -p "/" --priority 1 --apply-to "all" ha ".*" '{ "ha-mode": "exactly", "ha-params": 2, "ha-sync-mode": "automatic"}'
Toliau pateiktame sąraše bus paaiškinta, ką reiškia kiekviena komandos dalis.
-p "/"
: naudokite šią strategiją "/"
vhost (numatytasis po įdiegimo)--priority 1
: Politikos taikymo tvarka --apply-to "all"
: Gali būti "queues"
, "exchanges"
arba"all"
ha
: pavadinimas, kurį suteikiame savo politikai ".*"
: reguliarioji išraiška, naudojama sprendžiant, kurioms eilėms ar mainams taikoma ši politika. ".*"
atitiks bet ką'{ "ha-mode": "exactly", "ha-params": 2, "ha-sync-mode": "automatic"}'
: politikos JSON atvaizdas. Šiame dokumente aprašoma, ko mes norime – tiksliai 2 mazgų, kuriuose duomenys automatiškai sinchronizuojamiTrumpai tariant, ši politika užtikrins, kad eilėje arba biržoje visada turėsime 2 duomenų kopijas tol, kol turėsime ir veiks bent 2 mazgai. Jei turite daugiau mazgų, galite padidinti reikšmę ha-params
. Rekomenduojamas N/2 + 1
mazgų kvorumas ( ). Turėdami daugiau duomenų kopijų, padidėtų disko, i/o ir tinklo naudojimas, todėl gali sumažėti našumas.
Jei norite atspindėti duomenis visuose klasterio mazguose, galite naudoti šį JSON dokumentą.
'{ "ha-mode": "all", "ha-sync-mode": "automatic"}'
Jei norite atspindėti duomenis tik konkrečiuose mazguose (pavyzdžiui: node-1
ir node-2
), galite naudoti šiuos veiksmus.
'{ "ha-mode": "nodes", "ha-params" :["rabbit@node-1", "rabbit@node-2"], "ha-sync-mode": "automatic"}'
Galite pakeisti reguliarųjį posakį, kad skirtingoms eilėms priskirtumėte skirtingas strategijas. Tarkime, kad turime šiuos tris mazgus:
Tada galime sukurti dvi strategijas, dėl kurių eilių pavadinimas prasideda „klientas“, kurios bus atspindimos rabbit@client-ha
mazge, o visos eilės, kurių pavadinimas prasideda „produktas“, bus atspindimos rabbit@product-ha
mazge.
sudo rabbitmqctl set_policy -p "/" --priority 1 --apply-to "queues" ha-client "client.*" '{ "ha-mode": "nodes", "ha-params": ["rabbit@master", "rabbit@client-ha"], "ha-sync-mode": "automatic"}
sudo rabbitmqctl set_policy -p "/" --priority 1 --apply-to "queues" ha-product "product.*" '{ "ha-mode": "nodes", "ha-params": ["rabbit@master", "rabbit@product-ha"], "ha-sync-mode": "automatic"}
Maža pastaba: išskirtinės eilės niekada nėra atspindimos arba ilgalaikės RabbitMQ, net jei ši politika atitiktų tokias eiles. Išskirtinės eilės automatiškai sunaikinamos klientui atsijungus, todėl nebūtų jokios naudos jas kopijuoti į kitą serverį. Jei serveris sugestų, klientas nuo jo atsijungtų ir eilė būtų sunaikinta automatiškai. Veidrodiniai egzemplioriai taip pat būtų sunaikinti.
Norėdami išbandyti sugrupuotą sąranką, galime sukurti naują eilę naudodami komandų eilutės sąsają per valdymo konsolę.
sudo rabbitmqadmin declare queue --vhost "/" name=my-ha-queue durable=true
Taip bus sukurta ilgalaikė eilė numatytame /
vhost pavadinimu my-ha-queue
.
Vykdykite šią komandą ir išvestyje patikrinkite, ar eilei priskirta mūsų „ha“ politika, o pagrindiniame ir veidrodiniame mazge yra pid.
sudo rabbitmqctl list_queues name policy state pid slave_pids
Dabar galime paskelbti pranešimą į eilę iš pagrindinio mazgo ir sustabdyti RabbitMQ pagrindiniame mazge.
sudo rabbitmqadmin -u user_name -p password publish routing_key=my-ha-queue payload="hello world"
sudo systemctl rabbitmqctl shutdown
Dabar susigrąžinkite jį prijungę prie veidrodinio mazgo.
sudo rabbitmqadmin -H MIRROR_NODE_IP_OR_DNS -u user_name -p password get queue=my-ha-queue
Galiausiai galime iš naujo paleisti pagrindinį mazgą.
sudo systemctl start rabbitmq-server.service
Kaip minėta anksčiau, RabbitMQ automatiškai sukuria svečio vartotoją su numatytuoju svečio slaptažodžiu. Būtų bloga praktika palikti šį numatytąjį vartotoją viešai atskleistoje sistemoje.
sudo rabbitmqctl delete_user guest
Naudojate kitą sistemą? Plesk yra patentuotas žiniatinklio prieglobos valdymo skydelis, leidžiantis vartotojams administruoti savo asmenines ir (arba) klientų svetaines, duomenų bazes
Squid yra populiari nemokama „Linux“ programa, leidžianti sukurti persiuntimo žiniatinklio tarpinį serverį. Šiame vadove pamatysite, kaip įdiegti „Squid“ „CentOS“, kad paverstumėte jus
Įvadas Lighttpd yra „Apache“ šakutė, skirta daug mažiau išteklių imti. Jis yra lengvas, todėl jo pavadinimas ir yra gana paprastas naudoti. Įdiegti
VULTR neseniai atliko pakeitimus, ir dabar viskas turėtų veikti gerai, kai įjungta „NetworkManager“. Jei norite išjungti
Icinga2 yra galinga stebėjimo sistema, o kai naudojama pagrindinio kliento modelyje, ji gali pakeisti NRPE pagrįstų stebėjimo patikrų poreikį. Meistras-klientas
Naudojate kitą sistemą? Apache Cassandra yra nemokama ir atviro kodo NoSQL duomenų bazių valdymo sistema, skirta užtikrinti mastelio keitimą, hig.
Naudojate kitą sistemą? Mattermost yra atvirojo kodo, savarankiškai priglobta alternatyva Slack SAAS pranešimų paslaugai. Kitaip tariant, naudodami Mattermost, jūs apytiksliai
„Plesk“ valdymo skydelyje yra labai graži „Lets Encrypt“ integracija. „Lets Encrypt“ yra vienas iš vienintelių SSL teikėjų, išduodančių visus sertifikatus
„Lets Encrypt“ yra sertifikatų institucija, skirta nemokamai teikti SSL sertifikatus. cPanel sukūrė tvarkingą integraciją, kad jūs ir jūsų klientas
Naudojate kitą sistemą? Concrete5 yra atvirojo kodo TVS, kuri siūlo daug išskirtinių ir naudingų funkcijų, padedančių redaktoriams lengvai sukurti turinį
Naudojate kitą sistemą? „Review Board“ yra nemokamas atvirojo kodo įrankis, skirtas šaltinio kodui, dokumentacijai, vaizdams ir daugeliui kitų peržiūrėti. Tai internetinė programinė įranga
Šiame vadove sužinosite, kaip nustatyti HTTP autentifikavimą Nginx žiniatinklio serveriui, kuriame veikia CentOS 7. Reikalavimai Norėdami pradėti, jums reikės
YOURLS (Your Own URL Shortener) yra atvirojo kodo URL sutrumpinimo ir duomenų analizės programa. Šiame straipsnyje apžvelgsime diegimo procesą
Naudojate kitą sistemą? Įvadas ArangoDB yra atvirojo kodo NoSQL duomenų bazė su lanksčiu duomenų modeliu dokumentams, grafikams ir raktų reikšmėms. tai yra
Įvadas Katalogas /etc/ vaidina lemiamą vaidmenį veikiant Linux sistemai. Taip yra todėl, kad beveik visos sistemos konfigūracijos
Daugelis sistemos administratorių valdo didelius serverių kiekius. Kai failus reikia pasiekti skirtinguose serveriuose, prisijungiant prie kiekvieno atskirai apytiksliai
Ši pamoka apims Half Life 2 žaidimų serverio diegimą CentOS 6 sistemoje. 1 veiksmas: būtinų sąlygų įdiegimas Norėdami nustatyti ou
Laravel GitScrum arba GitScrum yra atvirojo kodo produktyvumo įrankis, skirtas padėti kūrimo komandoms įgyvendinti Scrum metodiką panašiai
Įvadas Šiame „Vultr“ vadove sužinosite, kaip įdiegti „PowerDNS“. PowerDNS yra programa, skirta paleisti savo vardų serverius. Tai labai naudinga, kai
Galite nukopijuoti ir įklijuoti šį bash scenarijų į Vultr valdymo skydelio paleisties scenarijaus sritį. Jis įdiegs visus reikalingus paketus į ru
Dirbtinis intelektas nėra ateityje, jis čia, dabartyje Šiame tinklaraštyje Skaitykite, kaip dirbtinio intelekto programos paveikė įvairius sektorius.
Ar taip pat esate DDOS atakų auka ir esate sumišęs dėl prevencijos metodų? Perskaitykite šį straipsnį, kad išspręstumėte savo užklausas.
Galbūt girdėjote, kad įsilaužėliai uždirba daug pinigų, bet ar kada susimąstėte, kaip jie uždirba tokius pinigus? padiskutuokime.
Ar norite pamatyti revoliucinius „Google“ išradimus ir kaip šie išradimai pakeitė kiekvieno žmogaus gyvenimą šiandien? Tada skaitykite tinklaraštį, kad pamatytumėte „Google“ išradimus.
Savavaledžių automobilių koncepcija, kuri išvažiuotų į kelius su dirbtinio intelekto pagalba, yra svajonė, kurią jau kurį laiką svajojame. Tačiau nepaisant kelių pažadų, jų niekur nematyti. Skaitykite šį tinklaraštį, kad sužinotumėte daugiau…
Kadangi mokslas sparčiai vystosi, perimdamas daug mūsų pastangų, taip pat didėja rizika, kad pateksime į nepaaiškinamą singuliarumą. Skaitykite, ką mums gali reikšti išskirtinumas.
Duomenų saugojimo metodai gali būti tobulinami nuo pat Duomenų gimimo. Šiame tinklaraštyje, remiantis infografika, aprašoma duomenų saugojimo raida.
Skaitykite tinklaraštį, kad paprasčiausiai sužinotumėte apie skirtingus didžiųjų duomenų architektūros sluoksnius ir jų funkcijas.
Šiame skaitmeniniu būdu pagrįstame pasaulyje išmanieji namų įrenginiai tapo svarbia gyvenimo dalimi. Štai keletas nuostabių išmaniųjų namų įrenginių privalumų, kaip jie daro mūsų gyvenimą vertą gyventi ir paprastesnį.
Neseniai „Apple“ išleido „macOS Catalina 10.15.4“ priedą, skirtą problemoms išspręsti, tačiau atrodo, kad dėl atnaujinimo kyla daugiau problemų, dėl kurių „Mac“ įrenginiai blokuojami. Norėdami sužinoti daugiau, perskaitykite šį straipsnį