introduzione
Invoice Ninja è un'applicazione web gratuita e open source che può essere utilizzata per fatturazione, pagamenti, monitoraggio del tempo e molto altro. È la soluzione migliore per i clienti di fatturazione e fatturazione. Puoi creare e inviare facilmente fatture online in pochi secondi. Invoice Ninja ti consente di creare fatture personalizzate e mostrare fatture in tempo reale come file PDF.
In questo tutorial, spiegherò come installare Invoice Ninja sul server Ubuntu 16.04.
Prerequisiti
- Un'istanza del server Ubuntu 16.04 con 2 GB di RAM installati.
- Un utente sudo con privilegi di root.
- Dovrai conoscere l'IP principale dell'istanza del tuo server. In questo tutorial, userò
192.168.0.227
.
Passaggio 1: aggiornare il sistema
Prima di installare qualsiasi pacchetto sull'istanza del server Ubuntu, si consiglia di aggiornare il sistema. Accedi al tuo server tramite SSH come utente sudo ed esegui il comando seguente:
sudo apt-get update -y
sudo apt-get upgrade -y
sudo shutdown -r now
Passaggio 2: installare lo stack LEMP
Prima di iniziare, dovrai configurare uno stack LEMP (Nginx, MariaDB e PHP) sul tuo server.
Innanzitutto, installa Nginx e MariaDB con il seguente comando:
sudo apt-get install nginx mariadb-server -y
Una volta completata l'installazione, avviare i servizi Nginx e MariaDB e abilitarli all'avvio:
sudo systemctl start nginx
sudo systemctl enable nginx
sudo systemctl start mysql
sudo systemctl enable mysql
Successivamente, avrai bisogno di PHP 7 e PHP-FPM per l'installazione di Invoice Ninja.
Puoi installare PHP-FPM e le altre estensioni PHP richieste con il seguente comando:
sudo apt-get install php7.0-fpm php7.0-gd php7.0-xml php7.0-mysql php7.0-zip php7.0-curl php7.0-gmp php7.0-mbstring php7.0-mcrypt
Al termine dell'installazione, dovrai modificare il php.ini
file di configurazione:
sudo nano /etc/php/7.0/fpm/php.ini
Cambia la seguente riga:
cgi.fix_pathinfo=0
Salva e chiudi il file.
Per impostazione predefinita, l'installazione di MariaDB non è stata protetta. Dovrai assicurarlo. Puoi farlo eseguendo mysql_secure_installation script
.
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 utilizzando la shell MySQL con il seguente comando:
mysql -u root -p
Inserisci la tua password di root e premi "invio", vedrai la shell MySQL (MariaDB).
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
Configurare il pool PHP-FPM per l'utente Nginx:
sudo nano /etc/php/7.0/fpm/pool.d/www-data.conf
Aggiungi le seguenti righe:
[www-data]
user = www-data
group = www-data
listen = /var/run/php-fpm-www-data.sock
listen.owner = www-data
listen.group = www-data
listen.mode = 0666
pm = ondemand
pm.max_children = 5
pm.process_idle_timeout = 10s
pm.max_requests = 200
chdir = /
Salvare e chiudere il file al termine, quindi riavviare PHP-FPM per applicare queste modifiche.
systemctl restart php7.0-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 Composer, un gestore delle dipendenze per PHP. 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 Invoice Ninja usando il composer
comando come mostrato di seguito:
cd /var/www/html/ninja
sudo composer install --no-dev -o
Al termine dell'installazione, rinominare il .env
file e apportare 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/ninja
directory:
sudo chown -R www-data:www-data /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
Concedere le autorizzazioni appropriate al file del certificato.
sudo chmod 600 /etc/nginx/cert/*
Creare un nuovo file di configurazione dell'host virtuale all'interno della /etc/nginx/
directory.
sudo nano /etc/nginx/conf.d/ninja.conf
Aggiungi le seguenti righe:
server {
listen 80;
server_name 192.168.0.227;
add_header Strict-Transport-Security max-age=2592000;
rewrite ^ https://$server_name$request_uri? permanent;
}
server {
listen 443 default;
server_name 192.168.0.227;
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-fpm-www-data.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 e chiudi il file. Quindi abilitare l'host virtuale con il seguente comando.
sudo ln -s /etc/nginx/sites-available/ninja /etc/nginx/sites-enabled/
Infine, riavvia 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 i servizi HTTP e HTTPS tramite il firewall UFW. Esegui i seguenti comandi per aprire queste porte:
sudo ufw allow 80/tcp
sudo ufw allow 443/tcp
Infine, apri il tuo browser web e accedi all'URL https://192.168.0.227
. È quindi possibile completare i passaggi richiesti per completare l'installazione.
Congratulazioni! Abbiamo installato correttamente Invoice Ninja con Nginx e MariaDB sul server Ubuntu 16.04.