Forutsetninger
Trinn 1: Legg til en Sudo-bruker
Trinn 2: Oppdater CentOS 7 System
Trinn 3: Installer Apache Web Server
Trinn 4: Åpne nettbrannmurporter
Trinn 5: Deaktiver SELinux (hvis aktivert)
Trinn 6: Installer PHP 7.1
Trinn 7: Installer MariaDB (MySQL) Server
Trinn 8: Opprett database for ProcessWire CMS
Trinn 9: Installer ProcessWire CMS-filer
Trinn 10: Fullfør ProcessWire CMS-installasjonen
ProcessWire CMS 3.0 er et enkelt, fleksibelt og kraftig, gratis og åpen kildekode Content Management System (CMS). ProcessWire CMS 3.0 har en brukervennlig API-stil i jQuery-stil, fullt modulær plugin-arkitektur og et fleksibelt og kraftig malsystem som gir en like tilfredsstillende brukeropplevelse for designere, utviklere og sluttbrukere.
I denne opplæringen skal vi installere ProcessWire CMS 3.0 på en CentOS 7 LAMP VPS ved å bruke Apache-webserver, PHP 7.1 og en MariaDB-database.
Forutsetninger
- En ren Vultr CentOS 7-serverforekomst med SSH-tilgang
Trinn 1: 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 ditt foretrukne brukernavn):
useradd user1
Deretter setter du passordet for user1brukeren:
passwd user1
Når du blir bedt om det, skriv inn et sikkert og minneverdig passord.
Sjekk nå /etc/sudoersfilen for å forsikre deg om at sudoersgruppen er aktivert:
visudo
Se etter en del som dette:
%wheel ALL=(ALL) ALL
Denne linjen forteller oss at brukere som er medlemmer av wheelgruppen kan bruke sudokommandoen for å få rootprivilegier. Den skal være ukommentert som standard, slik at du ganske enkelt kan avslutte filen.
Deretter må vi legge user1til i wheelgruppen:
usermod -aG wheel user1
Vi kan bekrefte user1gruppemedlemskapet og kontrollere at usermodkommandoen fungerte med groupskommandoen:
groups user1
Bruk nå sukommandoen for å bytte til den nye sudo- user1brukerkontoen:
su - user1
Ledeteksten vil oppdateres for å indikere at du nå er logget på user1kontoen. 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 du nettopp har opprettet:
sudo systemctl restart sshd
Avslutt user1kontoen:
exit
Avslutt rootkontoen (som vil koble fra sshøkten):
exit
Du kan nå gå sshinn i serverforekomsten fra din lokale vert ved å bruke den nye ikke-root sudo- user1brukerkontoen:
ssh user1@YOUR_VULTR_IP_ADDRESS
Hvis du vil kjøre sudouten å måtte skrive inn et passord hver gang, åpner du /etc/sudoersfilen igjen ved å bruke visudo:
sudo visudo
Rediger seksjonen for wheelgruppen slik at den ser slik ut:
%wheel ALL=(ALL) NOPASSWD: ALL
Vennligst merk: Deaktivering av passordkravet for sudo-brukeren er ikke en anbefalt praksis, men det er inkludert her da det kan gjøre serverkonfigurasjonen mye mer praktisk og mindre frustrerende, spesielt under lengre systemadministrasjonsøkter. Hvis du er bekymret for sikkerhetsimplikasjonene, kan du alltid tilbakestille konfigurasjonsendringen til den opprinnelige etter at du er ferdig med administrasjonsoppgavene.
Når du vil logge på rootbrukerkontoen fra sudobrukerkontoen, kan du bruke en av følgende kommandoer:
sudo -i
sudo su -
Du kan avslutte rootkontoen og gå tilbake til sudobrukerkontoen din når som helst ved å skrive exit.
Trinn 2: Oppdater CentOS 7 System
Før vi installerer noen pakker på CentOS-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 yum -y update
Trinn 3: Installer Apache Web Server
Installer Apache-nettserveren:
sudo yum -y install httpd
Bruk systemctlkommandoen for å starte og aktivere Apache til å kjøre automatisk ved oppstart:
sudo systemctl enable httpd
sudo systemctl start httpd
Sjekk Apache-konfigurasjonsfilen din for å sikre at DocumentRootdirektivet peker til riktig katalog:
sudo vi /etc/httpd/conf/httpd.conf
Den DocumentRootkonfigurasjon alternativet vil se slik ut:
DocumentRoot "/var/www/html"
La oss nå sørge for at mod_rewriteApache-modulen er lastet. Vi kan gjøre dette ved å søke i konfigurasjonsfilen for Apache-basemodulene etter begrepet " mod_rewrite".
Åpne filen:
sudo vi /etc/httpd/conf.modules.d/00-base.conf
Søk etter begrepet mod_rewrite.
Hvis mod_rewriteApache-modulen er lastet inn, vil du finne en konfigurasjonslinje som ser 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.
Vi må nå redigere Apaches standard konfigurasjonsfil slik at den mod_rewritefungerer riktig med ProcessWire CMS.
Å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) vil se omtrent slik ut:
<Directory "/var/www/html">
Options Indexes FollowSymLinks
AllowOverride All
Require all granted
</Directory>
Lagre og lukk nå Apache-konfigurasjonsfilen.
Vi vil starte Apache på nytt på slutten av denne opplæringen, men å starte Apache på nytt regelmessig under installasjon og konfigurasjon er absolutt en god vane, så la oss gjøre det nå:
sudo systemctl restart httpd
Trinn 4: Åpne nettbrannmurporter
Vi må nå åpne standard HTTPog HTTPSporter, da de vil bli blokkert som firewalldstandard.
Åpne brannmurportene:
sudo firewall-cmd --permanent --add-port=80/tcp
sudo firewall-cmd --permanent --add-port=443/tcp
Last inn brannmuren på nytt for å bruke endringene:
sudo firewall-cmd --reload
Du vil se ordet successvises i terminalen din etter hver vellykket brannmurkonfigurasjonskommando.
Vi kan raskt bekrefte at Apache- HTTPporten er åpen ved å besøke IP-adressen eller domenet til serverforekomsten i en nettleser:
http://YOUR_VULTR_IP_ADDRESS/
Du vil se standard Apache-webside i nettleseren din.
Trinn 5: Deaktiver SELinux (hvis aktivert)
SELinux stands for "Security Enhanced Linux". It is a security enhancement to Linux which allows users and administrators more control over access control. It is disabled by default on Vultr CentOS 7 instances, but we will cover the steps to disable it, just in case you are not starting from a clean install and it was previously enabled.
To avoid file permission problems with ProcessWire CMS we need to ensure that SELinux is disabled.
First, let's check whether SELinux is enabled or disabled with the sestatus command:
sudo sestatus
If you see something like: SELinux status: disabled then it is definitely disabled and you can skip straight to the next step. If you see any other message, then you will need to complete this section.
Open the SELinux configuration file with your favourite terminal editor:
sudo vi /etc/selinux/config
Change SELINUX=enforcing to SELINUX=disabled and then save the file.
To apply the configuration change, SELinux requires a server reboot, so you can either restart the server using the Vultr control panel or you can simply use the shutdown command:
sudo shutdown -r now
When the server reboots, your SSH session will get disconnected and you may see a message informing you about a 'broken pipe' or 'Connection closed by remote host'. This is nothing to worry about, simply wait for 20 seconds or so and then SSH back in again (with your own username and domain):
ssh user1@YOUR_DOMAIN
Or (with your own username and IP address):
ssh user1@YOUR_VULTR_IP_ADDRESS
Once you have logged back in, you should check the status of SELinux again with the sestatus command to make sure it is properly disabled:
sudo sestatus
You will see a message saying SELinux status: disabled. If you see a message saying SELinux status: enabled (or something similar) you will need to repeat the above steps and ensure that you properly restart your server.
Step 6: Install PHP 7.1
CentOS 7 requires us to add an external repo in order to install PHP 7.1, so run the following command:
sudo rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm
We can now install PHP 7.1 along with all of the necessary PHP modules required by ProcessWire CMS:
sudo yum -y install php71w php71w-gd php71w-mbstring php71w-mysql php71w-xml php71w-common php71w-pdo
Step 7: Install MariaDB (MySQL) Server
CentOS 7 defaults to using MariaDB database server, which is an enhanced, fully open source, community developed, drop-in replacement for MySQL server.
Install MariaDB database server:
sudo yum -y install mariadb-server
Start and enable MariaDB server to execute automatically at boot time:
sudo systemctl enable mariadb
sudo systemctl start mariadb
Secure your MariaDB server installation:
sudo mysql_secure_installation
The root password will be blank, so simply hit enter when prompted for the root password.
When prompted to create a MariaDB/MySQL root user, select "Y" (for yes) and then enter a secure root password. Simply answer "Y" to all of the other yes/no questions as the default suggestions are the most secure options.
Step 8: Create Database for ProcessWire CMS
Log into the MariaDB shell as the MariaDB root user by running the following command:
sudo mysql -u root -p
To access the MariaDB command prompt, simply enter the MariaDB root password when prompted.
Run the following queries to create a MariaDB database and database user for ProcessWire CMS:
CREATE DATABASE pw_db CHARACTER SET utf8 COLLATE utf8_general_ci;
CREATE USER 'pw_user'@'localhost' IDENTIFIED BY 'UltraSecurePassword';
GRANT ALL PRIVILEGES ON pw_db.* TO 'pw_user'@'localhost';
FLUSH PRIVILEGES;
EXIT;
Du kan erstatte databasenavnet pw_dbog brukernavnet pw_usermed noe mer du liker, hvis du foretrekker det. (Vær oppmerksom på at standard maksimal lengde for brukernavn i MariaDB på CentOS 7 er 16 tegn). Pass også på at du erstatter "UltraSecurePassword" med et faktisk sikkert passord.
Trinn 9: Installer ProcessWire CMS-filer
Endre din nåværende arbeidskatalog til standard nettkatalog:
cd /var/www/html/
Hvis du får en feilmelding som sier noe sånt som 'No such file or directory', prøv følgende kommando:
cd /var/www/ ; sudo mkdir html ; cd html
Din nåværende arbeidskatalog vil nå være: /var/www/html/. Du kan sjekke dette med pwdkommandoen (skriv ut arbeidskatalog):
pwd
Bruk nå for wgetå laste ned ProcessWire CMS-installasjonspakken:
sudo wget https://github.com/processwire/processwire/archive/master.zip
Merk: Du bør definitivt se etter den nyeste versjonen ved å gå til ProcessWire CMS-nedlastingssiden .
List gjeldende katalog for å kontrollere at du har lastet ned filen:
ls -la
Fjern index.html:
sudo rm index.html
La oss raskt installere unzipslik at vi kan pakke ut filen:
sudo yum -y install unzip
Dekomprimer nå zip-arkivet:
sudo unzip master.zip
Flytt alle installasjonsfilene til webrotkatalogen:
sudo mv processwire-master/* /var/www/html
Endre eierskap til nettfilene for å unngå problemer med tillatelser:
sudo chown -R apache:apache * ./
Start Apache på nytt:
sudo systemctl restart httpd
Trinn 10: Fullfør ProcessWire CMS-installasjonen
Det er nå på tide å besøke IP-adressen til serverforekomsten din i nettleseren din, eller hvis du allerede har konfigurert Vultr DNS-innstillingene (og gitt den nok tid til å spre seg), kan du ganske enkelt besøke domenet ditt i stedet.
For å få tilgang til ProcessWire CMS-installasjonssiden, skriv inn Vultr-forekomstens IP-adresse i nettleserens adresselinje, etterfulgt av index.php:
http://YOUR_VULTR_IP_ADDRESS/install.php
ProcessWire CMS-installasjonsprogrammet inneholder mange alternativer, så her er noen tips for å hjelpe deg:
På velkomstsiden for ProcessWire CMS-installasjon klikker du på Get Startedknappen for å starte installasjonsprosessen.
Velg nå din foretrukne installasjonsprofil (eller demoside) og klikk Continue.
Du vil se en Compatibility Checkside. Hvis du ser noen feil, betyr det sannsynligvis at du mangler noen PHP-moduler eller har et tillatelsesproblem, ellers kan du ganske enkelt klikke Continue.
Skriv inn følgende verdier på MySQL Database Settingssiden:
DB Name: pw_db
DB User: pw_user
DB Pass: UltraSecurePassword
DB Host: localhost
DB Port: 3306
Du kan la File Permissioninnstillingene stå på standardverdiene, eller du kan justere dem hvis du forstår implikasjonene.
Du kan angi fremtidige vertsnavn for nettstedet ditt i den aktuelle delen, eller du kan redigere site/config.phpfilen senere hvis du foretrekker det.
Klikk på for Continueå konfigurere databasen og installere ProcessWire CMS-filene.
Velg deretter din foretrukne Admin Theme.
Du kan endre Admin URLhvis du foretrekker det, eller du kan bare la den stå på standardverdien.
Skriv inn Admin Login Detailssom vist nedenfor:
User (a-z 0-9): <admin username>
Password: <admin password>
Password (again): <same admin password>
Email Address: <admin email address>
Når alle de riktige detaljene er angitt, kan du klikke for Continueå fullføre ProcessWire-installasjonen.
Når installasjonen er fullført, klikker du bare på Login to Adminknappen for å logge på Admin-delen.
Du kan se en advarsel som sier noe sånt som:
Warning: your server locale is undefined and may cause issues. Please add this to /site/config.php file (adjust en_US.UTF-8â₠as needed): setlocale(LC_ALL,'en_US.UTF-8');
Du kan fikse denne feilen ved å redigere site/config.phpfilen:
sudo vi site/config.php
Legg til riktig verdi på slutten av filen:
setlocale(LC_ALL,'en_GB.utf8');
Hvis du ikke kan finne ut hvilken verdi du skal bruke, kan du finne en liste over passende verdier for din bestemte serverforekomst ved å kjøre localekommandoen:
locale -a
Ikke glem å lagre og avslutte site/config.phpfilen når du er ferdig med å redigere.
For sikkerhets skyld må du endre tillatelsene på site/config.phpfilen:
sudo chmod 400 site/config.php
Start Apache på nytt.
sudo systemctl restart httpd
Du er klar til å begynne å legge til innholdet ditt og konfigurere utseendet på nettstedet ditt. Sørg for å sjekke ut den utmerkede ProcessWire CMS-dokumentasjonen for mer informasjon om hvordan du bygger og konfigurerer nettstedet ditt.