Skip to content

Examples and exercises

Yoann Valeri edited this page Mar 15, 2023 · 9 revisions

In this page we will present a tutorial and exercices on how to use Phobos. The content of this page comes from the following PDF made by Guillaume Courrier and Sebastien Gougeaud: Phobos tutorial and exercises.pdf.

Phobos tutorial

This document has been written and tested with Phobos 1.94.1. It assumes that the reader has access to a VM with Phobos installed and QuadstorVTL to manage tapes. Each exercise assumes that the previous ones were done.

Basic commands

Setup

Before we can use Phobos, we need to setup the database. Phobos provides a tool phobos_db for this purpose:

sudo -u postgres phobos_db setup_db

You will be asked to input a password for the database access. This password should match the one in the configuration /etc/phobos.conf. The option connect_string contains the information necessary for the connection to the PostgreSQL database. Make sure that the password matches as well as the host which should be localhost for this tutorial.

Once the database is setup, we can initialize the tables:

sudo phobos_db setup_tables

We can see that everything is setup properly by listing the objects in the database:

phobos object list

Since the database is empty, we should not see any output. If the command fails, the database is not properly setup.

Managing Phobos resources

Before we can write data, we need to have somewhere to write. In Phobos, that somewhere is referred to as a medium. A medium can only be accessed though a device.

Phobos can manage three types of resources (i.e. medium): -[dir] any POSIX filesystem; -[tape] magnetic tapes inside a library; -[rados_pool] a pool of RADOS objects inside a Ceph cluster.

In this tutorial, we will not use RADOS pools since their management is very similar to POSIX directories and require some knowledge of Ceph.

POSIX Directories

The goal now is to write a file in a directory. For that, we want to execute the following command:

phobos put /etc/hosts my_first_object
  • Execute the command above.
  • What error message did you get? Why?
  • What process do you need to start?
  • Does the command above work now?
  • Where can the object be written in the current setup? Try to list all the medium currently available to Phobos.
  • What command allows you to manage POSIX directories? List all the available actions on POSIX directories.
  • In what state should a medium be in order to be written to?
  • Use the appropriate commands to setup a directory named /tmp/archive.
  • Does the put command work now? If not, which option of phobos put should you use to specify where the object should be written?
  • Open Phobos' configuration /etc/phobos.conf. Which option can you modify to write objects on directories by default? Try to put an object without the command line option.
  • Try to list all the information about the object written.
  • Read the content of the object into a file.
  • Given the output of phobos extent list -o all, try to find where the object was written in /tmp/archive. You can compare the content of the file to the original file.
  • Write an object with the metadata foo=bar. How can you list the metadata of this object ? List objects with the metadata foo=bar.

Linear Tapes

We will now do the same thing but on tape. At this point, you should have Phobos properly setup for writing to a directory. You will learn how to setup tapes in this section.

  • What physical element do you need to write data on tape?
  • To what Phobos command do they correspond to? List all the available options for these commands.
  • Using lsscsi, list all the available tape drives and their LTO generation.
  • Using mtx, list all the available drives and tapes
  • Using mtx, load a tape into a drive. Can you load an LTO5 tape into an LTO6 drive? An LTO6 tape into an LTO5 drive?
  • Add a drive to Phobos using the SCSI Tape device path. You can also try with the serial number (see tapeinfo).
  • Add a tape to Phobos compatible with the drive.
  • Try to format the tape. If this didn't work, in which state should the drive be?
  • Can you write an object on the tape now?
  • Check the state of the drive using mtx.
  • Repeat steps 11 and 12 from the previous exercise.
  • What do the fields displayed by phobos drive status mean?
  • Using the commands mtx, lsscsi and tapeinfo, try to find the information given by phobos drive status.
  • Given the output of phobos extent list -o all, where is the object written?
  • Use phobos mput to write several objects in one command line.

Inspecting the state of the database

  • Connect to the Phobos database: psql phobos phobos.
  • List all the tables: \d.
  • Which table contains the path to the data of an object on the medium?
  • How does Phobos know where an object should be accessed?
  • What is the use of the lock table?
  • What devices are stored in the database?
  • What media are stored in the database?
  • List which phobos command lists the content of each table.

If you try now, you will see that it fails because it cannot contact phobosd:

<ERROR> Cannot contact 'phobosd': will abort: Transport endpoint is not connected

This is because, phobos cannot manage the media and devices directly. This needs to be done by a central component: phobosd.

systemctl start phobosd

The daemon should be up and running. Use phobos ping to see if it is able to accept new requests.\

If you try the phobos put command again, it will still not work but for a different reason: No space left on device. This error was sent by the daemon because it currently have no medium on which it can write data. Hence, no space left on device.

So if we want to write data, we need to add a directory to Phobos:

mkdir /tmp/archive
phobos dir add /tmp/archive

Once added, we can see the information inside the database:

phobos dir list -o all
/tmp/archive

Once in the database, we need to format the directory and unlock it:

phobos dir format /tmp/archive
phobos dir unlock /tmp/archive

The phobos put command will now work.

You can read back the data and check if the retrieved file match:

phobos get my_first_object /tmp/out
diff /etc/hosts /tmp/out

We can also see our first object in the database:

phobos object list -o all

Advanced commands

Labelling media

Using /etc/phobos-2-1.conf:

  • Create then add to the database a set of 10 directories such as:
    • they are named *tuto{1..10*};
    • the first two get the tag cache;
    • the last five get the tag archive;
    • the last two also get the tag read-only.
    • Format all the directories and unlock only the directories 1, 3 and 7.
    • Try to launch the following commands, and tell why some of them fail.
phobos put /etc/hosts tuto1
phobos put --tags cache /etc/hosts tuto2
phobos put --tags archive /etc/hosts tuto3
phobos put --tags read-only /etc/hosts tuto4
phobos put --tags archive,read-only /etc/hosts tuto5
  • After unlocking the directory 9, does the fifth command succeed?

Updating labels

Using /etc/phobos-2-2.conf

  • List the available tapes.
  • Update the tapes tags such as:
    • tag old-gen on LTO7 tapes;
    • tag to-format on tapes tagged as corrupted.
    • Check the tags update succeed.

Updating access

Using /etc/phobos-2-3.conf

  • Modify the directory accesses such as:
    • we can write on the directory tagged fast;
    • we can retrieve the object tuto1;
    • we can delete the object tuto2.
  • Remove all the accesses of all directories.

Locating resources

Using /etc/phobos-2-4.conf

  • List the available tapes and directories.
  • For each of them, launch a locate command and tell why the command gives you this result.
  • What will happen if a get command target an object located on the xxxx tape?

Locating objets

Using /etc/phobos-2-4.conf

  • List the objects.
  • For each of them, launch a locate command and tell why the command gives you this result.
  • What will happen if a get command target the object on-distant-dir? The object on-both-tapes?

Updating an object

Using /etc/phobos-2-5.conf

  • List the objects.
  • Update the object to-update by pushing the file /etc/hosts.
  • List the deprecated versions using the option --deprecated to check if the overwritten version still exists.
  • Retrieve the version 1 of the object to-update.

Adding and deleting objets

Using /etc/phobos-2-6.conf

  • Create and add one directory to the Phobos system. Format and unlock it.
  • Add an objet to the system.
  • Delete it using the del command.
  • List the deleted object using the option --deprecated.
  • Cancel the deletion.
  • Check the object is alive using the list command.

Managing objects

Using /etc/phobos-2-6.conf

  • List the objects.
  • Delete the object to-remove.
  • List the deleted/deprecated objects.
  • Cancel the deletion of the objects removed2 and removed3.
  • Why the operation did not work for removed3? % removed3 doit générer une erreur, car existant déjà
  • Retrieve the contents of removed3 and insert it back in the system.

Managing aliases

Using /etc/phobos-2-7.conf

  • Before launching phobosd, open the configuration file and look at the definition of the default alias.
  • Define two new aliases:
  • fast-archive -- 1 replica, using fast tagged tapes;
  • mirror-cache -- 3 replicas, using directories.
  • Add two objects to the Phobos system, one for each alias.
  • Check the alias was well-considered, by listing the extents.
  • Repeat the last two questions with the following parameters, without defining an alias: 2 replicas, on raid tagged directories.
Clone this wiki locally