Introducere
Polr este un scurtător de legături gratuit și open-source scris în PHP și Lumen. Vă permite să găzduiți rapid propriul dvs. scurtător URL. Caracteristicile sale semnificative includ un tablou de bord de gestiune, analize de link-uri detaliate și o API. Acest tutorial vă va ghida în procesul de instalare a Polr pe CentOS 8.
Cerințe preliminare
Acest tutorial necesită o instanță Vultr Cloud Compute cu CentOS 8 și acces rădăcină și un nume de domeniu valabil îndreptat către serverul dumneavoastră.
Instalați Apache
Polr necesită un server web, o bază de date MySQL și PHP. Pentru acest tutorial vom folosi serverul web Apache.
Instalați serverul web Apache.
dnf install httpd -y
systemctl enable httpd.service
Deschideți porturile 80 (HTTP) și 443 (HTTPS) prin firewall pentru a putea accesa serverul de pe internet.
sudo firewall-cmd --permanent --zone=public --add-service=http
sudo firewall-cmd --permanent --zone=public --add-service=https
sudo firewall-cmd --reload
Creați un nou fișier de configurare Apache pentru instalarea Polr.
nano /etc/httpd/conf.d/polr.conf
Inserați următorul fragment în fișierul nou creat, înlocuind example.comcu propriul nume de domeniu.
<VirtualHost *:80>
ServerName example.com
ServerAlias example.com
DocumentRoot "/var/www/html/public"
<Directory "/var/www/html/public">
Require all granted
Options Indexes FollowSymLinks
AllowOverride All
Order allow,deny
Allow from all
</Directory>
ErrorLog /var/log/httpd/error.log
CustomLog /var/log/httpd/access.log combined
</VirtualHost>
Instalați PHP
Polr necesită PHP și o serie de module PHP. Instalați modulele PHP și PHP necesare de Polr.
dnf install php php-xml php-pdo php-mysqlnd php-mbstring php-tokenizer php-json php-curl -y
Instalați MySQL și creați o bază de date
Polr stochează date într-o bază de date SQL. Instalați și activați serverul MySQL.
dnf install mysql-server -y
systemctl enable mysqld.service
systemctl start mysqld.service
Securizați instalarea de instalare MySQL rulând scriptul furnizat.
mysql_secure_installation
Când vi se solicită o parolă rădăcină, alegeți o parolă sigură și continuați prin instalare.
Would you like to setup VALIDATE PASSWORD plugin? [Y/N] N
New password: <Your Password>
Re-enter new password: <Your Password>
Remove anonymous users? [Y/N] Y
Disallow root login remotely? [Y/N] Y
Remove test database and access to it? [Y/N] Y
Reload privilege tables now? [Y/N] Y
Conectați-vă la consola MySQL.
mysql -u root -p
Când vi se cere o parolă, introduceți parola rădăcină creată anterior. După ce v-ați conectat la consolă, creați o nouă bază de date pentru Polr.
mysql>CREATE DATABASE polr;
Creați un utilizator nou de bază de date și acordați-i privilegii bazei de date create. Puteți înlocui usernameși passwordcu numele de utilizator și parola la alegere.
mysql>CREATE USER 'username'@'localhost' identified by 'password';
mysql>GRANT ALL PRIVILEGES on polr.* to 'username'@'localhost';
mysql>FLUSH PRIVILEGES;
Ieșiți de la consola MySQL.
mysql>exit
Instalați Polr
Instalați gitși clonați depozitul Polr din Github.
dnf install git -y
cd /var/www/html
git clone https://github.com/cydrobolt/polr.git --depth=1
Mutați fișierele descărcate la rădăcina webserver-ului.
mv ./polr/.[!.]* . && mv ./polr/* . && rm -rf polr
Descărcați pachetul Composr. Acest lucru este necesar pentru instalarea dependențelor.
curl -sS https://getcomposer.org/installer | php
Instalați dependențele cu Composr.
php composer.phar install --no-dev -o
Copiați fișierul de configurare furnizat pentru a activa instalatorul bazat pe web.
cp .env.setup .env
Setați permisiunile de fișiere corespunzătoare.
chown -R apache:apache /var/www/html/
chmod -R 755 /var/www/html/
chcon -R -t httpd_sys_rw_content_t storage .env
Porniți serverul web Apache.
systemctl start httpd.service
Finalizați instalarea
Navigați pentru example.com/setupa lansa instalatorul Polr bazat pe web și introduceți informațiile necesare. Utilizați datele de autentificare MySQL create anterior pentru configurarea bazei de date. După ce ați trimis formularul de instalare, instalarea Polr va fi finalizată.