Installing Rucio server

Prerequisites

Rucio server runs on Python 2.6, 2.7.

Platforms: Rucio should run on any Unix-like platform.

Python Dependencies

Rucio server needs the following python modules:


# pip==9.0.1                # PyPA recommended tool for installing Python packages
SQLAlchemy==1.1.15          # db backend
alembic==0.9.6              # Lightweight database migration tool for SQLAlchemy
Mako==1.0.7                 # Templating language
python-editor==1.0.3        # Programmatically open an editor, capture the result
flup==1.0.2                 # Needed to deploy web.py in lighthttpd

All Dependencies are automatically installed with pip.

Install via docker

Server and auth :

1 - yum install docker 2 - cat /etc/yum.repos.d/ca.repo [carepo] name=IGTF CA Repository baseurl=http://linuxsoft.cern.ch/mirror/repository.egi.eu/sw/production/cas/1/current/ enabled=1 gpgcheck=1 gpgkey=file:///etc/pki/rpm-gpg/GPG-KEY-EUGridPMA-RPM-3

3 - cat /etc/pki/rpm-gpg/GPG-KEY-EUGridPMA-RPM-3 —–BEGIN PGP PUBLIC KEY BLOCK—– Version: GnuPG v1.2.1 (GNU/Linux)

mQGiBELTiyYRBAD8goP2vWdf46e/stZvzgkBgJIFTMkHqZOpLqlCKTRGf4VHUASh hdaktDtPx44fVO4E3zmugc7FP6xz/Hj3SqrUKt98vzF1EMb3i4UMCOBif+jM6VFS N5N3gDEukNpP2h46LkNPbRPgAEeUmUZy4kTyB9xC/VA7d1sFx6sJZpCHiwCg7DNX bj4Wuk5b+FyyCOg9++xabokEAJwt4+iyDX3uYZrkzh9hOXgrbBiyGrorAz3jOpqM 4L9+OKs5q9UsBwVXs5Zjei/irgxNjHNZCPo/V4f7o2CHxa88rn4GvstftSK6Oeey 8PaV3vdb5C5SRSbRgvxoUOo6eGVBpv8bVpKm//tNkTboHVsEAKQ1rYzx/m89aCZj VCw5A/0c3E0rH4ZCeNg7yvta9ur3U7n/aFhzbU3wFLhcIndrPaufz5Sy/SYhOaS9 RgH36GbsmOq6JskdtSpBLq0768BUmrjcosgWl3REpMAZc4vvtb55WRYsrNSrqmXZ /jHLjQkFHFdObIEcvxl+yIIwUxybMkvdxPZxnpGjF2gg6AoP7rQ5RVVHcmlkUE1B IERpc3RyaWJ1dGlvbiBTaWduaW5nIEtleSAzIDxpbmZvQGV1Z3JpZHBtYS5vcmc+ iFkEExECABkFAkLTiyYECwcDAgMVAgMDFgIBAh4BAheAAAoJEMMtmcg827xx5PQA oON2EH0dqfwNjGr1GlGyt1o5bWkzAJ0Y4QOPWaCIJFABoluX5nifjKWV9w== =qXx1 —–END PGP PUBLIC KEY BLOCK—– 4 - yum install lcg-CA

5 - Generate a host certificate and install it : openssl pkcs12 -in hostCert.p12 -clcerts -nokeys -out /etc/grid-security/hostcert.pem openssl pkcs12 -in hostCert.p12 -nocerts -nodes -out /etc/grid-security/hostkey.pem chmod 0600 /etc/grid-security/hostkey.pem

6 - service docker start

docker run –privileged –name rucio-server -v /etc/hostname:/etc/hostname -v /var/log/httpd:/var/log/httpd -v /etc/grid-security/hostcert.pem:/etc/grid-security/hostcert.pem -v /etc/grid-security/hostkey.pem:/etc/grid-security/hostkey.pem -v /sys/fs/cgroup:/sys/fs/cgroup:ro -v /opt/rucio/etc:/opt/rucio/etc -v /etc/grid-security:/etc/grid-security -v /etc/pki:/etc/pki -d -p 443:443 gitlab-registry.cern.ch/rucio01/rucio/mysql_server

Voila. You have a Rucio server up and running

The following is only needed if you didn’t bootstrap the DB

7 - docker exec -i -t rucio-server /bin/bash Now, you’re inside the container

8 - Put in the config a alembic section into rucio.cfg :

[alembic] cfg = alembic.ini

9 - cat /tmp/alembic.ini

# A generic, single database configuration.

[alembic] # path to migration scripts script_location =/usr/lib/python2.7/site-packages/rucio/db/sqla/migrate_repo sqlalchemy.url = Replace by the DB string here

# Logging configuration [loggers] keys = root,sqlalchemy,alembic

[handlers] keys = console

[formatters] keys = generic

[logger_root] level = WARN handlers = console qualname =

[logger_sqlalchemy] level = WARN handlers = qualname = sqlalchemy.engine

[logger_alembic] level = INFO handlers = qualname = alembic

[handler_console] class = StreamHandler args = (sys.stderr,) level = NOTSET formatter = generic

[formatter_generic] format = %(levelname)-5.5s [%(name)s] %(message)s datefmt = %H:%M:%S

10 - /usr/rucio/tools/bootstrap.py

11 - apachectl restart