Bevezetés
Előfeltételek
1. lépés: Frissítse a rendszert
2. lépés: Telepítse a LEMP szervert.
3. lépés: Az adatbázis konfigurálása
4. lépés: A PHP-FPM konfigurálása
5. lépés: Töltse le és konfigurálja a Számla-nindzsát
6. lépés: Az Nginx konfigurálása a Invoice Ninja számára
7. lépés: Hozzáférés a számla nindzsához
Bevezetés
Az Invoice Ninja egy ingyenes és nyílt forráskódú webbázis-alkalmazás, amely számlázásra, fizetésre, időkövetésre és még sok másra használható. A legjobb megoldás az ügyfelek számlázására és számlázására. Könnyen, másodpercek alatt online hozhat létre és küldhet számlákat. Az Invoice Ninja lehetővé teszi, hogy saját egyéni számlát készítsen, és az élő számlát PDF-fájlként jelenítse meg.
Ebben az oktatóanyagban elmagyarázom, hogyan telepítheti az Invoice Ninja-t a CentOS 7 kiszolgálóra.
Előfeltételek
1. lépés: Frissítse a rendszert
Mielőtt bármilyen csomagot telepítene egy CentOS-kiszolgálópéldányra, javasoljuk a rendszer frissítését. Jelentkezzen be a szerverére SSH-n keresztül sudo felhasználóként, és futtassa a következő parancsot:
sudo yum install epel-release -y
sudo yum update -y
sudo shutdown -r now
2. lépés: Telepítse a LEMP szervert.
Mielőtt elkezdené, telepítenie kell a LEMP-t (Nginx, MariaDB és PHP) a szerverére.
Először telepítse az Nginxet és a MariaDB-t a következő paranccsal:
sudo yum install nginx mariadb-server -y
A telepítés befejezése után indítsa el az Nginx és a MariaDB szolgáltatást, és engedélyezze, hogy elinduljanak a rendszerindításkor:
sudo systemctl start nginx
sudo systemctl enable nginx
sudo systemctl start mariadb
sudo systemctl enable mariadb
Ezután PHP7-re és PHP7.0-FPM-re lesz szüksége a Invoice Ninja telepítéséhez.
Először adja hozzá a PHP7.0 tárolót a rendszerhez a következő paranccsal:
sudo rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm
Ezután telepítse a PHP7.0-FPM-et és a többi szükséges PHP-bővítményt a következő paranccsal:
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
A telepítés befejezése után módosítania kell a php.ini konfigurációs fájlt:
sudo nano /etc/php.ini
Módosítsa a következő sort:
cgi.fix_pathinfo=0
Mentse és zárja be a fájlt.
Alapértelmezés szerint a MariaDB telepítése nem védett, ezért először biztonságossá kell tennie. Ezt a mysql biztonságos telepítőszkriptjének futtatásával teheti meg :
sudo mysql_secure_installation
Válaszoljon az összes kérdésre az alábbiak szerint:
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
Ha minden kész, csatlakozzon a MySQL shellhez a következő paranccsal:
mysql -u root -p
Írja be a root jelszavát, és nyomja meg az Enter billentyűt, és megjelenik a MySQL shell:
Ezután hozzon létre egy új adatbázist és egy új felhasználót az Invoice Ninja számára:
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
Ezután be kell állítania a PHP-FPM készletet az Nginx felhasználó számára:
sudo nano /etc/php-fpm.d/www.conf
Módosítsa a következő sorokat:
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
Mentse el és zárja be a fájlt, ha végzett.
Ezután létre kell hoznia egy új könyvtárat a PHP munkamenethez és a socket fájlhoz:
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/
Végül indítsa el a PHP7.0-FPM szolgáltatást, és adja hozzá a rendszerindításkor:
sudo systemctl start php-fpm
systemctl enable php-fpm
Letöltheti az Invoice Ninja legújabb stabil verzióját a GitHub tárolóból a következő paranccsal:
cd /var/www/html/
sudo git clone https://github.com/hillelcoren/invoice-ninja.git ninja
Ezenkívül telepítenie kell a Dependency Manager for PHP-t (composer). A következő paranccsal telepítheti:
curl -sS https://getcomposer.org/installer | sudo php -- --install-dir=/usr/bin --filename=composer
Ezután telepítse az összes Számlaninja függőséget a composer paranccsal az alábbiak szerint:
cd /var/www/html/ninja
sudo composer install --no-dev -o
A telepítés után nevezze át az .env fájlt, és hajtson végre néhány módosítást:
sudo mv .env.example .env
sudo nano .env
Változtassa meg a sorokat az alábbiak szerint:
DB_DATABASE=ninja_db
DB_USERNAME=ninja
DB_PASSWORD=password
Ha végzett, mentse a fájlt, majd futtassa a következő parancsot az adatbázis előkészítéséhez:
sudo php artisan migrate
A rendszer kéri, hogy futtassa a parancsot, írja be a „yes”-t, és nyomja meg az „enter” billentyűt.
Ezután indítsa el az adatbázist rekordokkal az alábbiak szerint:
sudo php artisan db:seed
Írja be a „yes”-t, és nyomja meg az „enter” gombot.
Ezután módosítsa a /var/www/html/ninjacímtár tulajdonjogát :
sudo chown -R nginx:nginx /var/www/html/ninja/
Ezután létre kell hoznia egy SSL-tanúsítványt, és létre kell hoznia egy új virtuális gazdagép-konfigurációt az Invoice Ninja számára.
Először hozzon létre egy könyvtárat az SSL számára:
sudo mkdir -p /etc/nginx/cert/
Ezután hozzon létre egy SSL-tanúsítványt a következő paranccsal:
sudo openssl req -new -x509 -days 365 -nodes -out /etc/nginx/cert/ninja.crt -keyout /etc/nginx/cert/ninja.key
Ezután adjon megfelelő engedélyt a tanúsítványfájlhoz:
sudo chmod 600 /etc/nginx/cert/*
Ezután hozzon létre egy új virtuális gazdagép konfigurációs fájlt az /etc/nginx/ könyvtárban:
sudo nano /etc/nginx/conf.d/ninja.conf
Adja hozzá a következő sorokat:
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;
}
}
Mentse és zárja be a fájlt, és indítsa újra az Nginx webszervert:
sudo systemctl restart nginx
7. lépés: Hozzáférés a számla nindzsához
Mielőtt hozzáférne az Invoice Ninja webes felületéhez, engedélyeznie kell a http és https szolgáltatást a tűzfalon keresztül. Futtassa az alábbi parancsokat a portok megnyitásához:
sudo firewall-cmd --permanent --add-service=http
sudo firewall-cmd --permanent --add-service=https
sudo firewall-cmd --reload
Végül nyissa meg a webböngészőt, írja be az URL-t https://192.168.15.23, majd hajtsa végre a szükséges lépéseket a telepítés befejezéséhez.
Gratulálunk! Sikeresen telepítettük az Invoice Ninja-t az Nginx-szel és a MariaDB-vel a CentOS 7 szerveren.