Ubuntu 16.04에 송장 닌자를 설치하는 방법

소개

Invoice Ninja는 무료, 오픈 소스 웹 기반 응용 프로그램으로 송장, 지불, 시간 추적 등에 사용할 수 있습니다. 인보이스 및 청구 고객에게 가장 적합한 솔루션입니다. 몇 초 만에 온라인으로 쉽게 송장을 작성하고 보낼 수 있습니다. 송장 Ninja를 사용하면 사용자 정의 송장을 만들고 라이브 송장을 PDF 파일로 표시 할 수 있습니다.

이 튜토리얼에서는 Ubuntu 16.04 서버에 Invoice Ninja를 설치하는 방법을 설명합니다.

전제 조건

  • 2GB RAM이 설치된 Ubuntu 16.04 서버 인스턴스
  • 루트 권한이있는 sudo 사용자
  • 서버 인스턴스의 기본 IP를 알아야합니다. 이 자습서에서는을 사용 192.168.0.227합니다.

1 단계 : 시스템 업데이트

Ubuntu 서버 인스턴스에 패키지를 설치하기 전에 시스템을 업데이트하는 것이 좋습니다. sudo 사용자로 SSH를 통해 서버에 로그인하고 다음 명령을 실행하십시오.

sudo apt-get update -y
sudo apt-get upgrade -y
sudo shutdown -r now

2 단계 : LEMP 스택 설치

시작하기 전에 서버에서 LEMP (Nginx, MariaDB 및 PHP) 스택을 구성해야합니다.

먼저 다음 명령을 사용하여 Nginx 및 MariaDB를 설치하십시오.

sudo apt-get install nginx mariadb-server -y

설치가 완료되면 Nginx 및 MariaDB 서비스를 시작하고 부팅시 시작할 수 있도록합니다 :

sudo systemctl start nginx
sudo systemctl enable nginx
sudo systemctl start mysql
sudo systemctl enable mysql

다음으로, Invoice Ninja 설치를 위해 PHP 7 및 PHP-FPM이 필요합니다.

다음 명령을 사용하여 PHP-FPM 및 기타 필요한 PHP 확장을 설치할 수 있습니다.

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

설치가 완료되면 php.ini구성 파일 을 수정해야 합니다.

sudo nano /etc/php/7.0/fpm/php.ini

다음 줄을 변경하십시오.

cgi.fix_pathinfo=0

파일을 저장하고 닫습니다.

3 단계 : 데이터베이스 구성

기본적으로 MariaDB 설치는 보안되지 않습니다. 당신은 그것을 확보해야합니다. 을 실행하여이를 수행 할 수 있습니다 mysql_secure_installation script.

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

루트 비밀번호를 입력하고 "enter"를 누르면 MySQL (MariaDB) 쉘이 나타납니다.

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 구성

Nginx 사용자를위한 PHP-FPM 풀을 구성하십시오 :

sudo nano /etc/php/7.0/fpm/pool.d/www-data.conf

다음 줄을 추가하십시오.

[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 = /

완료되면 파일을 저장하고 닫은 다음 PHP-FPM을 다시 시작하여 이러한 변경 사항을 적용하십시오.

systemctl restart php7.0-fpm

5 단계 : 송장 닌자 다운로드 및 구성

다음 명령을 사용하여 GitHub 리포지토리에서 최신 안정 버전의 Invoice Ninja를 다운로드 할 수 있습니다.

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

또한 PHP의 종속성 관리자 인 Composer를 설치해야합니다. 다음 명령을 사용하여 설치할 수 있습니다.

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

그런 다음 composer아래 표시된 명령을 사용하여 모든 Invoice Ninja 종속성을 설치하십시오 .

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

명령을 실행하라는 프롬프트가 표시되면 "yes"를 입력하고 "enter"를 누르십시오.

다음으로 아래와 같이 레코드가있는 데이터베이스를 시드하십시오.

sudo php artisan db:seed

"yes"를 입력하고 "enter"를 누르십시오.

다음으로 /var/www/html/ninja디렉토리의 소유권을 변경하십시오 .

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

6 단계 : 송장 닌자에 대해 Nginx 구성

다음으로 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.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;
       }
    }

파일을 저장하고 닫습니다. 그런 다음 다음 명령으로 가상 호스트를 활성화하십시오.

sudo ln -s /etc/nginx/sites-available/ninja /etc/nginx/sites-enabled/

마지막으로 Nginx 웹 서버를 다시 시작하십시오.

sudo systemctl restart nginx

7 단계 : 송장 닌자 액세스

Invoice Ninja 웹 인터페이스에 액세스하기 전에 UFW 방화벽을 통해 HTTP 및 HTTPS 서비스를 허용해야합니다. 다음 명령을 실행하여이 포트를여십시오.

sudo ufw allow 80/tcp
sudo ufw allow 443/tcp

마지막으로 웹 브라우저를 열고 URL에 액세스하십시오 https://192.168.0.227. 그런 다음 필요한 단계를 완료하여 설치를 완료 할 수 있습니다.

축하합니다! 우분투 16.04 서버에 Nginx 및 MariaDB와 함께 Invoice Ninja를 성공적으로 설치했습니다.



Leave a Comment

AI가 랜섬웨어 공격의 증가와 싸울 수 있습니까?

AI가 랜섬웨어 공격의 증가와 싸울 수 있습니까?

랜섬웨어 공격이 증가하고 있지만 AI가 최신 컴퓨터 바이러스를 처리하는 데 도움이 될 수 있습니까? AI가 답인가? AI boone 또는 bane인지 여기에서 읽으십시오.

ReactOS: 이것이 Windows의 미래입니까?

ReactOS: 이것이 Windows의 미래입니까?

오픈 소스이자 무료 운영 체제인 ReactOS가 최신 버전과 함께 제공됩니다. 현대 Windows 사용자의 요구 사항을 충족하고 Microsoft를 무너뜨릴 수 있습니까? 이 구식이지만 더 새로운 OS 환경에 대해 자세히 알아보겠습니다.

WhatsApp 데스크톱 앱 24*7을 통해 연결 유지

WhatsApp 데스크톱 앱 24*7을 통해 연결 유지

Whatsapp은 마침내 Mac 및 Windows 사용자용 데스크톱 앱을 출시했습니다. 이제 Windows 또는 Mac에서 Whatsapp에 쉽게 액세스할 수 있습니다. Windows 8 이상 및 Mac OS 10.9 이상에서 사용 가능

AI는 어떻게 프로세스 자동화를 다음 단계로 끌어올릴 수 있습니까?

AI는 어떻게 프로세스 자동화를 다음 단계로 끌어올릴 수 있습니까?

인공 지능이 소규모 회사에서 어떻게 인기를 얻고 있으며 어떻게 인공 지능이 성장할 가능성을 높이고 경쟁자가 우위를 점할 수 있는지 알아보려면 이 기사를 읽으십시오.

macOS Catalina 10.15.4 추가 업데이트로 인해 해결보다 더 많은 문제가 발생함

macOS Catalina 10.15.4 추가 업데이트로 인해 해결보다 더 많은 문제가 발생함

최근 Apple은 문제를 해결하기 위해 macOS Catalina 10.15.4 추가 업데이트를 출시했지만 이 업데이트로 인해 Mac 컴퓨터의 브릭킹으로 이어지는 더 많은 문제가 발생하는 것 같습니다. 자세히 알아보려면 이 기사를 읽어보세요.

빅데이터의 13가지 상용 데이터 추출 도구

빅데이터의 13가지 상용 데이터 추출 도구

빅데이터의 13가지 상용 데이터 추출 도구

저널링 파일 시스템이란 무엇이며 어떻게 작동합니까?

저널링 파일 시스템이란 무엇이며 어떻게 작동합니까?

우리 컴퓨터는 모든 데이터를 저널링 파일 시스템이라고 하는 체계적인 방식으로 저장합니다. 검색을 누르는 즉시 컴퓨터에서 파일을 검색하고 표시할 수 있는 효율적인 방법입니다.https://wethegeek.com/?p=94116&preview=true

기술적 특이점: 인류 문명의 먼 미래?

기술적 특이점: 인류 문명의 먼 미래?

과학이 빠른 속도로 발전하고 우리의 많은 노력을 인수함에 따라 설명할 수 없는 특이점에 처할 위험도 높아집니다. 특이점이 우리에게 무엇을 의미할 수 있는지 읽어보십시오.

26가지 빅 데이터 분석 기법에 대한 통찰: 1부

26가지 빅 데이터 분석 기법에 대한 통찰: 1부

26가지 빅 데이터 분석 기법에 대한 통찰: 1부

2021년 의료 분야에서 인공 지능의 영향

2021년 의료 분야에서 인공 지능의 영향

의료 분야의 AI는 지난 수십 년 동안 큰 도약을 했습니다. 따라서 의료 분야에서 AI의 미래는 여전히 나날이 성장하고 있습니다.