Forutsetninger
Legg til en Sudo-bruker
Trinn 1: Oppdater Fedora-systemet
Trinn 2: Installer Apache Web Server
Trinn 3: Deaktiver SELinux
Trinn 4: Installer PHP 7.1
Trinn 5: Installer MariaDB (MySQL) Server
Trinn 6: Opprett en database for SilverStripe
Trinn 7: Installer Silverstripe CMS-filer
Trinn 8: Fullfør SilverStripe CMS-installasjonen
SilverStripe er et fleksibelt og utvidbart gratis og åpen kildekode for enterprise-grade Content Management System (CMS) skrevet i PHP. Den er enkel å bruke og lære, veldig robust og sikker, har utmerket gjenbrukbar, godt optimert og lesbar kode, og inkluderer en kraftig malmotor som gjør det enkelt og raskt å lage nettsider.
Forutsetninger
- En ren Vultr Fedora 26-serverforekomst med SSH-tilgang
Legg til en Sudo-bruker
Vi starter med å legge til en ny sudobruker.
Først logger du på serveren din som root.
ssh root@YOUR_VULTR_IP_ADDRESS
Legg til en ny bruker kalt user1(eller hvilket navn du foretrekker).
useradd user1
Deretter setter du passordet for user1brukeren.
passwd user1
Du vil bli bedt om et passord, så skriv inn et sikkert passord og sørg for at du husker det.
Sjekk nå sudoersfilen for å forsikre deg om at sudoers-gruppen er aktivert.
vi sudo
Se etter et avsnitt som dette.
%wheel ALL=(ALL) ALL
Så lenge den er ukommentert, forteller dette oss at brukere som er medlemmer av wheelgruppen kan bruke sudokommandoen for å få rootprivilegier. Hvis den er kommentert ut, må du fjerne kommentaren og lagre filen ved å trykke " Escape"-tasten (for å gå inn i kommandomodus) og deretter skrive :wq(etterfulgt av " Enter") for å skrive endringer i filen og avslutte redigeringsprogrammet.
Merk: Hvis standard terminalredigeringsprogrammet ikke er satt til vieller vim, må du bruke noen alternative kommandoer for å lagre og avslutte filen.
Deretter må vi legge user1til i wheelgruppen.
usermod -aG wheel user1
Vi kan nå bruke sukommandoen til å bytte til den nye sudo- user1brukerkontoen.
su - user1
Ledeteksten vil oppdateres for å vise at du er logget på user1kontoen, og du kan bekrefte dette med whoamikommandoen.
whoami
Start nå sshdtjenesten på nytt slik at du kan logge på sshmed den nye ikke-root sudo-brukerkontoen.
sudo systemctl restart sshd
Avslutt user1kontoen.
exit
Avslutt rootkontoen (som vil koble fra sshøkten din ).
exit
Du kan nå gå sshinn på serveren fra din lokale vert ved å bruke den nye ikke-root sudo- user1brukerkontoen.
ssh user1@YOUR_VULTR_IP_ADDRESS
Trinn 1: Oppdater Fedora-systemet
Før vi installerer noen pakker på Fedora-serverforekomsten, vil vi først oppdatere systemet.
Pass på at du er logget på serveren med en ikke-root sudo-bruker og kjør følgende kommando.
sudo dnf -y update
Trinn 2: Installer Apache Web Server
Installer Apache-nettserveren.
sudo dnf -y install httpd
Bruk deretter systemctlkommandoen til å starte og aktivere Apache til å kjøre automatisk ved oppstart.
sudo systemctl enable httpd
sudo systemctl start httpd
Vi må nå sørge for at mod_rewriteApache-modulen er lastet. Vi kan gjøre dette ved å søke i konfigurasjonsfilen for Fedora Apache-basemoduler for begrepet mod_rewrite.
sudo vi /etc/httpd/conf.modules.d/00-base.conf
Søk på ordet mod_rewritei vived å skrive /mod_rewritei kommando-modus (etter å ha trykket på " escape" -tasten).
Hvis mod_rewriteApache-modulen er lastet, skal konfigurasjonslinjen se slik ut.
LoadModule rewrite_module modules/mod_rewrite.so
Hvis linjen ovenfor starter med et semikolon, må du fjerne semikolonet for å fjerne kommentaren til linjen og laste inn modulen. Dette gjelder selvfølgelig også for alle andre nødvendige Apache-moduler.
Hvis du bruker viredigeringsprogrammet, kan du lagre filen ved å trykke " Escape"-tasten (for å gå inn i kommandomodus) og deretter skrive for :wqå skrive eventuelle endringer i filen og avslutte redigeringsprogrammet.
Vi må nå redigere Apaches standard konfigurasjonsfil slik at den mod_rewritevil fungere riktig med SilverStripe. Så åpne filen.
sudo vi /etc/httpd/conf/httpd.conf
Finn deretter delen som begynner med <Directory "/var/www/html">og endre AllowOverride nonetil AllowOverride All. Sluttresultatet (med alle kommentarer fjernet) skal se omtrent slik ut.
<Directory "/var/www/html">
Options Indexes FollowSymLinks
AllowOverride All
Require all granted
</Directory>
Sørg også for at DocumentRootdirektivet peker til riktig katalog. Det skal se slik ut.
DocumentRoot "/var/www/html"
Du kan nå lagre og lukke Apache-konfigurasjonsfilen.
Vi må nå åpne standard HTTPog HTTPSporter, da de vil bli blokkert som firewalldstandard.
sudo firewall-cmd --permanent --add-port=80/tcp
sudo firewall-cmd --permanent --add-port=443/tcp
Last inn på nytt for firewalldå bruke endringene.
sudo firewall-cmd --reload
Vi vil starte Apache på nytt på slutten av denne opplæringen, men å starte Apache på nytt etter enhver konfigurasjonsendring er absolutt en god vane, så la oss gjøre det nå.
sudo systemctl restart httpd
Trinn 3: Deaktiver SELinux
SELinux står for "Security Enhanced Linux". Det er en sikkerhetsforbedring til Linux som gir brukere og administratorer mer kontroll over tilgangskontroll. Det er aktivert som standard i Fedora 26, men det er definitivt ikke avgjørende for serversikkerhet siden mange Linux-serverdistribusjoner ikke leveres med den installert eller aktivert som standard.
For å unngå filtillatelsesproblemer med SilverStripe CMS senere, skal vi deaktivere SELinux foreløpig. Åpne SELinux-konfigurasjonsfilen med din favorittterminalredigerer.
sudo vi /etc/selinux/config
Og endre SELINUX=enforcingtil SELINUX=disabled, og lagre deretter filen.
For å bruke konfigurasjonsendringen, krever SELinux en omstart av serveren, slik at du enten kan starte serveren på nytt ved å bruke Vultr-kontrollpanelet, eller du kan ganske enkelt bruke shutdownkommandoen.
sudo shutdown -r now
Når serveren starter på nytt, vil SSH-økten din bli frakoblet, og du kan se en melding som klager på en 'broken pipe'eller informerer deg 'Connection closed by remote host'. Dette er ingenting å bekymre seg for, bare vent i 20 sekunder eller så og deretter SSH inn igjen (med ditt eget brukernavn og domene).
ssh user1@example.net
Eller (med ditt eget brukernavn og IP-adresse).
ssh user1@YOUR_VULTR_IP_ADDRESS
Når du har logget på igjen, bør du sjekke statusen til SELinux med sestatuskommandoen for å sikre at den er riktig deaktivert.
sudo sestatus
Du bør se en melding som sier SELinux status: disabled. Hvis du ser en melding som sier SELinux status: enabled(eller noe lignende), må du gjenta trinnene ovenfor og sørge for at du starter serveren på nytt.
Trinn 4: Installer PHP 7.1
Vi kan nå installere PHP 7.1 sammen med de nødvendige PHP-modulene som kreves av SilverStripe.
sudo dnf -y install php php-gd php-mbstring php-xml php-tidy php-mysqlnd
Den date.timezoneinnstilling i php.inimå være riktig innstilt. Så åpne php.inifilen med din favorittterminalredigerer.
sudo vi /etc/php.ini
Sett date.timezonealternativet til din foretrukne tidssone. Den riktige innstillingen for en London-forekomst vil for eksempel se slik ut.
date.timezone = Europe/London
Trinn 5: Installer MariaDB (MySQL) Server
Fedora 26 bruker som standard MariaDB, som er en forbedret, fullstendig åpen kildekode, fellesskapsutviklet drop-in-erstatning for MySQL-server.
Installer MariaDB.
sudo dnf -y install mariadb-server
Start og aktiver MariaDB til å kjøre automatisk ved oppstart.
sudo systemctl enable mariadb
sudo systemctl start mariadb
Og sikre MariaDB-serverinstallasjonen.
sudo mysql_secure_installation
Den rootpassord vil bli tomt, så bare trykke " enter" når du blir bedt om rootpassord.
Når du blir bedt om å opprette en MariaDB/MySQL- rootbruker, velg " Y" (for ja) og skriv deretter inn et sikkert rootpassord. Bare svar " Y" på alle de andre ja/nei-spørsmålene, da standardforslagene er de sikreste alternativene.
Trinn 6: Opprett en database for SilverStripe
Logg inn på MariaDB-skallet som MariaDB- rootbrukeren ved å kjøre følgende kommando.
sudo mysql -u root -p
For å få tilgang til MariaDB-ledeteksten, skriv ganske enkelt inn MariaDB- rootpassordet når du blir bedt om det.
Kjør følgende spørringer for å opprette en MariaDB-database og databasebruker for SilverStripe.
CREATE DATABASE ss_data CHARACTER SET utf8 COLLATE utf8_general_ci;
CREATE USER 'ss_user'@'localhost' IDENTIFIED BY 'UltraSecurePassword';
GRANT ALL PRIVILEGES ON ss_data.* TO 'ss_user'@'localhost';
FLUSH PRIVILEGES;
EXIT;
Du kan erstatte databasenavnet ss_dataog brukernavnet ss_usermed noe mer du liker, hvis du foretrekker det. Pass også på at du endrer "UltraSecurePassword" til et faktisk sikkert passord.
Trinn 7: Installer Silverstripe CMS-filer
Endre gjeldende arbeidskatalog til standard nettkatalog.
cd /var/www/html/
Hvis du får en feilmelding som sier noe sånt, 'No such file or directory'kan du prøve følgende kommando.
cd /var/www/ ; sudo mkdir html ; cd html
Din nåværende arbeidskatalog skal nå være /var/www/html/. Du kan sjekke dette med pwdkommandoen (skriv ut arbeidskatalog).
pwd
Vi kan bruke wgettil å enkelt laste ned SilverStripe CMS tarball.
sudo wget https://silverstripe-ssorg-releases.s3.amazonaws.com/sssites-ssorg-prod/assets/releases/SilverStripe-cms-v3.6.2.tar.gz
Vennligst merk: Du bør definitivt se etter den nyeste versjonen ved å sjekke SilverStripe-nedlastingssiden . Bare høyreklikk på nedlastingsknappen på siden og kopier URL-en. Du kan deretter lime inn den mest oppdaterte tarball-URLen i wgetkommandoen vist ovenfor.
List opp gjeldende katalog for å sjekke at vi har lastet ned filen.
ls -la
Nå, komprimer tarballen.
sudo tar xvzf SilverStripe-cms-v3.6.2.tar.gz
Og endre eierskap til nettfilene for å unngå problemer med tillatelser.
sudo chown -R apache:apache * .htaccess
La oss starte Apache på nytt.
sudo systemctl restart httpd
Nå er vi klare til å gå videre til det siste trinnet.
Trinn 8: Fullfør SilverStripe CMS-installasjonen
Det er på tide å besøke IP-adressen til din Fedora-serverforekomst i nettleseren din. Eller, hvis du allerede har konfigurert Vultr DNS-innstillingene (og gitt det nok tid til å spre seg), kan du ganske enkelt besøke domenet ditt i stedet.
Bare skriv inn følgende databasedetaljer (eller tilsvarende valg) på SilverStripe-installasjonssiden.
Database server: localhost
Database username: ss_user
Database password: UltraSecurePassword
Database name: ss_data
Fyll nå inn e-post, passord (for å få tilgang til SilverStripe-admin-delen), og angi standardspråket ditt.
Email: my_email@example.net
Password: AnotherUltraSecurePassword
Default language: English UK
Når du har fylt ut alle nødvendige detaljer, kan du ganske enkelt klikke på Install SilverStripeknappen og ditt nye SilverStripe CMS vil bli installert.
Merk: Du kan få en advarsel om at installasjonsfiler ikke blir fjernet. Hvis det er tilfelle, går du bare tilbake til terminalen og løper.
sudo rm install.php
Og det burde gjøre susen. Etter den lille løsningen kan du ganske enkelt oppdatere advarselssiden i nettleseren din, og du skal være i gang.
Hvis du ikke allerede har satt opp Vultr DNS, bør det sannsynligvis være neste steg.
Nå kan du begynne å legge til innholdet ditt og begynne å konfigurere utseendet til nettstedet ditt. Sørg for å sjekke ut brukerhjelpeveiledningen for SilverStripe CMS for mer veiledning om hvordan du bygger og konfigurerer nettstedet ditt på riktig måte.