Installer Plesk på CentOS 7
Bruger du et andet system? Plesk er et proprietært webhost kontrolpanel, der giver brugerne mulighed for at administrere deres personlige og/eller klienters websteder, databaser
Beanstalk er en hurtig og enkel arbejdskø. Det giver dig mulighed for at køre tidskrævende opgaver asynkront, såsom at sende e-mails, oprette forbindelse til eksterne API'er eller behandle billeder. Ved at gøre det reducerer du din webapp-forsinkelse. Laravel giver out-of-the-box support til beanstalkd
.
I denne vejledning vil vi installere beanstalkd
, opsætte en demo Laravel-applikation og administrere køarbejderne gennem Supervisor . Demoapplikationen vil få en liste over tilgængelige OS'er fra Vultr API og tilfældigt vælge en.
Det antages, at du allerede har Supervisor installeret på dit system. Hvis du ikke gør det, bør du læse følgende vejledning om, hvordan du opsætter Supervisor: Installation og konfiguration af Supervisor på Ubuntu 16.04
Det antages også, at du har SSH-adgang til din Vultr-instans.
Det første skridt at tage er at installere beanstalkd
.
sudo apt-get update
sudo apt-get install beanstalkd
Start tjenesten.
sudo systemctl start beanstalkd
Du kan også aktivere tjenesten til at starte ved systeminitialisering.
sudo systemctl enable beanstalkd
Tjek servicestatus ved at udstede følgende kommando.
sudo systemctl status beanstalkd
Lytter som standard beanstalkd
på porten 11300
. Beanstalk bruger en simpel tekstbaseret protokol beskrevet i dets github-lager . Du kan teste dens protokol ved at køre telnet
.
telnet localhost 11300
Skriv følgende og tryk på ENTER.
list-tubes
Du bør se en liste over tilgængelige rør på serveren:
OK 14
---
- default
For at lukke forbindelsen skal du blot skrive quit
og derefter trykke på ENTER.
Rør i Beanstalk repræsenterer arbejdskøer. Bønnestilk består grundlæggende af producenter , forbrugere , jobs og rør . Producenterne lægger job i et rør for at blive forbrugt (bearbejdet) af et vilkårligt antal forbrugere. Bemærk, at både producenter og forbrugere simpelthen er klienter af Beanstalk-serveren og er fuldstændig uafhængige af hinanden. Rent praktisk betyder det, at du ved at bruge Beanstalk kan producere dine jobs i din PHP-applikation og få dem behandlet i en NodeJS-app for eksempel. Heldigvis abstraherer Laravel alt dette og giver os en meget enkel API til at sende og håndtere job, som vi vil se næste gang.
For at bygge vores eksempelprojekt skal vi først installere dets afhængigheder. Vi skal installere PHP og Composer.
sudo apt-get install php php-mbstring php-xml php-common php-zip composer
Opret nu projektet baseret på Laravel 5.5.
composer create-project --prefer-dist laravel/laravel vultr "5.5.*"
Næste cd
i den nyligt oprettede mappe. Vi vil arbejde i denne mappe fra nu af. Denne mappe kan senere henvises til som PROJECT_ROOT
.
cd vultr/
For at bruge Beanstalk i Laravel skal vi installere endnu en afhængighed, PHP Beanstalk-klienten.
composer require pda/pheanstalk ~3.0
Vi skal også oprette en jobrepræsentation. I Laravel er dette en klasse inde i app/Jobs
mappen. Laravel har en konsolkommando til at hjælpe os med at oprette en jobklasse. Lad os skabe vores eksempeljob.
php artisan make:job FindFavoriteOS
Opdater app/Jobs/FindFavoriteOS.php
filen til følgende.
<?php
namespace App\Jobs;
use Illuminate\Bus\Queueable;
use Illuminate\Queue\SerializesModels;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Foundation\Bus\Dispatchable;
use Illuminate\Support\Facades\Log;
class FindFavoriteOS implements ShouldQueue
{
use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
/**
* Create a new job instance.
*
* @return void
*/
public function __construct()
{
//
}
/**
* Execute the job.
*
* @return void
*/
public function handle()
{
$rawData = file_get_contents('https://api.vultr.com/v1/os/list');
$list = json_decode($rawData, true);
shuffle($list);
$key = array_rand($list);
$favorite = $list[$key];
Log::info('My Favorite OS is: ' . $favorite['name']);
}
}
Håndteringsmetoden er det, der effektivt vil blive udført, når jobbet er opbrugt. Her henter vi data fra Vultr API, vælger tilfældigt et OS og skriver det valgte OS til logfilen. Logfilen er placeret på storage/logs/laravel.log
.
Vi har allerede installeret Beanstalk og defineret det job, der skal udføres af det. Nu er det tid til at fortælle Laravel at bruge Beanstalk som standard arbejdskø. Kopier standardfilen .env
fra Laravel-installationen.
cp .env.example .env
Åbn nu .env
filen og opdater linjen, hvor kødriveren er angivet.
QUEUE_DRIVER=beanstalkd
Til sidst skal du generere en applikationsnøgle.
php artisan key:generate
Vi er nu klar til at sende jobs til Beanstalk-arbejdskøen.
At sende et job i Laravel er ret simpelt. Opdater routes/web.php
filen.
<?php
Route::get('/', function () {
for ($i = 0; $i < 50; $i++) {
\App\Jobs\FindFavoriteOS::dispatch();
}
return '50 Jobs dispatched!';
});
Selvom det ikke anbefales at køre den indbyggede server i produktionen, vil vi bruge den her for korthedens skyld.
php artisan serve --host 0.0.0.0 --port 8000
Naviger nu til i en webbrowser http://[vultr-instance-ip]:8000
. Du vil se følgende besked.
50 Jobs dispatched!
Åbn en ny SSH-forbindelse til din server og inde i vores projektrod, udfør følgende.
php artisan queue:work --once
Dette er det forventede output:
[2018-02-14 00:03:52] Processing: App\Jobs\FindFavoriteOS
[2018-02-14 00:03:53] Processed: App\Jobs\FindFavoriteOS
Bekræft, at loggen blev genereret.
cat storage/logs/laravel.log
For at undgå behovet for manuelt at behandle køen, vil vi bruge supervisord
. Opret følgende programkonfiguration i /etc/supervisor/conf.d/vultr.conf
.
[program:vultr]
process_name=%(program_name)s_%(process_num)02d
command=php [PROJECT_ROOT]/artisan queue:work
autostart=true
autorestart=true
numprocs=8
redirect_stderr=true
stdout_logfile=/var/log/worker.log
Bemærk, at den rigtige vej til at placere Supervisor-konfigurationsfilen afhænger af din opsætning. Husk også at erstatte [PROJECT_ROOT]
med den fulde sti til PROJECT_ROOT
på dit system.
Her konfigurerer vi Supervisor til automatisk at begynde at behandle køen og, i tilfælde af at scriptet går i stykker, genstarte det. Bemærk også, at vi ikke instansierer en enkelt arbejder, men 8 processer. Du er fri til at instansiere, hvor mange processer du finder nødvendige afhængigt af din applikation.
For at tillade Supervisor at administrere vores medarbejder, tving den til at genlæse sin konfiguration.
sudo supervisorctl reread
sudo supervisorctl update
Hvis Supervisor-tjenesten ikke er startet, er I mange nødt til at starte den.
sudo systemctl start supervisord
Lad os nu se, om opgaverne bliver behandlet.
tail -f storage/logs/laravel.log
Naviger til i en webbrowser http://[vultr-instance-ip]:8000
. Du vil se logfilerne blive genereret på din konsol.
Vi har konfigureret en Laravel-applikation til at bruge Beanstalk som en arbejdskø. Vi demonstrerede også, hvordan man bruger Supervisor til at styre medarbejdere.
Bruger du et andet system? Plesk er et proprietært webhost kontrolpanel, der giver brugerne mulighed for at administrere deres personlige og/eller klienters websteder, databaser
Bruger du et andet system? Hvis du køber en Debian-server, bør du altid have de nyeste sikkerhedsrettelser og opdateringer, uanset om du sover eller ej
Squid er et populært, gratis Linux-program, der giver dig mulighed for at oprette en webproxy til videresendelse. I denne vejledning vil du se, hvordan du installerer Squid på CentOS for at gøre dig
Denne vejledning forklarer, hvordan man opsætter en DNS-server ved hjælp af Bind9 på Debian eller Ubuntu. Gennem hele artiklen skal du erstatte dit-domænenavn.com i overensstemmelse hermed. Ved th
Bruger du et andet system? Red5 er en open source medieserver implementeret i Java, der giver dig mulighed for at køre Flash multi-bruger applikationer såsom live streamin
Bruger du et andet system? Vanilla forum er en open source forumapplikation skrevet i PHP. Det er en fuldt tilpasselig, nem at bruge og understøtter ekstern
Introduktion Lynis er et gratis, open source-systemrevisionsværktøj, der bruges af mange systemadministratorer til at verificere integriteten og hærde deres systemer. jeg
Bruger du et andet system? Microweber er en open source træk og slip CMS og online shop. Microweber-kildekoden er hostet på GitHub. Denne guide vil vise dig
Bruger du et andet system? Microweber er en open source træk og slip CMS og online shop. Microweber-kildekoden er hostet på GitHub. Denne guide vil vise dig
Bruger du et andet system? Mattermost er et open source, selvhostet alternativ til Slack SAAS-meddelelsestjenesten. Med andre ord, med Mattermost er du ca
Bruger du et andet system? DotCMS er et open source, enterprise-grade content management system skrevet i Java. Den indeholder næsten alle nødvendige funktioner
Bruger du et andet system? BigTree CMS 4.2 er et hurtigt og let, gratis og open source, enterprise-grade content management system (CMS) med omfattende
Hvad skal du bruge En Vultr VPS med mindst 1 GB RAM. SSH-adgang (med root/administrative rettigheder). Trin 1: Installation af BungeeCord Første ting først
Bruger du et andet system? Docker er et program, der gør det muligt at implementere programmer, der køres som containere. Det blev skrevet i det populære Go-programmin
Golang er et programmeringssprog udviklet af Google. Takket være sin alsidighed, enkelhed og pålidelighed er Golang blevet en af de mest populære
Plesk-kontrolpanelet har en meget flot integration til Lets Encrypt. Lets Encrypt er en af de eneste SSL-udbydere, der udleverer certifikater komplet
Lets Encrypt er en certifikatmyndighed dedikeret til at levere SSL-certifikater gratis. cPanel har bygget en pæn integration, så du og din klient
Hvis du har glemt din MySQL root-adgangskode, kan du nulstille den ved at følge trinene i denne artikel. Processen er ret enkel og fungerer på disse
Bruger du et andet system? GoAccess er en open source weblog-analysator. Du kan bruge det til analyse af logs på realtidsbasis i enten terminalen eller
YOURLS (Your Own URL Shortener) er en open source URL-forkortelse og dataanalyseapplikation. I denne artikel vil vi dække installationsprocessen
Kunstig intelligens er ikke i fremtiden, det er her lige i nuet I denne blog Læs, hvordan kunstig intelligens-applikationer har påvirket forskellige sektorer.
Er du også et offer for DDOS-angreb og forvirret over forebyggelsesmetoderne? Læs denne artikel for at løse dine spørgsmål.
Du har måske hørt, at hackere tjener mange penge, men har du nogensinde spekuleret på, hvordan tjener de den slags penge? lad os diskutere.
Vil du se revolutionerende opfindelser fra Google, og hvordan disse opfindelser ændrede livet for ethvert menneske i dag? Læs derefter til bloggen for at se opfindelser fra Google.
Konceptet med selvkørende biler til at køre på vejene ved hjælp af kunstig intelligens er en drøm, vi har haft i et stykke tid nu. Men på trods af flere løfter er de ingen steder at se. Læs denne blog for at lære mere...
Efterhånden som videnskaben udvikler sig i et hurtigt tempo og overtager en stor del af vores indsats, stiger risikoen for at udsætte os selv for en uforklarlig Singularitet. Læs, hvad singularitet kunne betyde for os.
Opbevaringsmetoderne for dataene har været under udvikling, kan være siden fødslen af dataene. Denne blog dækker udviklingen af datalagring på basis af en infografik.
Læs bloggen for at kende forskellige lag i Big Data-arkitekturen og deres funktionaliteter på den enkleste måde.
I denne digitalt drevne verden er smarte hjemmeenheder blevet en afgørende del af livet. Her er et par fantastiske fordele ved smarte hjemmeenheder om, hvordan de gør vores liv værd at leve og enklere.
For nylig udgav Apple macOS Catalina 10.15.4 en supplerende opdatering for at løse problemer, men det ser ud til, at opdateringen forårsager flere problemer, hvilket fører til mursten af mac-maskiner. Læs denne artikel for at lære mere