CentOS 7に請求書忍者をインストールする方法

前書き

Invoice Ninjaは、請求書、支払い、時間の追跡などに使用できる無料のオープンソースのウェブベースアプリケーションソフトウェアです。これは、請求および請求の顧客にとって最適なソリューションです。数秒でオンラインで簡単に請求書を作成して送信できます。請求書忍者を使用すると、独自のカスタム請求書を作成し、PDFファイルとしてライブ請求書を表示できます。

このチュートリアルでは、CentOS 7サーバーにInvoice Ninjaをインストールする方法を説明します。

前提条件

  • 2GB RAMがインストールされたCentOS 7 x64インスタンス。
  • sudoのユーザー

ステップ1:システムを更新する

CentOSサーバーインスタンスにパッケージをインストールする前に、システムを更新することをお勧めします。sudoユーザーとしてSSH経由でサーバーにログインし、次のコマンドを実行します。

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

次に、Invoice NinjaのインストールにはPHP7およびPHP7.0-FPMが必要です。

まず、次のコマンドを使用してシステムに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を構成する

次に、NginxユーザーのPHP-FPMプールを構成する必要があります。

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:請求書忍者をダウンロードして設定する

次のコマンドを使用して、GitHubリポジトリからInvoice Ninjaの最新の安定バージョンをダウンロードできます。

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

また、PHP(コンポーザー)の依存関係マネージャーをインストールする必要があります。次のコマンドでiinstallできます:

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 nginx:nginx /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.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 Webサーバーを再起動します。

sudo systemctl restart nginx

ステップ7:請求書忍者にアクセスする

Invoice Ninja Webインターフェースにアクセスする前に、firewalldを介したhttpおよびhttpsサービスを許可する必要があります。以下のコマンドを実行してポートを開きます。

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

最後に、Webブラウザーを開いてURLを入力https://192.168.15.23し、必要な手順を実行してインストールを完了します。

おめでとう!CentOS 7サーバーにNginxとMariaDBを含むInvoice Ninjaを正常にインストールしました。



Leave a Comment

CentOS 7にApacheをインストールする方法

CentOS 7にApacheをインストールする方法

CentOS 7サーバーにApache 2.4をインストールする方法を説明します。安定したウェブサーバーを構築するための前提条件と手順を解説します。

FreeBSD 11.1にBlacklistdをインストールする方法

FreeBSD 11.1にBlacklistdをインストールする方法

FreeBSD 11.1におけるBlacklistdのインストール方法について詳しく解説します。この方法を通じて、強力なセキュリティ対策を実装できます。

Windows Serverのサーバーマネージャーを使用した複数サーバーの管理

Windows Serverのサーバーマネージャーを使用した複数サーバーの管理

サーバーマネージャーを使用して、Windows Serverの管理が向上します。セキュリティリスクを軽減し、効率的な管理を実現します。

CentOS 7にSeafileサーバーをインストールする方法

CentOS 7にSeafileサーバーをインストールする方法

CentOS 7にSeafileサーバーをインストールする方法。Seafile(コミュニティバージョン)は、ownCloudに似た無料のオープンソースファイル同期および共有ソリューションです。

DebianでSnortを設定する方法

DebianでSnortを設定する方法

Snortは無料のネットワーク侵入検知システムです。最新の方法で、SnortをDebianにインストールし、設定する手順を紹介します。ネットワークのセキュリティを強化しましょう。

CentOS 7にGraylogサーバーをインストールする方法

CentOS 7にGraylogサーバーをインストールする方法

CentOS 7にGraylogサーバーをインストールし、ログ管理を行う方法を学びます。

WindowsでhMailServerを使用してメールサーバーを構築する

WindowsでhMailServerを使用してメールサーバーを構築する

WindowsサーバーでWebサイトを実行している場合、電子メールも受信できるようにするためにhMailServerを使用する方法を解説します。

Ubuntu 19.04にFiveMサーバーをインストールする方法

Ubuntu 19.04にFiveMサーバーをインストールする方法

FiveMサーバーをUbuntu 19.04にインストールするための詳細なガイド。必要条件からインストール、起動、トラブルシューティングまで、すべてのステップを含みます。

WsgiDAVを使用してDebian 10にWebDAVをデプロイする

WsgiDAVを使用してDebian 10にWebDAVをデプロイする

Debian 10にWebDAVをデプロイする方法を学び、WsgiDAVとSSL証明書で安全な接続を実現しましょう。

ヘルスケア2021における人工知能の影響

ヘルスケア2021における人工知能の影響

ヘルスケアにおけるAIは、過去数十年から大きな飛躍を遂げました。したがって、ヘルスケアにおけるAIの未来は、日々成長を続けています。