Introducere
Invoice Ninja este un software de aplicații de baze web gratuit și open source, care poate fi utilizat pentru facturare, plăți, urmărire timp și multe altele. Este cea mai bună soluție pentru facturarea și facturarea clienților. Puteți crea și trimite facturi online în câteva secunde. Factura Ninja vă permite să creați propria factură personalizată și să afișați factura live ca fișier PDF.
În acest tutorial, vă voi explica cum să instalați Invoice Ninja pe serverul CentOS 7.
Cerințe preliminare
Pasul 1: Actualizați sistemul
Înainte de a instala pachetele pe o instanță a serverului CentOS, se recomandă actualizarea sistemului. Conectați-vă la serverul dvs. prin SSH ca utilizator sudo și executați următoarea comandă:
sudo yum install epel-release -y
sudo yum update -y
sudo shutdown -r now
Pasul 2: Instalați LEMP Server.
Înainte de a începe, va trebui să instalați LEMP (Nginx, MariaDB și PHP) pe serverul dvs.
Mai întâi, instalați Nginx și MariaDB cu următoarea comandă:
sudo yum install nginx mariadb-server -y
După finalizarea instalării, începeți serviciul Nginx și MariaDB și permiteți-le să pornească la pornire:
sudo systemctl start nginx
sudo systemctl enable nginx
sudo systemctl start mariadb
sudo systemctl enable mariadb
În continuare, veți avea nevoie de PHP7 și PHP7.0-FPM pentru instalarea Invoice Ninja.
Mai întâi, adăugați depozitul PHP7.0 la sistem cu următoarea comandă:
sudo rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm
Apoi, instalați PHP7.0-FPM și alte extensii PHP necesare cu următoarea comandă:
sudo yum install install php70w-fpm php70w-cli php70w-pear php70w-gd php70w-xml php70w-curl php70w-gmp php70w-pdo php70w-mysql php70w-zip php70w-mbstring php70w-mcrypt -y
După terminarea instalării, va trebui să modificați fișierul de configurare php.ini:
sudo nano /etc/php.ini
Modificați următoarea linie:
cgi.fix_pathinfo=0
Salvați și închideți fișierul.
În mod implicit, instalarea MariaDB nu este securizată, așa că va trebui să o asigurați mai întâi. Puteți face acest lucru rulând scriptul de instalare securizat mysql :
sudo mysql_secure_installation
Răspundeți la toate întrebările așa cum se arată mai jos:
Set root password? [Y/n] Y
New password:
Re-enter new 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
Când totul este terminat, conectează-te cu shell-ul MySQL cu următoarea comandă:
mysql -u root -p
Introduceți parola root și apăsați Enter, veți vedea shell-ul MySQL:
Apoi, creează o nouă bază de date și un nou utilizator pentru Invoice Ninja:
MariaDB [(none)]> CREATE DATABASE ninja_db;
MariaDB [(none)]> GRANT ALL PRIVILEGES ON ninja_db.* TO 'ninja'@'localhost' IDENTIFIED BY 'password';
MariaDB [(none)]> FLUSH PRIVILEGES;
MariaDB [(none)]> \q
În continuare, va trebui să configurați pool-ul PHP-FPM pentru utilizatorul Nginx:
sudo nano /etc/php-fpm.d/www.conf
Modificați următoarele linii:
user = nginx
group = nginx
listen = /var/run/php/php-fpm.sock
listen.owner = nginx
listen.group = nginx
listen.mode = 0660
env[HOSTNAME] = $HOSTNAME
env[PATH] = /usr/local/bin:/usr/bin:/bin
env[TMP] = /tmp
env[TMPDIR] = /tmp
env[TEMP] = /tmp
Salvați și închideți fișierul când ați terminat.
În continuare, va trebui să creați un nou director pentru sesiunea PHP și fișierul socket:
sudo mkdir -p /var/lib/php/session
sudo mkdir -p /var/run/php/
sudo chown -R nginx:nginx /var/lib/php/session/
sudo chown -R nginx:nginx /var/run/php/
În cele din urmă, porniți serviciul PHP7.0-FPM și adăugați-l pentru a începe la ora de pornire:
sudo systemctl start php-fpm
systemctl enable php-fpm
Puteți descărca cea mai recentă versiune stabilă a facturii Ninja din depozitul GitHub cu următoarea comandă:
cd /var/www/html/
sudo git clone https://github.com/hillelcoren/invoice-ninja.git ninja
Va trebui, de asemenea, să instalați Dependency Manager pentru PHP (compozitor). Puteți să-l instalați cu următoarea comandă:
curl -sS https://getcomposer.org/installer | sudo php -- --install-dir=/usr/bin --filename=composer
Apoi, instalați toate dependențele de factură Ninja folosind comanda compozitorului, așa cum se arată mai jos:
cd /var/www/html/ninja
sudo composer install --no-dev -o
După terminarea instalării, redenumiți fișierul .env și faceți câteva modificări:
sudo mv .env.example .env
sudo nano .env
Modificați liniile după cum se arată mai jos:
DB_DATABASE=ninja_db
DB_USERNAME=ninja
DB_PASSWORD=password
Salvați fișierul când ați terminat, apoi executați următoarea comandă pentru a pregăti baza de date:
sudo php artisan migrate
Vi se va solicita să rulați comanda, tastați „da” și apăsați „enter”.
Apoi, sămânțați baza de date cu înregistrări, după cum se arată mai jos:
sudo php artisan db:seed
Tastați „da” și apăsați „enter”.
Apoi, schimbați proprietatea /var/www/html/ninjadirectorului:
sudo chown -R nginx:nginx /var/www/html/ninja/
În continuare, va trebui să creați un certificat SSL și să creați o nouă configurație de gazdă virtuală pentru Invoice Ninja.
Mai întâi, creați un director pentru SSL:
sudo mkdir -p /etc/nginx/cert/
Apoi, generați un certificat SSL cu următoarea comandă:
sudo openssl req -new -x509 -days 365 -nodes -out /etc/nginx/cert/ninja.crt -keyout /etc/nginx/cert/ninja.key
În continuare, acordați permisiunea corespunzătoare fișierului de certificat:
sudo chmod 600 /etc/nginx/cert/*
Apoi, creați un nou fișier de configurare de gazdă virtuală în directorul / etc / nginx /:
sudo nano /etc/nginx/conf.d/ninja.conf
Adăugați următoarele linii:
server {
listen 80;
server_name 192.168.15.23;
add_header Strict-Transport-Security max-age=2592000;
rewrite ^ https://$server_name$request_uri? permanent;
}
server {
listen 443 default;
server_name 192.168.15.23;
ssl on;
ssl_certificate /etc/nginx/cert/ninja.crt;
ssl_certificate_key /etc/nginx/cert/ninja.key;
ssl_session_timeout 5m;
ssl_ciphers 'AES128+EECDH:AES128+EDH:!aNULL';
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_prefer_server_ciphers on;
root /var/www/html/ninja/public;
index index.html index.htm index.php;
charset utf-8;
location / {
try_files $uri $uri/ /index.php?$query_string;
}
location = /favicon.ico { access_log off; log_not_found off; }
location = /robots.txt { access_log off; log_not_found off; }
# Access and Error Log for Invoice Ninja
access_log /var/log/nginx/ininja.access.log;
error_log /var/log/nginx/ininja.error.log;
sendfile off;
# Handle PHP Applications
location ~ \.php$ {
fastcgi_split_path_info ^(.+\.php)(/.+)$;
fastcgi_pass unix:/var/run/php/php-fpm.sock;
fastcgi_index index.php;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_intercept_errors off;
fastcgi_buffer_size 16k;
fastcgi_buffers 4 16k;
}
location ~ /\.ht {
deny all;
}
}
Salvați și închideți fișierul și reporniți serverul web Nginx:
sudo systemctl restart nginx
Pasul 7: Accesul facturii Ninja
Înainte de a accesa interfața web a facturii Ninja, va trebui să permiteți serviciul http și https prin firewalld. Rulați comenzile de mai jos pentru a deschide porturile:
sudo firewall-cmd --permanent --add-service=http
sudo firewall-cmd --permanent --add-service=https
sudo firewall-cmd --reload
În cele din urmă, deschideți browserul web și tastați URL-ul https://192.168.15.23, apoi completați pașii necesari pentru a termina instalarea.
Felicitări! am instalat cu succes Invoice Ninja cu Nginx și MariaDB pe serverul CentOS 7.