Hvordan sette opp en Tekkit Classic Server på Ubuntu 16.10
Bruker du et annet system? Hva er Tekkit Classic? Tekkit Classic er en modpack for spillet alle kjenner og elsker; Minecraft. Den inneholder noe av ver
Beanstalk er en rask og enkel arbeidskø. Den lar deg kjøre tidkrevende oppgaver asynkront, som å sende e-post, koble til eksterne APIer eller behandle bilder. Ved å gjøre det vil du redusere ventetiden for nettappen din. Laravel gir direkte støtte for beanstalkd
.
I denne opplæringen vil vi installere beanstalkd
, sette opp en demo Laravel-applikasjon og administrere køarbeiderne gjennom Supervisor . Demoapplikasjonen vil få en liste over tilgjengelige operativsystemer fra Vultr API og tilfeldig velge ett.
Det antas at du allerede har Supervisor installert på systemet ditt. Hvis du ikke gjør det, bør du lese følgende veiledning om hvordan du setter opp Supervisor: Installere og konfigurere Supervisor på Ubuntu 16.04
Det antas også at du har SSH-tilgang til din Vultr-instans.
Det første trinnet å ta er å installere beanstalkd
.
sudo apt-get update
sudo apt-get install beanstalkd
Start tjenesten.
sudo systemctl start beanstalkd
Du kan også aktivere tjenesten for å starte ved systeminitialisering.
sudo systemctl enable beanstalkd
Sjekk tjenestestatusen ved å gi følgende kommando.
sudo systemctl status beanstalkd
Som standard, beanstalkd
lytter på porten 11300
. Beanstalk bruker en enkel tekstbasert protokoll beskrevet i dets github-lager . Du kan teste protokollen ved å kjøre telnet
.
telnet localhost 11300
Skriv følgende og trykk ENTER.
list-tubes
Du bør se en liste over tilgjengelige rør på serveren:
OK 14
---
- default
For å lukke tilkoblingen, skriv ganske enkelt quit
og trykk deretter ENTER.
Rør i Beanstalk representerer arbeidskøer. Bønnestengel er hovedsakelig sammensatt av produsenter , forbrukere , jobber og rør . Produsenter legger jobber i et rør for å bli konsumert (bearbeidet) av et hvilket som helst antall forbrukere. Merk at både produsenter og forbrukere ganske enkelt er klienter av Beanstalk-serveren og er helt uavhengige av hverandre. Rent praktisk betyr dette at du ved å bruke Beanstalk kan produsere jobbene dine i PHP-applikasjonen din og få den behandlet i for eksempel en NodeJS-app. Heldigvis abstraherer Laravel alt dette og gir oss et veldig enkelt API for å sende og håndtere jobber, som vi vil se neste gang.
For å bygge vårt eksempelprosjekt, må vi først installere avhengighetene. Vi skal installere PHP og Composer.
sudo apt-get install php php-mbstring php-xml php-common php-zip composer
Lag nå prosjektet basert på Laravel 5.5.
composer create-project --prefer-dist laravel/laravel vultr "5.5.*"
Neste cd
inn i den nylig opprettede mappen. Vi vil jobbe i denne katalogen fra nå av. Denne mappen kan bli referert til senere som PROJECT_ROOT
.
cd vultr/
For å bruke Beanstalk i Laravel må vi installere en avhengighet til, PHP Beanstalk-klienten.
composer require pda/pheanstalk ~3.0
Vi må også opprette en jobbrepresentasjon. I Laravel er dette en klasse inne i app/Jobs
mappen. Laravel har en konsollkommando for å hjelpe oss med å lage en jobbklasse. La oss lage prøvejobben vår.
php artisan make:job FindFavoriteOS
Oppdater 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åndtaksmetoden er det som effektivt vil bli utført når jobben er oppbrukt. Her henter vi data fra Vultr API, velger tilfeldig et OS og skriver det valgte OS til loggfilen. Loggfilen ligger på storage/logs/laravel.log
.
Vi har allerede installert Beanstalk og definert jobben som skal utføres av den. Nå er det på tide å fortelle Laravel å bruke Beanstalk som standard arbeidskø. Kopier standardfilen .env
fra Laravel-installasjonen.
cp .env.example .env
Åpne nå .env
filen og oppdater linjen der kødriveren er spesifisert.
QUEUE_DRIVER=beanstalkd
Til slutt, generer en applikasjonsnøkkel.
php artisan key:generate
Vi er nå klare til å sende jobber til Beanstalk-arbeidskøen.
Å sende en jobb i Laravel er ganske enkelt. Oppdater routes/web.php
filen.
<?php
Route::get('/', function () {
for ($i = 0; $i < 50; $i++) {
\App\Jobs\FindFavoriteOS::dispatch();
}
return '50 Jobs dispatched!';
});
Til tross for at det ikke er anbefalt å kjøre den innebygde serveren i produksjon, vil vi bruke den her for korthets skyld.
php artisan serve --host 0.0.0.0 --port 8000
Nå i en nettleser, naviger til http://[vultr-instance-ip]:8000
. Du vil se følgende melding.
50 Jobs dispatched!
Åpne en ny SSH-tilkobling til serveren din og inn i prosjektroten vår, utfør følgende.
php artisan queue:work --once
Dette er forventet utgang:
[2018-02-14 00:03:52] Processing: App\Jobs\FindFavoriteOS
[2018-02-14 00:03:53] Processed: App\Jobs\FindFavoriteOS
Bekreft at loggen ble generert.
cat storage/logs/laravel.log
For å unngå behovet for å behandle køen manuelt, vil vi bruke supervisord
. Opprett følgende programkonfigurasjon 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
Legg merke til at den riktige banen for å sette Supervisor-konfigurasjonsfilen vil avhenge av oppsettet ditt. Husk også å erstatte [PROJECT_ROOT]
med hele banen til PROJECT_ROOT
på systemet ditt.
Her konfigurerer vi Supervisor til å automatisk begynne å behandle køen og, i tilfelle skriptet går i stykker, å starte det på nytt. Vær også oppmerksom på at vi ikke instansierer en enkelt arbeider, men 8 prosesser. Du står fritt til å instansiere hvor mange prosesser du finner nødvendige avhengig av søknaden din.
For å la Supervisor administrere arbeideren vår, tving den til å lese konfigurasjonen på nytt.
sudo supervisorctl reread
sudo supervisorctl update
Hvis Veiledertjenesten ikke er startet, må dere mange starte den.
sudo systemctl start supervisord
La oss nå se om jobbene blir behandlet.
tail -f storage/logs/laravel.log
Naviger til i en nettleser http://[vultr-instance-ip]:8000
. Du vil se loggene som genereres på konsollen din.
Vi har konfigurert en Laravel-applikasjon til å bruke Beanstalk som en arbeidskø. Vi demonstrerte også hvordan man bruker Supervisor til å administrere arbeidere.
Bruker du et annet system? Hva er Tekkit Classic? Tekkit Classic er en modpack for spillet alle kjenner og elsker; Minecraft. Den inneholder noe av ver
Bruker du et annet system? Jekyll er et flott alternativ til WordPress for blogging eller deling av innhold. Det krever ingen databaser, og det er veldig enkelt, jeg
PHP og relaterte pakker er de mest brukte komponentene når du distribuerer en webserver. I denne artikkelen vil vi lære hvordan du setter opp PHP 7.0 eller PHP 7.1 o
Squid er et populært, gratis Linux-program som lar deg lage en webproxy for videresending. I denne veiledningen vil du se hvordan du installerer Squid på CentOS for å gjøre deg om
Introduksjon Lighttpd er en apachegaffel som har som mål å være mye mindre ressurskrevende. Den er lett, derav navnet, og er ganske enkel å bruke. Installer
Yii er et PHP-rammeverk som lar deg utvikle applikasjoner raskere og enklere. Det er enkelt å installere Yii på Ubuntu, som du vil lære nøyaktig
Denne opplæringen forklarer hvordan du setter opp en DNS-server ved å bruke Bind9 på Debian eller Ubuntu. Bytt ut ditt-domenenavn.com gjennom hele artikkelen. På th
VULTR har nylig gjort endringer på sin side, og alt skal nå fungere bra ut av boksen med NetworkManager aktivert. Skulle du ønske å deaktivere
Icinga2 er et kraftig overvåkingssystem, og når det brukes i en master-klient-modell, kan det erstatte behovet for NRPE-baserte overvåkingskontroller. Mester-klienten
Bruker du et annet system? Red5 er en åpen kildekode medieserver implementert i Java som lar deg kjøre Flash flerbrukerapplikasjoner som live streamin
I denne artikkelen vil vi se hvordan du kompilerer og installerer Nginx mainline fra de offisielle kildene til Nginx med PageSpeed-modulen, som lar deg t
Bruker du et annet system? Apache Cassandra er et gratis og åpen kildekode NoSQL-databasebehandlingssystem som er designet for å gi skalerbarhet, høy
Bruker du et annet system? Apache Cassandra er et gratis og åpen kildekode NoSQL-databasebehandlingssystem som er designet for å gi skalerbarhet, høy
Bruker du et annet system? Vanilla forum er en åpen kildekode-forumapplikasjon skrevet i PHP. Det er en fullt tilpassbar, enkel å bruke og støtter ekstern
Bruker du et annet system? Introduksjon Kanboard er et gratis og åpen kildekodeprogram for prosjektledelse som er designet for å forenkle og visualisere
Bruker du et annet system? Introduksjon Kanboard er et gratis og åpen kildekodeprogram for prosjektledelse som er designet for å forenkle og visualisere
Bruker du et annet system? Gitea er et alternativt åpen kildekode, selvdrevet versjonskontrollsystem drevet av Git. Gitea er skrevet på Golang og er
Bruker du et annet system? Gitea er et alternativt, selvdrevet versjonskontrollsystem med åpen kildekode drevet av git. Gitea er skrevet på Golang og er
Bruker du et annet system? Thelia er et åpen kildekodeverktøy for å lage e-business-nettsteder og administrere nettinnhold skrevet i PHP. Thelia kildekode i
Bruker du et annet system? MODX Revolution er et raskt, fleksibelt, skalerbart, gratis og åpen kildekode, enterprise-grade Content Management System (CMS) skrevet i
Kunstig intelligens er ikke i fremtiden, det er her akkurat i nåtiden I denne bloggen Les hvordan kunstig intelligens-applikasjoner har påvirket ulike sektorer.
Er du også et offer for DDOS-angrep og forvirret over forebyggingsmetodene? Les denne artikkelen for å løse spørsmålene dine.
Du har kanskje hørt at hackere tjener mye penger, men har du noen gang lurt på hvordan tjener de den slags penger? la oss diskutere.
Vil du se revolusjonerende oppfinnelser fra Google og hvordan disse oppfinnelsene forandret livet til alle mennesker i dag? Les deretter til bloggen for å se oppfinnelser fra Google.
Konseptet med selvkjørende biler som skal ut på veiene ved hjelp av kunstig intelligens er en drøm vi har hatt en stund nå. Men til tross for flere løfter, er de ingen steder å se. Les denne bloggen for å lære mer...
Ettersom vitenskapen utvikler seg raskt og tar over mye av innsatsen vår, øker også risikoen for å utsette oss for en uforklarlig singularitet. Les hva singularitet kan bety for oss.
Lagringsmetodene for dataene har vært i utvikling kan være siden fødselen av dataene. Denne bloggen dekker utviklingen av datalagring på grunnlag av en infografikk.
Les bloggen for å kjenne ulike lag i Big Data Architecture og deres funksjoner på den enkleste måten.
I denne digitaldrevne verden har smarthusenheter blitt en avgjørende del av livet. Her er noen fantastiske fordeler med smarthusenheter om hvordan de gjør livet vårt verdt å leve og enklere.
Nylig lanserte Apple macOS Catalina 10.15.4 en tilleggsoppdatering for å fikse problemer, men det ser ut til at oppdateringen forårsaker flere problemer som fører til muring av mac-maskiner. Les denne artikkelen for å lære mer