Nextcloud21.0.1+Apache+PHP+MariaDB+RedisをUbuntu 20.04にセットアップ


はじめに

Nextcloudは、自前のサーバを使って手軽にセキュアなファイル共有環境を実現できるオンラインストレージです。
これまで、CentOS での Nextcloud 環境の構築手順をいくつかご紹介しておりました。
今回は、Ubuntu Server 20.04 に Nextcloud 環境を構築する手順をご紹介します。
Ubuntu Server であれば、 snap パッケージを利用して手軽に Nextcloud 環境を試せるのは 過去の記事 でご紹介しておりますが、今回は、構成のアレンジがしやすいように、必要なパッケージを手動でインストールし、データベース、インメモリキャッシュサーバも追加する手順となります。

# Ubuntu Server は普段あまり触る機会がないので、手順に変なところがありましたら、やさしくツッコミをお願いします。

今回構築する環境

構成イメージ

こんな感じで、いたってシンプルです。イントラネット環境のイメージですが、Amazon EC2等のクラウドサーバー上でも構築できます。。

利用するOS、ミドルウェア

サーバOS(Ubuntu Server)

今回は Ubuntu Server 20.04 LTS を利用します。VirtualBox や Vagrant、Hyper-V などで準備いただいても問題ありません。
ここで展開している手順の環境は以下のとおりです。

$ cat /etc/os-release | grep VERSION  
VERSION="20.04.2 LTS (Focal Fossa)"
VERSION_ID="20.04"
VERSION_CODENAME=focal
$ uname -a
Linux ip-10-0-2-232 5.4.0-1045-aws #47-Ubuntu SMP Tue Apr 13 07:02:25 UTC 2021 x86_64 x86_64 x86_64 GNU/Linux

Nextcloud本体

もちろんこれがないと Nextcloud が使えません。
Nextcloud のバージョンはいろいろありますが、2021/4/18 時点の最新版である 21.0.1 を使います。

Webサーバ(Apache)

NextcloudはWebベースで動作しますので、Webサーバが動作する環境が必要です。今回はApacheを使います。
ここで展開している手順でのApacheのバージョンは以下のとおりです。

$ apache2 -v
Server version: Apache/2.4.41 (Ubuntu)
Server built:   2020-08-12T19:46:17

PHP

NextcloudはPHPで動作します。
ここで展開している手順でのPHPのバージョンは以下のとおりです。

$ php -v
PHP 7.4.16 (cli) (built: Mar  5 2021 07:54:38) ( NTS )
Copyright (c) The PHP Group
Zend Engine v3.4.0, Copyright (c) Zend Technologies
    with Zend OPcache v7.4.16, Copyright (c), by Zend Technologies

データベース(MariaDB)

Nextcloudではデータベースを利用します。本格的な運用ではMariaDB/MySQLといったデータベースを利用することが推奨されます。今回はMariaDBを利用します。
ここで展開している手順でのMariaDBのバージョンは以下のとおりです。

$ mariadb --version
mariadb  Ver 15.1 Distrib 10.5.9-MariaDB, for debian-linux-gnu (x86_64) using readline 5.2

インメモリキャッシュサーバ(Redis)

Nextcloudではファイルのロック管理をしておりますが、このデータ管理にインメモリキャッシュサーバを使うことによりパフォーマンス向上が期待できます。今回はRedisを利用します。
今回は、PHPのセッション管理もRedisで行うことができるようにします。
ここで展開している手順でのRedisのバージョンは以下のとおりです。

$ redis-server --version
Redis server v=6.2.1 sha=00000000:0 malloc=jemalloc-5.1.0 bits=64 build=9e28c64fd48469e

構築手順

ほぼほぼNextcloud公式ドキュメントに基づいて進めていきます。

前準備

①パッケージの最新化をします。

sudo apt update;sudo apt upgrade -y

②インストール作業に必要なパッケージをインストールします。

sudo apt install build-essential pkg-config tcl -y 

Webサーバー(Apache)のインストール

①Apacheをインストールします。

sudo apt install apache2 -y

.htaccessを使うため、mod_rewriteを有効にします。

cd /etc/apache2/mods-available
sudo a2enmod rewrite

③設定ファイルを追加します。

sudo vi /etc/apache2/sites-available/nextcloud.conf

【設定内容】

<VirtualHost *:80>
  DocumentRoot /var/www/html/nextcloud/
  ServerName  【サーバーのIPアドレス】

  <Directory "/var/www/html/nextcloud/">
    Require all granted
    AllowOverride All
    Options FollowSymLinks MultiViews
  </Directory>
</VirtualHost>

④追加した設定ファイルを有効にします。あわせてデフォルトの設定ファイルを無効にします。

cd /etc/apache2/sites-available/
sudo a2ensite nextcloud
sudo a2dissite 000-default

⑤Apacheを自動起動するように設定し、Apacheを起動します。

sudo systemctl enable apache2.service
sudo systemctl start apache2.service

PHPのインストール

①今回はPHP 7.4を使います。最新のPHPバージョンを取得できるようにリポジトリを追加します。

sudo add-apt-repository ppa:ondrej/php
sudo add-apt-repository ppa:ondrej/apache2

②PHPならびに関連モジュールをインストールします。

sudo apt install php7.4 php7.4-curl php7.4-dom php7.4-gd php7.4-mbstring php7.4-zip php7.4-mysql php7.4-bz2 php7.4-intl php7.4-apcu php7.4-redis php7.4-imagick php7.4-bcmath php7.4-gmp -y

③PHPの設定を一部修正します。

sudo sed -i "s/^max_execution_time = 30/max_execution_time = 60/" /etc/php/7.4/apache2/php.ini
sudo sed -i "s/^memory_limit = 128M/memory_limit = 512M/" /etc/php/7.4/apache2/php.ini
sudo sed -i "s/^session.save_handler = files/session.save_handler = redis/" /etc/php/7.4/apache2/php.ini
sudo sed -i "s@^;session.save_path = \"/var/lib/php/sessions\"@session.save_path = \"tcp://localhost:6379\"@" /etc/php/7.4/apache2/php.ini

MariaDBのインストール

①今回はMariaDB 10.5を使います。最新のMariaDBバージョンを取得できるようにリポジトリを追加します。

sudo apt-key adv --fetch-keys 'https://mariadb.org/mariadb_release_signing_key.asc'
sudo add-apt-repository 'deb [arch=amd64] http://mariadb.mirror.globo.tech/repo/10.5/ubuntu focal main'

②MariaDBをインストールします。

sudo apt install mariadb-server mariadb-client -y

③MariaDBを自動起動するように設定し、MariaDBを起動します。

sudo systemctl enable mariadb.service
sudo systemctl start mariadb.service

④MariaDBの基本セットアップを行います。いくつか質問されますが New password:Re-enter new password:で MariaDBのrootユーザのパスワードを設定する以外は全て[Enter]キーを押しておきます。

sudo mysql_secure_installation

⑤MariaDBコンソールを使い、引き続きNextcloudで使用するユーザ、データベース、権限の追加をします。ここではそれぞれ以下のとおり設定します。

  • ユーザ: nextcloud
  • データベース名: nextcloud
sudo mysql -uroot

CREATE DATABASE nextcloud DEFAULT CHARACTER SET utf8mb4;
CREATE USER 'nextcloud'@'localhost' IDENTIFIED BY '[nextcloudユーザに対して設定したいパスワード]';
GRANT ALL ON nextcloud.* TO "nextcloud"@"localhost";
SHOW GRANTS FOR 'nextcloud'@'localhost';
quit;

【SHOW GRANTS ~の実行結果例】

MariaDB [(none)]> SHOW GRANTS FOR 'nextcloud'@'localhost';
+------------------------------------------------------------------------------------------------------------------+
| Grants for nextcloud@localhost                                                                                   |
+------------------------------------------------------------------------------------------------------------------+
| GRANT USAGE ON *.* TO `nextcloud`@`localhost` IDENTIFIED BY PASSWORD '*********'                                 |
| GRANT ALL PRIVILEGES ON `nextcloud`.* TO `nextcloud`@`localhost`                                                 |
+------------------------------------------------------------------------------------------------------------------+
2 rows in set (0.002 sec)

Redisのインストール

①今回は2021/4/18現在でstableの最新版であるRedis 6.2を使います。普通にパッケージインストールするとバージョンが古くなってしまうため、ソースからコンパイルしてインストールします。Redisのソースファイル群を取得します。

cd /tmp
wget http://download.redis.io/redis-stable.tar.gz
tar xf redis-stable.tar.gz

②makeし、インストールします。

cd redis-stable
make
sudo make install

③必要なユーザー、ディレクトリを準備します。

sudo adduser --system --group --no-create-home redis
sudo mkdir /etc/redis
sudo mkdir /var/log/redis
sudo mkdir /var/lib/redis
sudo chown redis:redis /etc/redis
sudo chown redis:redis /var/log/redis
sudo chown redis:redis /var/lib/redis
sudo chmod 770 /var/lib/redis

④Redisの設定ファイルのテンプレートをコピー、編集して設定ファイルを作成します。

sudo cp redis.conf /etc/redis
sudo su -c "sed -e 's/^logfile .*$/logfile \"\/var\/log\/redis\/redis.log\"/' -e 's/^dir .*$/dir \/var\/lib\/redis\//' ./redis.conf > /etc/redis/redis.conf"

⑤自動起動設定ファイルを作成します。

sudo vi /etc/systemd/system/redis.service

【redis.serviceの内容】

[Unit]
Description=Redis In-Memory Data Store
After=network.target

[Service]
User=redis
Group=redis
ExecStart=/usr/local/bin/redis-server /etc/redis/redis.conf
ExecStop=/usr/local/bin/redis-cli shutdown
Restart=always

[Install]
WantedBy=multi-user.target

⑥Redisを自動起動するように設定し、Redisを起動します。

sudo systemctl enable redis.service
sudo systemctl start redis.service

Nextcloudのインストール

①Nextcloudパッケージ本体とチェックサムファイル(Nextcloudパッケージ本体が正しくダウンロードされているかをチェックするためのファイル)をダウンロードします。

cd /tmp
wget https://download.nextcloud.com/server/releases/nextcloud-21.0.1.tar.bz2
wget https://download.nextcloud.com/server/releases/nextcloud-21.0.1.tar.bz2.md5

②チェックサムファイルを利用してNextcloudパッケージが正しくダウンロードされているか確認します。

md5sum -c nextcloud-21.0.1.tar.bz2.md5 < nextcloud-21.0.1.tar.bz2

nextcloud-21.0.1.tar.bz2: OK または nextcloud-21.0.1.tar.bz2: 完了 と表示されれば OK です

③ダウンロードしたNextcloudパッケージを展開します。

tar xf nextcloud-21.0.1.tar.bz2

④展開したNextcloudをWebサーバをインストールします。

sudo mv nextcloud/ /var/www/html/

⑤Nextcloudのデータディレクトリを作成します。

sudo mkdir /var/www/html/nextcloud/data

⑥Nextcloudのディレクトリ全体で読み書きができるように所有者情報を変更します。

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

⑦Apacheを再起動します。

sudo systemctl restart apache2.service

Nextcloudの初期設定

①ブラウザで http://(サーバのIPアドレス)/ にアクセスします。下のような画面が出ればOKです。この画面で以下のとおり入力し、「セットアップを完了します」をクリックします。

項目 入力値
ユーザー名 初期の管理者ユーザー名
パスワード このユーザーのパスワード
データベースのユーザー名 nextcloud
データベースのパスワード nextcloudユーザーに設定したパスワード
データベース名 nextcloud
データベースのホスト名 localhost:3306
推奨アプリをインストール チェックを外す

②データベースに必要なテーブルなどが自動作成され、このような画面が表示され、Nextcloudが動作します。

⑤データベースにテーブルができていることを確認します。これでデータベース周りの設定は終わりです。

sudo mysql -u root nextcloud
SHOW TABLES;
quit;

SHOW TABLES; の実行結果】

+-----------------------------+
| Tables_in_nextcloud         |
+-----------------------------+
| oc_accounts                 |
| oc_accounts_data            |
| oc_activity                 |

~~~ (中略) ~~~

| oc_vcategory_to_object      |
| oc_webauthn                 |
| oc_whats_new                |
+-----------------------------+

⑥Nextcloudの設定ファイルに設定を追加します。

sudo vi /var/www/html/nextcloud/config/config.php

【一番下の } の上に以下の行を追加】

  'default_phone_region' => 'JP',
  'memcache.distributed' => '\\OC\\Memcache\\Redis',
  'memcache.locking' => '\\OC\\Memcache\\Redis',
  'memcache.local' => '\\OC\\Memcache\\APCu',
  'redis' =>
  array (
    'host' => 'localhost',
    'port' => 6379,
  ),
  'htaccess.RewriteBase' => '/',

⑦.htaccessファイルを更新します。

sudo -u www-data php /var/www/nextcloud/occ maintenance:update:htaccess

⑧Nextcloud セットアップ警告対応のためにパッケージを追加インストールします。

sudo apt install libmagickcore-6.q16-6-extra -y

⑨変更した設定を反映させるためにApacheを再起動します。

sudo systemctl restart apache2

あとがき

Nextcloudはサーバー1つあれば気軽に試せますので、使い勝手とかいろいろ試してみてください。
次回は、WebサーバーとしてNginxを使う場合の手順を展開する予定です。

更新履歴

  • 2021/4/18: 初版。