Встановіть Plesk на CentOS 7
Використання іншої системи? Plesk — це власна панель керування веб-хостом, яка дозволяє користувачам адмініструвати свої персональні та/або клієнтські веб-сайти, бази даних
Invoice Ninja — це безкоштовне програмне забезпечення для веб-баз з відкритим кодом, яке можна використовувати для виставлення рахунків, платежів, відстеження часу та багато іншого. Це найкраще рішення для виставлення рахунків і виставлення рахунків клієнтам. Ви можете легко створювати та надсилати рахунки-фактури онлайн за лічені секунди. Invoice Ninja дозволяє створювати власний рахунок-фактуру та показувати поточний рахунок-фактуру у форматі PDF-файлу.
У цьому підручнику я поясню вам, як встановити Invoice Ninja на сервері CentOS 7.
Перед встановленням будь-яких пакетів на екземпляр сервера CentOS рекомендується оновити систему. Увійдіть на свій сервер через SSH як ваш користувач sudo і виконайте таку команду:
sudo yum install epel-release -y
sudo yum update -y
sudo shutdown -r now
Перш ніж почати, вам потрібно буде встановити 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
Збережіть і закрийте файл.
За замовчуванням інсталяція 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
Далі вам потрібно буде налаштувати пул 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
Ви можете завантажити останню стабільну версію 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/
Далі вам потрібно буде створити сертифікат 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
Перш ніж отримати доступ до веб-інтерфейсу 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 — це власна панель керування веб-хостом, яка дозволяє користувачам адмініструвати свої персональні та/або клієнтські веб-сайти, бази даних
Squid — популярна безкоштовна програма для Linux, яка дозволяє створювати веб-проксі для переадресації. У цьому посібнику ви дізнаєтеся, як встановити Squid на CentOS, щоб перетворити вас
Вступ Lighttpd — це форк Apache, який має набагато меншу ресурсомісткість. Він легкий, звідси його назва, і досить простий у використанні. Встановити
VULTR нещодавно вніс зміни на свою сторону, і тепер усе має працювати нормально з коробки з увімкненим NetworkManager. Якщо ви бажаєте вимкнути
Icinga2 — це потужна система моніторингу, і при використанні в моделі «майстер-клієнт» вона може замінити потребу в перевірках моніторингу на основі NRPE. Майстер-клієнт
Використання іншої системи? Apache Cassandra — це безкоштовна система керування базами даних NoSQL з відкритим вихідним кодом, яка розроблена для забезпечення масштабованості, високої
Використання іншої системи? Microweber — це CMS та інтернет-магазин із відкритим вихідним кодом. Вихідний код Microweber розміщено на GitHub. Цей посібник покаже вам
Використання іншої системи? Vanilla forum — це програма з відкритим вихідним кодом, написана на PHP. Це повністю настроюваний, простий у використанні та підтримує зовнішній вигляд
Використання іншої системи? Mattermost — це автономна альтернатива службі обміну повідомленнями Slack SAAS з відкритим кодом. Іншими словами, з Mattermost ви бл
Панель керування Plesk має дуже гарну інтеграцію для Lets Encrypt. Lets Encrypt є одним із єдиних постачальників SSL, які надають сертифікати повністю
Lets Encrypt — це центр сертифікації, який надає безкоштовні сертифікати SSL. cPanel створив чітку інтеграцію, щоб ви і ваш клієнт
Використання іншої системи? Concrete5 — це CMS з відкритим вихідним кодом, яка пропонує багато відмінних і корисних функцій, які допомагають редакторам легко створювати вміст.
Використання іншої системи? Review Board — це безкоштовний інструмент з відкритим кодом для перегляду вихідного коду, документації, зображень та багато іншого. Це веб-програмне забезпечення
У цьому посібнику ви дізнаєтеся, як налаштувати автентифікацію HTTP для веб-сервера Nginx, що працює на CentOS 7. Вимоги Щоб почати, вам знадобиться
Використання іншої системи? GoAccess — це аналізатор веб-журналів з відкритим вихідним кодом. Ви можете використовувати його для аналізу журналів у режимі реального часу в терміналі або
YOURLS (Your Own URL Shortener) — програма для скорочення URL-адрес і аналізу даних із відкритим вихідним кодом. У цій статті ми розглянемо процес встановлення
Використання іншої системи? Вступ ArangoDB — це відкрита база даних NoSQL з гнучкою моделлю даних для документів, графіків і ключів-значень. це є
Вступ Каталог /etc/ відіграє важливу роль у функціонуванні системи Linux. Причина цього в тому, що майже кожна конфігурація системи
Багато системних адміністраторів керують великою кількістю серверів. Якщо потрібно отримати доступ до файлів на різних серверах, увійти на кожен окремо бл
У цьому посібнику буде описано процес встановлення ігрового сервера Half Life 2 на систему CentOS 6. Крок 1: Встановлення необхідних умов Щоб налаштувати ou
Штучний інтелект не в майбутньому, він тут прямо в сьогоденні У цьому блозі Прочитайте, як програми штучного інтелекту вплинули на різні сектори.
Ви також стали жертвою DDOS-атак і спантеличені методами запобігання? Прочитайте цю статтю, щоб вирішити свої запитання.
Можливо, ви чули, що хакери заробляють багато грошей, але чи замислювалися ви коли-небудь, як вони заробляють такі гроші? давайте обговоримо.
Ви хочете побачити революційні винаходи Google і як ці винаходи змінили життя кожної людини сьогодні? Тоді читайте в блозі, щоб побачити винаходи Google.
Концепція самокерованих автомобілів, щоб вирушати в дороги за допомогою штучного інтелекту, є мрією, яку ми давно мріємо. Але, незважаючи на кілька обіцянок, їх ніде не видно. Прочитайте цей блог, щоб дізнатися більше…
Оскільки наука розвивається швидкими темпами, бере на себе багато наших зусиль, ризики піддати себе незрозумілій Сингулярності також зростає. Читайте, що може означати для нас сингулярність.
Методи зберігання даних можуть розвиватися з моменту народження Даних. Цей блог висвітлює еволюцію зберігання даних на основі інфографіки.
Прочитайте блог, щоб дізнатися про різні шари архітектури великих даних та їх функціональні можливості найпростішим способом.
У цьому цифровому світі пристрої розумного дому стали важливою частиною життя. Ось кілька дивовижних переваг пристроїв розумного дому щодо того, як вони роблять наше життя гідним життя та спрощують його.
Нещодавно Apple випустила додаткове оновлення macOS Catalina 10.15.4, щоб виправити проблеми, але схоже, що оновлення викликає більше проблем, що призводять до блокування комп’ютерів Mac. Прочитайте цю статтю, щоб дізнатися більше