Cum se instalează factura Ninja pe CentOS 7

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

  • A fost instalată o instanță CentOS 7 x64 cu 2 GB RAM.
  • Un utilizator sudo .

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.

Pasul 3: Configurarea bazei de date

Î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

Pasul 4: Configurați PHP-FPM

Î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

Pasul 5: Descărcați și configurați factura Ninja

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/

Pasul 6: Configurați Nginx pentru factura 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.

Lasă un comentariu

O perspectivă asupra a 26 de tehnici de analiză a datelor mari: partea 1

O perspectivă asupra a 26 de tehnici de analiză a datelor mari: partea 1

O perspectivă asupra a 26 de tehnici de analiză a datelor mari: partea 1

Funcționalitățile straturilor arhitecturii de referință pentru Big Data

Funcționalitățile straturilor arhitecturii de referință pentru Big Data

Citiți blogul pentru a cunoaște diferitele straturi din Arhitectura Big Data și funcționalitățile acestora în cel mai simplu mod.

6 lucruri extrem de nebunești despre Nintendo Switch

6 lucruri extrem de nebunești despre Nintendo Switch

Mulți dintre voi cunoașteți Switch care va fi lansat în martie 2017 și noile sale funcții. Pentru cei care nu știu, am pregătit o listă de funcții care fac din „Switch” un „gadget obligatoriu”.

Promisiuni tehnologice care sunt încă nelivrate

Promisiuni tehnologice care sunt încă nelivrate

Aștepți ca giganții tehnologiei să-și îndeplinească promisiunile? vezi ce a ramas nelivrat.

Cum poate AI să ducă automatizarea proceselor la următorul nivel?

Cum poate AI să ducă automatizarea proceselor la următorul nivel?

Citiți asta pentru a afla cum devine populară inteligența artificială în rândul companiilor la scară mică și cum crește probabilitățile de a le face să crească și de a le oferi concurenților avantaje.

Singularitatea tehnologică: un viitor îndepărtat al civilizației umane?

Singularitatea tehnologică: un viitor îndepărtat al civilizației umane?

Pe măsură ce Știința Evoluează într-un ritm rapid, preluând multe dintre eforturile noastre, crește și riscurile de a ne supune unei Singularități inexplicabile. Citiți, ce ar putea însemna singularitatea pentru noi.

CAPTCHA: Cât timp poate rămâne o tehnică viabilă pentru distincția uman-AI?

CAPTCHA: Cât timp poate rămâne o tehnică viabilă pentru distincția uman-AI?

CAPTCHA a devenit destul de dificil de rezolvat pentru utilizatori în ultimii ani. Va fi capabil să rămână eficient în detectarea spam-ului și a botului în viitor?

Telemedicină și îngrijire medicală la distanță: viitorul este aici

Telemedicină și îngrijire medicală la distanță: viitorul este aici

Ce este telemedicina, îngrijirea medicală la distanță și impactul acesteia asupra generației viitoare? Este un loc bun sau nu în situația de pandemie? Citiți blogul pentru a găsi o vedere!

Te-ai întrebat vreodată cum câștigă hackerii bani?

Te-ai întrebat vreodată cum câștigă hackerii bani?

Poate ați auzit că hackerii câștigă mulți bani, dar v-ați întrebat vreodată cum câștigă acești bani? sa discutam.

Actualizarea suplimentului macOS Catalina 10.15.4 cauzează mai multe probleme decât rezolvă

Actualizarea suplimentului macOS Catalina 10.15.4 cauzează mai multe probleme decât rezolvă

Recent, Apple a lansat macOS Catalina 10.15.4 o actualizare suplimentară pentru a remedia problemele, dar se pare că actualizarea provoacă mai multe probleme care duc la blocarea mașinilor Mac. Citiți acest articol pentru a afla mai multe