diff --git a/content/TruenasApps/StableApps/PlexApp.md b/content/TruenasApps/StableApps/PlexApp.md new file mode 100644 index 0000000000..b09fc618ce --- /dev/null +++ b/content/TruenasApps/StableApps/PlexApp.md @@ -0,0 +1,265 @@ +--- +title: "Plex" +description: "Provides installation instructions to configure and deploy the Plex app in TrueNAS." +weight: +aliases: +tags: +- apps +- media +keywords: +- nas data storage +- software storage solutions +- TrueNAS media applications +--- + + +Plex is a media server that allows you to manage and stream your media (music, movies, live TV, etc.) to any Plex client. + +{{< include file="/static/includes/AppsUnversioned.md" >}} + +## Before You Begin +Before you install the Plex app: + +* Set up a Plex account. + + After installing the Plex app and logging into Plex through the **Web Portal** button in TrueNAS, if you have not already configured your Plex account media server, Plex shows the configuration screens to set up the media server, add libraries, and customize your Plex account. + +{{< include file="/static/includes/apps/AppsStableBeforeYouBegin.md" >}} + +* Go to **Datasets**, and select the pool or dataset where you want to add the Plex datasets. + For example, */tank/apps/plex* or */tank/plex*. + You can use either an existing pool or [create a new one]({{< relref "CreatePoolWizard.md" >}}) + + Create the two datasets Plex uses for storage volumes: + * **data** for user media data storage + * **config** for Plex application configuration storage. + + You can create a dataset for log data or use a temporary directory option for log data. + Transcode data is not useful or meant for persistent storage, so using a temporary directory is a better option. + + When creating the above datasets, select the **apps** dataset preset. + + You can set up the permissions (ACLs) for these datasets after adding them using the **Edit ACL** screen, or wait and use the **Install Plex** wizard ACL settings to add permissions. You can also edit permissions after using either method. + +### Installing the Plex App +{{< hint info >}} +This basic procedure covers the required Plex app settings. +For optional settings, see [Understanding App Installation Wizard Settings](#understanding-app-installation-wizard-settings). +{{< /hint >}} + +{{< include file="/static/includes/apps/AddMultipleAppInstancesAndNaming.md" >}} + +{{< include file="/static/includes/apps/LocateAndOpenInstallWizard.md" >}} + +{{< trueimage src="/images/SCALE/Apps/InstallPlexScreen.png" alt="Install Plex Screen" id="Install Plex Screen" >}} + +{{< include file="/static/includes/apps/AppsWizardAppNameAndVersion.md" >}} + +Next, enter the **Plex Configuration** settings. +For a basic installation, you can accept the default values. + +{{< include file="/static/includes/apps/AppsInstallWizardTimezoneSetting.md" >}} + +While logged into your Plex account, go to the [Plex **Claim Code** web page](https://www.plex.tv/claim/) to copy the **Claim Code** string provided by Plex, and then paste it into the TrueNAS **Install Plex** wizard **Claim Token** field. This authentication token provides TrueNAS access to your Plex account. + +{{< trueimage src="/images/SCALE/Apps/InstallPlexConfig1.png" alt="Plex Configuration Settings" id="Plex Configuration Settings" >}} + +Next, either accept the default values shown or enter the IP addresses for local network connections (Ethernet or WiFi routers) you want in your Plex network. +See [Setting Up Local Network](#setting-up-local-network) below for more information. + +You can add devices and/or additional environment variables, but these are not necessary to deploy the app. +For more information on adding these, see [Adding Devices](#adding-devicess) below. + +Accept the default values in both **User and Group Configuration** and **Network Configurations**. +(Optional) If you created a new user to administer apps, enter that user ID in the user and group fields. +See [User and Group Configuration](#user-and-group-configuration) and [Network Configuration](#network-configuration) for more details. + +Add your **Storage Configuration** settings. +{{< expand "Configuring Plex Storage" "v" >}} +Set **Host Path (Path that already exists on the system)** in **Type** for **Plex Data Storage**. +Select **Enable ACL**, and then either enter or browse to and select the **data** dataset to populate the **Host Path** field. + +{{< trueimage src="/images/SCALE/Apps/InstallPlexStorageConfigDataACLandACE.png" alt="Add Plex Data Storage" id="Add Plex Data Storage" >}} + +Select **Add** to the right of **ACL Entries** for each user or group entry you want to add. +For example, add the **568** user and **0**, and give each **FULL_CONTROL Access**. + +Select **Force Flag**. + +Repeat the storage steps above for the **Plex Configuration** and, when using a dataset for logs, for the **Plex Logs** storage volumes. +Create a dataset for log storage to save and easily access log data. +If not, set the storage volume type to either **temporary** or **tmpfs** for both **Logs** and **Transcode** storage. +{{< /expand >}} + +Add any labels you want to use to organize your media files. +For example, labeling video files as *movies* or *sports*, etc. Labels allow creating custom groupings or classifications beyond the default metadata provided by Plex. + +Accept the defaults in **Resources Configuration** and select the GPU option if you have a compatible GPU installed in the system and you want to use it for hardware-accelerated transcoding. + +Click **Install**. A progress dialog opens before switching to the **Installed** applications screen. +The **Installed** screen shows the **plex** app in the **Deploying** state until fully installed and then the status changes to **Running** when ready to use. + +Click **Web Portal** on the **Application Info** widget to open the Plex web portal sign-in screen. + +{{< trueimage src="/images/SCALE/Apps/PlexAppWebPortalSignInScreen.png" alt="Plex Sign In Screen" id="Plex Sign In Screen" >}} + +After signing in, Plex guides you through several initial media server configuration screens if this is a new account or shows your default Plex media screen for your existing configured account. + +## Understanding App Installation Wizard Settings +The following section provides more detailed explanations of the settings in each section of the **Install** installation wizard. + +### Application Name Settings + +{{< include file="/static/includes/apps/AppsWizardAppNameAndVersion.md" >}} + +### Plex Configuration Settings +Plex configuration settings include setting up the server timezone, authentication to the Plex account, location of the Plex container image, local network settings, and adding devices or additional environment variables to apply to the container. + +{{< trueimage src="/images/SCALE/Apps/InstallPlexConfig1.png" alt="Install Plex Configuration Settings" id="Install Plex Configuration Settings" >}} + +{{< include file="/static/includes/apps/AppsInstallWizardTimezoneSetting.md" >}} + +Authentication to the Plex account is accomplished through a [claim token provided by Plex](https://www.plex.tv/claim/). +While signed into your Plex account, copy the token provided by Plex into the **Claim Token** field. +The Plex app does not deploy if you do not include this token. + +Accept the default value in **Image** to use the container image for the TrueNAS app. + +#### Setting Up Local Network +TrueNAS shows the default IP addresses detected for your system. +If these address fields are not shown in the wizard, your network is considered to be on the external network. + +Either accept the default values or enter the IP addresses for local network connections (Ethernet or WiFi routers) you want in your Plex local network. +These addresses define how Plex interacts with devices and services on your network and can optimize how your Plex media server communicates with devices in your home. + +Specified addresses are considered to be on the local network when enforcing bandwidth restrictions. +If left blank, only the subnet for the server is considered to be on your local network. +When the host network is not enabled, the server subnet is the network for Docker. +Therefore, all connections from other clients are considered to be on the external network. +If set, all other IP addresses are considered to be external to your local network. + +#### Adding Devices in the Container +Plex account settings allow you to add and manage devices, such as a USB TV Tunner or other similar hardware, that connect to your media server, both on the local network you define and remotely from external network connections. +Adding devices in the TrueNAS Plex app passes devices through to your Plex account. +Click **Add** to the right of **Devices** in the **Install Plex** wizard for each device to add. + +{{< trueimage src="/images/SCALE/Apps/InstallPlexConfigAddDevice.png" alt="Install Plex Add Device" id="Install Plex Add Device" >}} + +Enter the name of the device in the **Host Device** and in the **Container Device** fields. For example, device */dev/dvb*. + +#### Adding Environment Variables +{{< include file="/static/includes/apps/AppInstallWizardEnvironVariablesSettings.md" >}} + +Refer to Plex documentation for more information on [environment variables](https://support.plex.tv/articles/201105343-advanced-hidden-server-settings/) they provide to customize your app deployment. + +### User and Group Configuration + +{{< trueimage src="/images/SCALE/Apps/InstallPlexUserAndGroupConfig.png" alt="Plex User and Group Configuration Settings" id="Plex User and Group Configuration Settings" >}} + +{{< include file="/static/includes/apps/AppInstallWizardUserAndGroupConfig.md" >}} + +The run-as user information is found on the Plex app details screen in the **Run-As Content** widget. + +{{< trueimage src="/images/SCALE/Apps/PlexDetailsScreen.png" alt="Plex App Details Screen" id="Plex App Details Screen" >}} + +### Network Configuration +The default web port for Plex is **32400**. + +{{< include file="/static/includes/apps/AppInstallWizardNetworkConfig.md" >}} + +{{< include file="/static/includes/apps/AppsInstallWizardAdvancedDNSSettings.md" >}} + +### Storage Configuration +TrueNAS provides options for data and configuration storage volumes: ixVolumes and host paths. +Logs and transcode data can use these same storage options or you can create directories to hold log and/or transcode data. +Both logs and transcode data are not intended for persistent data storage. + +Logs and transcode data can be stored in the **temporary** directory option that creates a Docker volume in the hidden **ix-apps** dataset. + +Transcode data chunks are streamed to a player and meant to be discarded after use, like notes on a scratchpad. +This makes the **tmpfs** directory option a better choice as it creates a Linux temporary filesystem type in RAM. + +Neither directory storage option provides easy access to stored data, so if you want to store and access log data, create a dataset called **logs**. + +If opting to use datasets for all Plex storage volumes, create datasets to use with the host path option: +* **data** to use as the media data storage volume. +* **config** to use as the Plex app configuration storage volume. +* **logs** if you want to save and have easy access to log data. + +If you group these datasets under a parent dataset named *plex*, configure the [ACL permissions]({{< relref "PermissionsSCALE.md" >}}) for this parent dataset and add an ACE entry for the run-as (root or **0**) or assigned user (**568**). + +You can create the ACL permission using the app installation wizard or using the **Add Dataset** and **Edit ACL** screens. + +{{< include file="/static/includes/apps/InstallAppsStorageConfig.md" >}} + +{{< include file="/static/includes/apps/AppInstallWizardTemporaryAndTmpfsDirectories.md" >}} + +You can also create additional storage volumes inside the containers. +Additional storage options include the same options and the option to set up an SMB share inside the container. +See **Mounting an SMB Share** below for details. + +{{< expand "Creating App Datasets" "v" >}} +To create the Plex app datasets, go to **Datasets**, select the dataset you want to use as the parent dataset, then click **Add Dataset** to [add a dataset]({{< relref "DatasetsScale.md" >}}). +In this example, we create the Plex datasets under the parent dataset **plex**. + +Enter **plex** in **Name**, and select **Apps** as the **Dataset Preset**. +Click **Advanced Options** if you want to make any other setting changes. Click **Save**. +When prompted, select **Return to Pool List** to configure permissions later after adding the other three datasets, or open the ACL editor to edit ACL permissions immediately after adding the dataset. + +Next, select the **plex** dataset, and then click **Add Dataset** to add the first child dataset. +Enter **data** in **Name** and select **Apps** as the **Dataset Preset**. +Click **Advanced Options** if you want to make any other setting changes. Click **Save**. + +Repeat this to add the **config** dataset, and if desired, also create datasets for **logs** if you want to have easy access to and recovery of log files. +Use the option to add a temporary directory on disk or in RAM for transcode data (and logs if not creating a dataset) storage rather than adding datasets. +When finished you should have the **plex** parent dataset with the child datasets under it. Our example paths are: +* */mnt/tank/plex/***data** +* */mnt/tank/plex/***config** +* */mnt/tank/plex/***logs** + +{{< trueimage src="/images/SCALE/Apps/AddPlexAppDatasets.png" alt="Add Plex Dataset Storage" id="Add Plex Dataset Storage" >}} +{{< /expand >}} + +#### ACL and ACE Settings + +{{< include file="/static/includes/apps/AppInstallWizardACLConfiguration.md" >}} + +#### Mounting an SMB Share +TrueNAS **Additional Storage** options include the ability to mount an SMB share inside the container pod. + +{{< include file="/static/includes/apps/AppWizardStorageSMBOption.md" >}} + +### Resource Configuration + +{{< trueimage src="/images/SCALE/Apps/InstallPlexResourcesConfiguration.png" alt="Resources Configuration Settings" id="Resources Configuration Settings" >}} + +{{< include file="/static/includes/apps/AppInstallWizardResourceConfig.md" >}} +{{< include file="/static/includes/apps/AppsInstallWizardGPUPassthrough.md" >}} + +## Troubleshooting Tips +Before editing Plex app settings, first stop the app, and then edit settings. After saving changes, restart the app. + +Refer to the Plex support website and documentation for assistance with your Plex media server issues. + +### App Sticks in Deploying State +You must get a claim token from Plex and add it to the app or Plex does not deploy. If your app is not deploying, try obtaining a fresh claim token from Plex. Stop the Plex app, then edit the TrueNAS Plex app settings to paste the new token into the **Claim Token** field. Save the change. Restart the app. + +If the app still does not start, try clearing your screen cache. This can sometimes prevent showing the app as fully deployed. + +### Plex App NVIDIA GPU Driver Issues +If Plex reports issues with drivers you might have to delete the app and recreate a fresh app container using the same datasets. +Also, check **Apps > Configuration > Settings** to make sure the NVIDIA driver option is selected. + +Search the [TrueNAS forum](https://forums.truenas.com/) for Plex discussion threads for other tips and suggestions. + +### Cannot Access Libraries or Media Files +Check the dataset permissions, and verify the user accessing these files has the correct permissions. +You can edit dataset permissions by using the **Edit** button on the **Permissions** widget on the **Datasets** screen. +Select the dataset, scroll down to the **Permissions** widget, and click **Edit** to open the **Edit ACL** screen. +Check the ACL entries list for the user accessing the files. If not present, click **Add ACL Entry**, select **User**, and then locate the user name on the **User** dropdown list. Assign the level of permissions you want to assign, then save the ACL changes. + +You can also add the user in the Plex app settings. +Click on the Plex app row on the **Installed** application table. Stop the app, then click **Edit**. +Scroll down to the storage volume for **Data**, click **Add** to the right of **ACL Entries**. +Select **Entry is for a USER** as the **ID Type**, enter the user ID number, and then select the level of permission you want to allow. +Save the changes, then restart the app. diff --git a/static/images/SCALE/Apps/AddPlexAppDatasets.png b/static/images/SCALE/Apps/AddPlexAppDatasets.png new file mode 100644 index 0000000000..0cd7fcd9ed Binary files /dev/null and b/static/images/SCALE/Apps/AddPlexAppDatasets.png differ diff --git a/static/images/SCALE/Apps/InstallPlexAddStorageTemporaryDirectorySettings.png b/static/images/SCALE/Apps/InstallPlexAddStorageTemporaryDirectorySettings.png new file mode 100644 index 0000000000..cf2adc1d9c Binary files /dev/null and b/static/images/SCALE/Apps/InstallPlexAddStorageTemporaryDirectorySettings.png differ diff --git a/static/images/SCALE/Apps/InstallPlexAddStorageTmpfsDirectorySetting.png b/static/images/SCALE/Apps/InstallPlexAddStorageTmpfsDirectorySetting.png new file mode 100644 index 0000000000..c10d038915 Binary files /dev/null and b/static/images/SCALE/Apps/InstallPlexAddStorageTmpfsDirectorySetting.png differ diff --git a/static/images/SCALE/Apps/InstallPlexConfig1.png b/static/images/SCALE/Apps/InstallPlexConfig1.png new file mode 100644 index 0000000000..fd56126d64 Binary files /dev/null and b/static/images/SCALE/Apps/InstallPlexConfig1.png differ diff --git a/static/images/SCALE/Apps/InstallPlexConfigAddDevice.png b/static/images/SCALE/Apps/InstallPlexConfigAddDevice.png new file mode 100644 index 0000000000..51e774bef1 Binary files /dev/null and b/static/images/SCALE/Apps/InstallPlexConfigAddDevice.png differ diff --git a/static/images/SCALE/Apps/InstallPlexResourcesConfiguration.png b/static/images/SCALE/Apps/InstallPlexResourcesConfiguration.png new file mode 100644 index 0000000000..409d072523 Binary files /dev/null and b/static/images/SCALE/Apps/InstallPlexResourcesConfiguration.png differ diff --git a/static/images/SCALE/Apps/InstallPlexScreen.png b/static/images/SCALE/Apps/InstallPlexScreen.png new file mode 100644 index 0000000000..afbd2a4263 Binary files /dev/null and b/static/images/SCALE/Apps/InstallPlexScreen.png differ diff --git a/static/images/SCALE/Apps/InstallPlexStorageConfigDataACLandACE.png b/static/images/SCALE/Apps/InstallPlexStorageConfigDataACLandACE.png new file mode 100644 index 0000000000..f92ba74da9 Binary files /dev/null and b/static/images/SCALE/Apps/InstallPlexStorageConfigDataACLandACE.png differ diff --git a/static/images/SCALE/Apps/InstallPlexStorageLogsTemporaryAndTranscodeTmpfsSettings.png b/static/images/SCALE/Apps/InstallPlexStorageLogsTemporaryAndTranscodeTmpfsSettings.png new file mode 100644 index 0000000000..2097cf9c4a Binary files /dev/null and b/static/images/SCALE/Apps/InstallPlexStorageLogsTemporaryAndTranscodeTmpfsSettings.png differ diff --git a/static/images/SCALE/Apps/InstallPlexUserAndGroupConfig.png b/static/images/SCALE/Apps/InstallPlexUserAndGroupConfig.png new file mode 100644 index 0000000000..62297a9b0b Binary files /dev/null and b/static/images/SCALE/Apps/InstallPlexUserAndGroupConfig.png differ diff --git a/static/images/SCALE/Apps/PlexAppWebPortalSignInScreen.png b/static/images/SCALE/Apps/PlexAppWebPortalSignInScreen.png new file mode 100644 index 0000000000..c3d11fc773 Binary files /dev/null and b/static/images/SCALE/Apps/PlexAppWebPortalSignInScreen.png differ diff --git a/static/images/SCALE/Apps/PlexDetailsScreen.png b/static/images/SCALE/Apps/PlexDetailsScreen.png new file mode 100644 index 0000000000..30ba24ef64 Binary files /dev/null and b/static/images/SCALE/Apps/PlexDetailsScreen.png differ diff --git a/static/includes/apps/AppInstallWizardTemporaryAndTmpfsDirectories.md b/static/includes/apps/AppInstallWizardTemporaryAndTmpfsDirectories.md new file mode 100644 index 0000000000..60ace2edcb --- /dev/null +++ b/static/includes/apps/AppInstallWizardTemporaryAndTmpfsDirectories.md @@ -0,0 +1,19 @@ + + +{{< expand "Setting Up Temporary Directory Volumes" "v" >}} +To allow TrueNAS to create temporary directories as storage volumes instead of using datasets, you have two options: set **Type** set to **Temporary (Temporary directory created on the disk)** or **tmpfs (Temporary directory created on the RAM)**. + +The **Temporary** option adds a directory in a Docker container in the hidden **ix-apps** dataset, located on the pool selected as the apps pool. +This directory is cleaned up on every container restart, which means the data no only exists in a current session in the container. + +The **tmpfs** option creates a Linux temporary filesystem type in RAM. + +{{< trueimage src="/images/SCALE/Apps/InstallPlexStorageLogsTemporaryAndTranscodeTmpfsSettings.png" alt="Setting Logs to Temporary and Transcode to tmpfs Direcories" id="Setting Logs to Temporary and Transcode to tmpfs Direcories" >}} + +If you add additional storage volumes and set them up as directories, the **Temporary** option requires entering the mount path for where to place the directory, and **tmpfs** requires setting the size limit for the directory in RAM (in MiB). + +{{< trueimage src="/images/SCALE/Apps/InstallPlexAddStorageTemporaryDirectorySettings.png" alt="Setting Additional to Temporary Directory" id="Setting Additional Storage to Temporary Directory" >}} + +{{< trueimage src="/images/SCALE/Apps/InstallPlexAddStorageTmpfsDirectorySetting.png" alt="Setting Additional Storage to tmpfs Directory" id="Setting Additional Storage to tmpfs Directory" >}} + +{{< /expand >}} \ No newline at end of file diff --git a/static/includes/apps/AppInstallWizardUserAndGroupConfig.md b/static/includes/apps/AppInstallWizardUserAndGroupConfig.md index c1969488d6..873c8de5c3 100644 --- a/static/includes/apps/AppInstallWizardUserAndGroupConfig.md +++ b/static/includes/apps/AppInstallWizardUserAndGroupConfig.md @@ -3,9 +3,10 @@ Some TrueNAS apps have predefined run-as user and group IDs. These assignments vary based on the app train and other variables such as installing but not running as the root user. Default user and group IDs are: -* **473** for apps in the **stable** train. -* **568** for some **community** apps and all apps in the **enterprise** train -* **999** for postgres storage volumes +* **473** for the MinIO stable train app. +* **568** (**apps** user), used in some **community** apps and all apps in the **enterprise** train +* **999** (**netdata** user), used for all postgres storage volumes +* **0** (**root** user). Accept the default user and group ID in the **User and Group Configuration** section or enter the user ID for a new TrueNAS user created to serve as the administrator for this app. diff --git a/static/includes/apps/AppsStableBeforeYouBegin.md b/static/includes/apps/AppsStableBeforeYouBegin.md index a02d4d18a0..7a074ed2f6 100644 --- a/static/includes/apps/AppsStableBeforeYouBegin.md +++ b/static/includes/apps/AppsStableBeforeYouBegin.md @@ -3,16 +3,15 @@ * Set a pool for applications to use if not already assigned. Go to **Apps**. If the pool for apps is not already set, do it when prompted. - - {{< trueimage src="/images/SCALE/Apps/AppsChooseAPoolForApps.png" alt="Choose A Pool for Apps" id="Choose A Pool for Apps" >}} - TrueNAS creates the **ix-apps** (hidden) dataset in the pool set as the application pool. This dataset is internally managed, so you cannot use this as the parent when you create required application datasets. - After setting the pool, the **Installed Applications** screen displays **Apps Service Running** on the top screen banner. + {{< trueimage src="/images/SCALE/Apps/AppsChooseAPoolForApps.png" alt="Choose A Pool for Apps" id="Choose A Pool for Apps" >}} + * (Optional) Create a new TrueNAS user to serve as the administrator for the app. + You can use the default user or add a new user. - When you [create a new user]({{< relref "ManageLocalUsersSCALE.md#creating-user-accounts" >}}) select **Create New Primary Group**, and select the appropriate group in the **Auxiliary Group** for the type of user you want to create. Make note of the UID for the new user to add in the installation wizard. + When you [create a new user]({{< relref "ManageLocalUsersSCALE.md#creating-user-accounts" >}}) select **Create New Primary Group**, and add the appropriate group in the **Auxiliary Group** for the type of user you want to create. Make note of the UID for the new user to add in the installation wizard. * Create the required dataset(s). \ No newline at end of file diff --git a/static/includes/apps/InstallAppsStorageConfig.md b/static/includes/apps/InstallAppsStorageConfig.md index 166285ab7d..5168eb31cd 100644 --- a/static/includes/apps/InstallAppsStorageConfig.md +++ b/static/includes/apps/InstallAppsStorageConfig.md @@ -2,20 +2,21 @@ {{< expand "Setting the Storage Volume Type" "v" >}} To allow TrueNAS to create the storage volume, leave **Type** set to **ixVolume (Dataset created automatically by the system)**. -This adds a storage volume for the application that can be found nested under the hidden **ix-apps** dataset, located on the pool selected as the apps pool. -This is recommended for a test deployment of an app but not for a full app deployment. +This adds a storage volume for the application nested in the hidden **ix-apps** dataset, located on the pool selected as the apps pool. +Using ixVolume is intended for a test deployment of an app but not for a full app deployment, as data does not persist for these volumes after deleting the app where a dataset does. +Datasets make recovering, transferring, and accessing app configuration, user, or other data possible where ixVolumes do not. To use an existing dataset, which is the recommended option, set **Type** to **Host Path (Path that already exists on the system)**. If the install wizard shows a **Mount Path**, either accept the default value or enter the correct mount path. For example, if the dataset name is *data*, enter */data* as the mount path. -If you do not select **Enable ACL**, either enter or browse to the location of the dataset and select it to populate the **Host Path** field. -If you select **Enable ACL** after populating the **Host Path** you have to repeat this step, so we recommend selecting **Enable ACL** first. +Select **Enable ACL** to define ACL permissions and to populate the **Host Path** field by either entering or browsing to and selecting the location of the dataset. +Populating the **Host Path** with the dataset location and then selecting **Enable ACL** clears the values, so we recommend selecting **Enable ACL** before entering the host path. {{< include file="/static/includes/apps/AppInstallWizardACLConfiguration.md" >}} -If the app requires additional datasets, click **Add** to the right of **Additional Storage** to show the storage volume fields. -Repeat the instructions above for each dataset to add. +When the app requires additional datasets, repeat the host path setting for each required dataset. +When adding additional storage volumes inside the container, click **Add** to the right of **Additional Storage** to show the storage volume fields. Click **Add** to show the mount and host path fields for each additional dataset and if creating storage volumes for postgres data and postgres backup. {{< /expand >}} \ No newline at end of file