Як встановити 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.


Встановіть Plesk на CentOS 7

Встановіть Plesk на CentOS 7

Використання іншої системи? Plesk — це власна панель керування веб-хостом, яка дозволяє користувачам адмініструвати свої персональні та/або клієнтські веб-сайти, бази даних

Як встановити Squid Proxy на CentOS

Як встановити Squid Proxy на CentOS

Squid — популярна безкоштовна програма для Linux, яка дозволяє створювати веб-проксі для переадресації. У цьому посібнику ви дізнаєтеся, як встановити Squid на CentOS, щоб перетворити вас

Як встановити Lighttpd (LLMP Stack) на CentOS 6

Як встановити Lighttpd (LLMP Stack) на CentOS 6

Вступ Lighttpd — це форк Apache, який має набагато меншу ресурсомісткість. Він легкий, звідси його назва, і досить простий у використанні. Встановити

Налаштування статичної мережі та IPv6 на CentOS 7

Налаштування статичної мережі та IPv6 на CentOS 7

VULTR нещодавно вніс зміни на свою сторону, і тепер усе має працювати нормально з коробки з увімкненим NetworkManager. Якщо ви бажаєте вимкнути

Змінення Icinga2 для використання моделі Master/Client на CentOS 6 або CentOS 7

Змінення Icinga2 для використання моделі Master/Client на CentOS 6 або CentOS 7

Icinga2 — це потужна система моніторингу, і при використанні в моделі «майстер-клієнт» вона може замінити потребу в перевірках моніторингу на основі NRPE. Майстер-клієнт

Як встановити Apache Cassandra 3.11.x на CentOS 7

Як встановити Apache Cassandra 3.11.x на CentOS 7

Використання іншої системи? Apache Cassandra — це безкоштовна система керування базами даних NoSQL з відкритим вихідним кодом, яка розроблена для забезпечення масштабованості, високої

Як встановити Microweber на CentOS 7

Як встановити Microweber на CentOS 7

Використання іншої системи? Microweber — це CMS та інтернет-магазин із відкритим вихідним кодом. Вихідний код Microweber розміщено на GitHub. Цей посібник покаже вам

Як встановити Vanilla Forum на CentOS 7

Як встановити Vanilla Forum на CentOS 7

Використання іншої системи? Vanilla forum — це програма з відкритим вихідним кодом, написана на PHP. Це повністю настроюваний, простий у використанні та підтримує зовнішній вигляд

Як встановити Mattermost 4.1 на CentOS 7

Як встановити Mattermost 4.1 на CentOS 7

Використання іншої системи? Mattermost — це автономна альтернатива службі обміну повідомленнями Slack SAAS з відкритим кодом. Іншими словами, з Mattermost ви бл

Lets Encrypt на Plesk

Lets Encrypt на Plesk

Панель керування Plesk має дуже гарну інтеграцію для Lets Encrypt. Lets Encrypt є одним із єдиних постачальників SSL, які надають сертифікати повністю

Дозволяє шифрувати на cPanel

Дозволяє шифрувати на cPanel

Lets Encrypt — це центр сертифікації, який надає безкоштовні сертифікати SSL. cPanel створив чітку інтеграцію, щоб ви і ваш клієнт

Як встановити Concrete5 на CentOS 7

Як встановити Concrete5 на CentOS 7

Використання іншої системи? Concrete5 — це CMS з відкритим вихідним кодом, яка пропонує багато відмінних і корисних функцій, які допомагають редакторам легко створювати вміст.

Як встановити Review Board на CentOS 7

Як встановити Review Board на CentOS 7

Використання іншої системи? Review Board — це безкоштовний інструмент з відкритим кодом для перегляду вихідного коду, документації, зображень та багато іншого. Це веб-програмне забезпечення

Налаштуйте автентифікацію HTTP за допомогою Nginx на CentOS 7

Налаштуйте автентифікацію HTTP за допомогою Nginx на CentOS 7

У цьому посібнику ви дізнаєтеся, як налаштувати автентифікацію HTTP для веб-сервера Nginx, що працює на CentOS 7. Вимоги Щоб почати, вам знадобиться

Як встановити GoAccess на CentOS 7

Як встановити GoAccess на CentOS 7

Використання іншої системи? GoAccess — це аналізатор веб-журналів з відкритим вихідним кодом. Ви можете використовувати його для аналізу журналів у режимі реального часу в терміналі або

Як встановити YOURLS на CentOS 7

Як встановити YOURLS на CentOS 7

YOURLS (Your Own URL Shortener) — програма для скорочення URL-адрес і аналізу даних із відкритим вихідним кодом. У цій статті ми розглянемо процес встановлення

Як встановити та налаштувати ArangoDB на CentOS 7

Як встановити та налаштувати ArangoDB на CentOS 7

Використання іншої системи? Вступ ArangoDB — це відкрита база даних NoSQL з гнучкою моделлю даних для документів, графіків і ключів-значень. це є

Використання Etckeeper для контролю версій /etc

Використання Etckeeper для контролю версій /etc

Вступ Каталог /etc/ відіграє важливу роль у функціонуванні системи Linux. Причина цього в тому, що майже кожна конфігурація системи

Чому ви повинні використовувати SSHFS? Як підключити віддалену файлову систему з SSHFS на CentOS 6

Чому ви повинні використовувати SSHFS? Як підключити віддалену файлову систему з SSHFS на CentOS 6

Багато системних адміністраторів керують великою кількістю серверів. Якщо потрібно отримати доступ до файлів на різних серверах, увійти на кожен окремо бл

Налаштування сервера Half Life 2 на CentOS 6

Налаштування сервера Half Life 2 на CentOS 6

У цьому посібнику буде описано процес встановлення ігрового сервера Half Life 2 на систему CentOS 6. Крок 1: Встановлення необхідних умов Щоб налаштувати ou

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

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

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

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. Прочитайте цю статтю, щоб дізнатися більше