Як встановити Invoice Ninja на CentOS 7

Вступ

Invoice Ninja — це безкоштовне програмне забезпечення для веб-баз з відкритим кодом, яке можна використовувати для виставлення рахунків, платежів, відстеження часу та багато іншого. Це найкраще рішення для виставлення рахунків і виставлення рахунків клієнтам. Ви можете легко створювати та надсилати рахунки-фактури онлайн за лічені секунди. Invoice Ninja дозволяє створювати власний рахунок-фактуру та показувати поточний рахунок-фактуру у форматі PDF-файлу.

У цьому підручнику я поясню вам, як встановити Invoice Ninja на сервері CentOS 7.

Передумови

  • Примірник CentOS 7 x64 з 2 Гб оперативної пам’яті.
  • Користувач sudo .

Крок 1: Оновіть систему

Перед встановленням будь-яких пакетів на екземпляр сервера CentOS рекомендується оновити систему. Увійдіть на свій сервер через SSH як ваш користувач sudo і виконайте таку команду:

sudo yum install epel-release -y
sudo yum update -y
sudo shutdown -r now

Крок 2: Встановіть сервер LEMP.

Перш ніж почати, вам потрібно буде встановити LEMP (Nginx, MariaDB і PHP) на вашому сервері.

Спочатку встановіть Nginx і MariaDB за допомогою такої команди:

sudo yum install nginx mariadb-server -y

Після завершення інсталяції запустіть службу Nginx і MariaDB і дозвольте їм запускатися під час завантаження:

sudo systemctl start nginx
sudo systemctl enable nginx
sudo systemctl start mariadb
sudo systemctl enable mariadb

Далі вам знадобляться PHP7 і PHP7.0-FPM для встановлення Invoice Ninja.

Спочатку додайте репозиторій PHP7.0 до системи за допомогою такої команди:

sudo rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm

Далі встановіть PHP7.0-FPM та інші необхідні розширення PHP за допомогою такої команди:

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

Після завершення інсталяції вам потрібно буде змінити файл конфігурації php.ini:

sudo nano /etc/php.ini

Змініть наступний рядок:

cgi.fix_pathinfo=0

Збережіть і закрийте файл.

Крок 3: Налаштуйте базу даних

За замовчуванням інсталяція MariaDB не захищена, тому спочатку її потрібно захистити. Ви можете зробити це, запустивши сценарій безпечної інсталяції mysql :

sudo mysql_secure_installation

Дайте відповіді на всі запитання, як показано нижче:

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

Коли все буде зроблено, підключіться до оболонки MySQL за допомогою такої команди:

mysql -u root -p

Введіть свій пароль root і натисніть Enter, ви побачите оболонку MySQL:

Далі створіть нову базу даних і нового користувача для 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

Крок 4: Налаштуйте PHP-FPM

Далі вам потрібно буде налаштувати пул PHP-FPM для користувача Nginx:

sudo nano /etc/php-fpm.d/www.conf

Змініть наступні рядки:

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

Збережіть і закрийте файл, коли закінчите.

Далі вам потрібно буде створити новий каталог для сесії PHP і файлу сокета:

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/

Нарешті, запустіть службу PHP7.0-FPM і додайте її для запуску під час завантаження:

sudo systemctl start php-fpm
systemctl enable php-fpm

Крок 5. Завантажте та налаштуйте Invoice Ninja

Ви можете завантажити останню стабільну версію Invoice Ninja зі сховища GitHub за допомогою такої команди:

cd /var/www/html/
sudo git clone https://github.com/hillelcoren/invoice-ninja.git ninja

Вам також потрібно буде встановити Dependency Manager для PHP (композитор). Ви можете встановити його за допомогою такої команди:

curl -sS https://getcomposer.org/installer | sudo php -- --install-dir=/usr/bin --filename=composer

Далі встановіть усі залежності Invoice Ninja за допомогою команди composer, як показано нижче:

cd /var/www/html/ninja
sudo composer install --no-dev -o

Після завершення інсталяції перейменуйте файл .env і внесіть деякі зміни:

sudo mv .env.example .env
sudo nano .env

Змініть рядки, як показано нижче:

DB_DATABASE=ninja_db
DB_USERNAME=ninja
DB_PASSWORD=password

Збережіть файл, коли ви закінчите, а потім виконайте таку команду, щоб підготувати базу даних:

sudo php artisan migrate

Вам буде запропоновано виконати команду, введіть «так» і натисніть «enter».

Далі заповніть базу даних записами, як показано нижче:

sudo php artisan db:seed

Введіть «так» і натисніть «enter».

Далі змініть власника /var/www/html/ninjaкаталогу:

sudo chown -R nginx:nginx /var/www/html/ninja/

Крок 6: Налаштуйте Nginx для Invoice Ninja

Далі вам потрібно буде створити сертифікат SSL і створити нову конфігурацію віртуального хоста для Invoice Ninja.

Спочатку створіть каталог для SSL:

sudo mkdir -p /etc/nginx/cert/

Далі згенеруйте сертифікат SSL за допомогою такої команди:

sudo openssl req -new -x509 -days 365 -nodes -out /etc/nginx/cert/ninja.crt -keyout /etc/nginx/cert/ninja.key

Далі надайте належний дозвіл файлу сертифіката:

sudo chmod 600 /etc/nginx/cert/*

Далі створіть новий файл конфігурації віртуального хоста в каталозі /etc/nginx/:

sudo nano /etc/nginx/conf.d/ninja.conf

Додайте такі рядки:

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;
       }
    }

Збережіть і закрийте файл і перезапустіть веб-сервер Nginx:

sudo systemctl restart nginx

Крок 7. Отримайте доступ до рахунка-фактури Ninja

Перш ніж отримати доступ до веб-інтерфейсу Invoice Ninja, вам потрібно буде дозволити службу http і https через firewalld. Виконайте наведені нижче команди, щоб відкрити порти:

sudo firewall-cmd --permanent --add-service=http
sudo firewall-cmd --permanent --add-service=https
sudo firewall-cmd --reload

Нарешті, відкрийте свій веб-браузер і введіть URL-адресу https://192.168.15.23, а потім виконайте необхідні кроки, щоб завершити встановлення.

Вітаю! ми успішно встановили Invoice Ninja з Nginx і MariaDB на сервері CentOS 7.

Залишити коментар

Повстання машин: застосування ШІ в реальному світі

Повстання машин: застосування ШІ в реальному світі

Штучний інтелект не в майбутньому, він тут прямо в сьогоденні У цьому блозі Прочитайте, як програми штучного інтелекту вплинули на різні сектори.

DDOS-атаки: короткий огляд

DDOS-атаки: короткий огляд

Ви також стали жертвою DDOS-атак і спантеличені методами запобігання? Прочитайте цю статтю, щоб вирішити свої запитання.

Ви коли-небудь замислювалися, як хакери заробляють гроші?

Ви коли-небудь замислювалися, як хакери заробляють гроші?

Можливо, ви чули, що хакери заробляють багато грошей, але чи замислювалися ви коли-небудь, як вони заробляють такі гроші? давайте обговоримо.

Революційні винаходи від Google, які полегшать ваше життя.

Революційні винаходи від Google, які полегшать ваше життя.

Ви хочете побачити революційні винаходи Google і як ці винаходи змінили життя кожної людини сьогодні? Тоді читайте в блозі, щоб побачити винаходи Google.

Friday Essential: Що сталося з автомобілями, керованими штучним інтелектом?

Friday Essential: Що сталося з автомобілями, керованими штучним інтелектом?

Концепція самокерованих автомобілів, щоб вирушати в дороги за допомогою штучного інтелекту, є мрією, яку ми давно мріємо. Але, незважаючи на кілька обіцянок, їх ніде не видно. Прочитайте цей блог, щоб дізнатися більше…

Технологічна сингулярність: віддалене майбутнє людської цивілізації?

Технологічна сингулярність: віддалене майбутнє людської цивілізації?

Оскільки наука розвивається швидкими темпами, бере на себе багато наших зусиль, ризики піддати себе незрозумілій Сингулярності також зростає. Читайте, що може означати для нас сингулярність.

Функціональні можливості шарів еталонної архітектури великих даних

Функціональні можливості шарів еталонної архітектури великих даних

Прочитайте блог, щоб дізнатися про різні шари архітектури великих даних та їх функціональні можливості найпростішим способом.

Еволюція зберігання даних – інфографіка

Еволюція зберігання даних – інфографіка

Методи зберігання даних можуть розвиватися з моменту народження Даних. Цей блог висвітлює еволюцію зберігання даних на основі інфографіки.

6 дивовижних переваг використання пристроїв розумного дому в нашому житті

6 дивовижних переваг використання пристроїв розумного дому в нашому житті

У цьому цифровому світі пристрої розумного дому стали важливою частиною життя. Ось кілька дивовижних переваг пристроїв розумного дому щодо того, як вони роблять наше життя гідним життя та спрощують його.

Оновлення доповнення macOS Catalina 10.15.4 спричиняє більше проблем, ніж вирішує

Оновлення доповнення macOS Catalina 10.15.4 спричиняє більше проблем, ніж вирішує

Нещодавно Apple випустила додаткове оновлення macOS Catalina 10.15.4, щоб виправити проблеми, але схоже, що оновлення викликає більше проблем, що призводять до блокування комп’ютерів Mac. Прочитайте цю статтю, щоб дізнатися більше