Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

Because these two situations need different setup steps, we will describe them independently below. We recommend the first possibility, i.e., running AiiDA on a local system and submitting calculations to PC2 HPC system because a local setup gives you more configuration freedom and also the possibility to, at the same time, submit also to other HPC systems. However, if you donÄt have a suitable local computer we include here also a guide for the second possibility of running AiIDA completely on PC2 HPC systems. If you are unsure what the best way for you is, please contact us at pc2-support@uni-paderborn.de.

The two setups have individual advantages and disadvantages:

...

  1. Set up a PostgreSQL database

    1. Load PostgreSQL module

      Code Block
      module load data/PostgreSQL/16.1-GCCcore-12.3.0
    2. Copy sample configuration

      Code Block
      cp /opt/software/pc2/EB-SW/software/PostgreSQL/16.1-GCCcore-12.3.0$EBROOTPOSTGRESQL/share/postgresql/postgresql.conf.sample postgresql.conf
    3. Change the settings in the config postgresql.conf:

      • port = : choose some random port (>1024, <65536)

      • listen_addresses = 'localhost'

      • unix_socket_directories = '/tmp'

      • unix_socket_permissions = 0700

    4. Create and initialize the data directory. The data directory should be on the parallel file system:

      Code Block
      initdb [path to data directory]
    5. Try to start PostgreSQL:

      Code Block
      postgres -c config_file=postgresql.conf -D [path to data directory]
    6. (while PostgreSQL is running) Create database:

      Code Block
      createdb  -p [port number]
    7. (while PostgreSQL is running) Configure PostgreSQL for AiiDA by running psql -p [port number]

      Code Block
      ALTER ROLE [your user name] WITH PASSWORD '[some random password]';
      CREATE USER aiida WITH PASSWORD '[some random password for user aiida]';
      CREATE DATABASE aiida OWNER aiida ENCODING 'UTF8' LC_COLLATE='en_US.UTF-8' LC_CTYPE='en_US.UTF-8';
      GRANT ALL PRIVILEGES ON DATABASE aiida to aiida;
    8. (while PostgreSQL is running) Test database connection:

      Code Block
      psql -h localhost -d aiida -U aiida -W -p [port number]
  2. Create an AiiDA profile

    Code Block
    verdi profile setup core.psql_dos --profile-name [AiiDA profile name] --set-as-default --email [your mail] --first-name [your first name] --last-name [your last name] --institution "[your Institution]" --no-use-rabbitmq 
    • PostgreSQL engine [postgresql_psycopg2]:

    • PostgreSQL hostname [localhost]:

    • PostgreSQL port [5432]: [port number]

    • PostgreSQL username: aiida

    • PostgreSQL password: [passwort for user aiida chosen above]

    • PostgreSQL database name: aiida

    • File repository URI: A directory on the parallel file system. it needs to start with file:// , i.e., file:///scratch/hpc-prf-[project abbreviation]/...

...

  • When running AiiDA on one of the login nodes: Run the PostgreSQL database in a tmux or screen session on the same login node

  • When running AiiDA on the PC2 Jupyter Hub: Run PostgreSQL database in a tmux or screen session in the console in Jupyter Lab instance

  • When running AiiDA in a long-running compute job: Start PostgreSQL database in the job before AiiDA in the background, i.e.,

    Code Block
    postgres -c config_file=postgresql.conf -D [path to data directory] &

...