introduzione
Invoice Ninja è un software applicativo gratuito e open source basato su Web che può essere utilizzato per fatturazione, pagamenti, monitoraggio del tempo e molti altri. È la migliore soluzione per i clienti di fatturazione e fatturazione. Puoi creare e inviare facilmente fatture online in pochi secondi. Invoice Ninja ti consente di creare la tua fattura personalizzata e mostrare la fattura in tempo reale come file PDF.
In questo tutorial, ti spiegherò come installare Invoice Ninja sul server CentOS 7.
Prerequisiti
- Un'istanza di CentOS 7 x64 con 2 GB di RAM installati.
- Un utente sudo .
Passaggio 1: aggiornare il sistema
Prima di installare eventuali pacchetti su un'istanza del server CentOS, si consiglia di aggiornare il sistema. Accedi al tuo server tramite SSH come utente sudo ed esegui il comando seguente:
sudo yum install epel-release -y
sudo yum update -y
sudo shutdown -r now
Passaggio 2: installare il server LEMP.
Prima di iniziare, dovrai installare LEMP (Nginx, MariaDB e PHP) sul tuo server.
Innanzitutto, installa Nginx e MariaDB con il seguente comando:
sudo yum install nginx mariadb-server -y
Una volta completata l'installazione, avviare il servizio Nginx e MariaDB e abilitarli all'avvio:
sudo systemctl start nginx
sudo systemctl enable nginx
sudo systemctl start mariadb
sudo systemctl enable mariadb
Successivamente, avrai bisogno di PHP7 e PHP7.0-FPM per l'installazione di Invoice Ninja.
Innanzitutto, aggiungi il repository PHP7.0 al sistema con il seguente comando:
sudo rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm
Quindi, installa PHP7.0-FPM e altre estensioni PHP richieste con il seguente comando:
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
Al termine dell'installazione, sarà necessario modificare il file di configurazione php.ini:
sudo nano /etc/php.ini
Cambia la seguente riga:
cgi.fix_pathinfo=0
Salva e chiudi il file.
Per impostazione predefinita, l'installazione di MariaDB non è protetta, quindi è necessario prima proteggerla. Puoi farlo eseguendo lo script di installazione sicura mysql :
sudo mysql_secure_installation
Rispondi a tutte le domande come mostrato di seguito:
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
Al termine, connettiti con la shell MySQL con il seguente comando:
mysql -u root -p
Inserisci la tua password di root e premi invio, vedrai la shell di MySQL:
Successivamente, crea un nuovo database e un nuovo utente per 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
Successivamente, dovrai configurare il pool PHP-FPM per l'utente Nginx:
sudo nano /etc/php-fpm.d/www.conf
Modifica le seguenti righe:
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 e chiudi il file al termine.
Successivamente, dovrai creare una nuova directory per la sessione PHP e il file 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/
Infine, avvia il servizio PHP7.0-FPM e aggiungilo per l'avvio all'avvio:
sudo systemctl start php-fpm
systemctl enable php-fpm
Puoi scaricare l'ultima versione stabile di Invoice Ninja dal repository GitHub con il seguente comando:
cd /var/www/html/
sudo git clone https://github.com/hillelcoren/invoice-ninja.git ninja
Dovrai anche installare Dependency Manager per PHP (compositore). Puoi installarlo con il seguente comando:
curl -sS https://getcomposer.org/installer | sudo php -- --install-dir=/usr/bin --filename=composer
Quindi, installa tutte le dipendenze di Fattura Ninja usando il comando compositore come mostrato di seguito:
cd /var/www/html/ninja
sudo composer install --no-dev -o
Al termine dell'installazione, rinomina il file .env e apporta alcune modifiche:
sudo mv .env.example .env
sudo nano .env
Cambia le linee come mostrato di seguito:
DB_DATABASE=ninja_db
DB_USERNAME=ninja
DB_PASSWORD=password
Salvare il file al termine, quindi eseguire il comando seguente per preparare il database:
sudo php artisan migrate
Ti verrà richiesto di eseguire il comando, digitare "Sì" e premere "Invio".
Successivamente, semina il database con i record come mostrato di seguito:
sudo php artisan db:seed
Digita "sì" e premi "invio".
Successivamente, modifica la proprietà della /var/www/html/ninjadirectory:
sudo chown -R nginx:nginx /var/www/html/ninja/
Successivamente, dovrai creare un certificato SSL e creare una nuova configurazione dell'host virtuale per Invoice Ninja.
Innanzitutto, crea una directory per SSL:
sudo mkdir -p /etc/nginx/cert/
Successivamente, genera un certificato SSL con il seguente comando:
sudo openssl req -new -x509 -days 365 -nodes -out /etc/nginx/cert/ninja.crt -keyout /etc/nginx/cert/ninja.key
Successivamente, autorizza correttamente il file del certificato:
sudo chmod 600 /etc/nginx/cert/*
Quindi, crea un nuovo file di configurazione dell'host virtuale all'interno della directory / etc / nginx /:
sudo nano /etc/nginx/conf.d/ninja.conf
Aggiungi le seguenti righe:
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;
}
}
Salvare e chiudere il file e riavviare il server Web Nginx:
sudo systemctl restart nginx
Passaggio 7: Accedi a Invoice Ninja
Prima di accedere all'interfaccia Web di Invoice Ninja, è necessario consentire il servizio http e https tramite firewalld. Esegui i comandi seguenti per aprire le porte:
sudo firewall-cmd --permanent --add-service=http
sudo firewall-cmd --permanent --add-service=https
sudo firewall-cmd --reload
Infine, apri il tuo browser web e digita l'URL https://192.168.15.23, quindi completa i passaggi necessari per completare l'installazione.
Congratulazioni! abbiamo installato correttamente Invoice Ninja con Nginx e MariaDB sul server CentOS 7.