Skip to content

clement-parisot/g5k-api

 
 

Repository files navigation

g5kapi

This application is in charge of providing the core APIs for Grid'5000.

The project is hosted at https://github.com/grid5000/g5kapi.

Please send an email to support-staff@lists.grid5000.fr if you cannot access the code, but if you read this, it's normally good…

Installation

The app is packaged for Debian Squeeze. Therefore installation is as follows:

sudo apt-get update
sudo apt-get install g5k-api

In particular, runtime dependencies of the app include ruby1.9.1-full and git-core.

Development

  • This app does not work with ruby 1.8. Therefore you need to have a working installation of ruby 1.9.2+. We recommend using rvm to manage your ruby installations.

  • As with every Rails app, it uses the bundler gem to manage dependencies:

      $ gem install bundler --no-ri --no-rdoc
    

    Note: in the next sections we'll run rake or cap executables. If you're using an old version of bundler and are not using rvm to manage your ruby installations, you will probably need to prefix every executable with bundle exec. E.g. rake -T will become bundle exec rake -T.

  • From the application root, install the application dependencies, mysql2 gem need deb package libmysqlclient-dev, pg gem needs deb package libpq-dev and for nokogiri see Nokogiri:

      $ sudo apt-get install libpq-dev           # needed for the pg gem
      $ bundle install
    
  • [option1 - the hard way - setup the full development environment on your machine]

    Install a MySQL database, and any other dependency that can be required by the API to run, and adapt the configuration files located in config/options/. Look at the puppet recipes that can be found in the puppet/ directory to know more about the software that should be installed to mirror the production servers.

  • [option2 - the easy way - use a Grid'5000 node as your development server]

    If you don't want to install a mysql server and other dependencies on your machine, you can use one of the Capistrano tasks that are bundled with the app to install the full development environment on a Grid'5000 node. If you enter the following command, then you'll have a Grid'5000 node provisioned for you with the right version of the OS and all the software dependencies and port forwarding setup (takes about 5-10 minutes to deploy and configure):

      $ SSH_KEY=~/.ssh/id_rsa_accessg5k HOST=graphene-29.nancy.g5k cap develop
      $ SSH_KEY=~/.ssh/id_rsa_accessg5k HOST=graphene-29.nancy.g5k cap package
      $ SSH_KEY=~/.ssh/id_rsa_accessg5k HOST=graphene-29.nancy.g5k cap install
      $ ssh -L 8000:localhost:8000 graphene-29.nancy.g5k
      $ http://localhost:8000/ui/dashboard
    

    This is the recommended approach, and you can reuse the node for packaging a new release once you've made some changes.

  • [option3 - an easier way - use Vagrant]

      $ vagrant up
      $ vagrant ssh
      $ sudo mysql -u root
    

    And create g5kapi-development and g5kapi-test databases.

    The vagrant provisionning script will attempt to configure the VM's root account to be accessible by ssh. By default, it will copy your authorized_keys, but you can control the keypair used with SSH_KEY=filename_of_private_key

  • Setup the database schema:

      $ rake db:setup RACK_ENV=development
    
  • To run the server, just enter:

      $ ./bin/g5k-api server start -e development
    
  • If you need to be authenticated for some development, use:

      $ HTTP_X_API_USER_CN=dmargery ./bin/g5k-api server start -e development
    

    If you want to develop on the UI, you should probably setup an SSH tunnel between your machine and one of the MySQL server of Grid'5000, so that you can access the current jobs:

      $ ssh -NL 13307:mysql.rennes.grid5000.fr:3306 access.rennes.grid5000.fr
    

That's it. If you're not too familiar with rails 3, have a look at http://guides.rubyonrails.org/.

You can also list the available rake tasks and capistrano tasks to see what's already automated for you:

$ rake -T
$ cap -T

Testing

Assuming you have your development environment setup, the only missing step is to create a test database, and a fake OAR database.

  • Create the test database as follows:

      $ RACK_ENV=test rake db:setup
    
  • Create the fake OAR database as follows:

      $ RACK_ENV=test rake db:oar:setup
    

    or RACK_ENV=test rake db:oar:seed if the OAR database already exists.

  • Launch the tests:

      $ RACK_ENV=test rake # or `bundle exec autotest` if this fails (issue with Rails<3.1 and em_mysql2 adapter with evented code).
    

Packaging

  • Bumping the version number is done as follows (a new changelog entry is automatically generated in debian/changelog):

      $ rake package:bump:patch # or: package:bump:minor, package:bump:major
    
  • Building the .deb package is easy, since we kindly provide a capistrano recipe that will automatically reserve a machine on Grid'5000, deploy a squeeze-based image, upload the latest committed code (HEAD) in the current branch, generate a .deb package, and download the generated package back to your machine, in the pkg/ directory.

    Just execute:

      $ cap package
    

    You can also pass a specific HOST if you wish (in this case it won't reserve a node on Grid'5000):

      $ cap package HOST=...
      $ cap package HOST=griffon-71.nancy.user SSH_KEY=~/.ssh/id_userg5k
    

    With vagrant (copy your ssh public key into the root account of the VM if the automated vagrant provisioning script hasn't (see higher)):

      $ cap package HOST=root@192.168.2.10 NOPROXY=true
      $ cap package USE_VAGRANT=true NOPROXY=true
    

Releasing and Installing and new version

  • Once you've packaged the new version, you must release it to the APT repository hosted on apt.grid5000.fr. There is Capistrano task for this: By default it will release to g5k-api-devel repository hosted by apt.grid5000.fr

      $ REMOTE_USER=g5kadmin cap release
    

    The system does not support different keys for the gateway and the remote node. In this case, the following might work for you

      $ SSH_KEY=~/.ssh/id_rsa_grid5000_g5k NOPROXY=true REMOTE_USER=g5kadmin cap release
    

    Note that you can use the same task to release on a different host (for testing purposes for example), by setting the HOST environment variable to another server (a Grid'5000 node for instance).

    To release to stable API, you will need to set PROD_REPO before running the task

    $ REMOTE_USER=g5kadmin PROD_REPO=true cap release

  • If you released on apt.grid5000.fr, then you are now able to install the new version on any server by launching the following commands:

    puppet-repo $ cap cmd HOST="api-server-devel.[sites]" CMD='sudo apt-get update && sudo apt-get install -y -o Dpkg::Options::="--force-confold" g5k-api'

    A more flexible mechanism can be used base on the script/puppet-repo-custom.rb file

    puppet-repo $ bundle exec cap shell ROLES=devel cap> sudo apt-get update && sudo apt-get install g5k-api -y && sudo puppetd -t

    For this command to work, you should have a look in the script/puppet-repo-custom.rb file, which in my case was dropped into the config/ directory of the puppet-repo repository.

    Then you can check that every server has the correct version running by grepping through the processlist to check the version numbers:

      puppet-repo $ bundle exec cap shell ROLES=devel
      cap> ps aux | grep g5k-api | grep -v grep
      [establishing connection(s) to api-server-devel.bordeaux.grid5000.fr, api-server-devel.grenoble.grid5000.fr, api-server-devel.lille.grid5000.fr, api-server-devel.lyon.grid5000.fr, api-server-devel.luxembourg.grid5000.fr, api-server-devel.nancy.grid5000.fr, api-server-devel.reims.grid5000.fr, api-server-devel.rennes.grid5000.fr, api-server-devel.orsay.grid5000.fr, api-server-devel.sophia.grid5000.fr, api-server-devel.toulouse.grid5000.fr]
       ** [out :: api-server-devel.bordeaux.grid5000.fr] g5k-api  26110  0.3 13.9 246432 72840 ?        Sl   Nov20  14:43 thin server (0.0.0.0:8000) [g5k-api-3.0.16]
       ** [out :: api-server-devel.grenoble.grid5000.fr] g5k-api  18510  0.3  7.5 249072 78620 ?        Sl   Nov18  22:48 thin server (0.0.0.0:8000) [g5k-api-3.0.16]
       ** [out :: api-server-devel.luxembourg.grid5000.fr] g5k-api  13384  0.1 13.6 203396 71184 ?        Sl   Nov22   1:29 thin server (0.0.0.0:8000) [g5k-api-3.0.16]
       ** [out :: api-server-devel.nancy.grid5000.fr] g5k-api  12702  0.3 26.9 312236 69704 ?        Sl   Nov20  17:27 thin server (0.0.0.0:8000) [g5k-api-3.0.16]
       ** [out :: api-server-devel.sophia.grid5000.fr] g5k-api  19366  0.2 16.2 325972 84864 ?        Sl   Nov18  21:03 thin server (0.0.0.0:8000) [g5k-api-3.0.16]
       ** [out :: api-server-devel.rennes.grid5000.fr] g5k-api  19353  0.9  7.2 246492 76220 ?        Sl   05:53   4:38 thin server (0.0.0.0:8000) [g5k-api-3.0.16]
       ** [out :: api-server-devel.lille.grid5000.fr] g5k-api  18563  0.2 35.3 262788 92760 ?        Sl   Nov18  19:43 thin server (0.0.0.0:8000) [g5k-api-3.0.16]
       ** [out :: api-server-devel.orsay.grid5000.fr] g5k-api  30348  0.3 27.4 244552 71028 ?        Sl   Nov22   4:57 thin server (0.0.0.0:8000) [g5k-api-3.0.16]
       ** [out :: api-server-devel.toulouse.grid5000.fr] g5k-api   3825  0.3 32.3 259840 83660 ?        Sl   Nov18  23:54 thin server (0.0.0.0:8000) [g5k-api-3.0.16]
       ** [out :: api-server-devel.reims.grid5000.fr] g5k-api   1749  0.8 31.9 324736 82696 ?        Sl   Nov18  65:08 thin server (0.0.0.0:8000) [g5k-api-3.0.16]
       ** [out :: api-server-devel.lyon.grid5000.fr] g5k-api   9940  0.5 33.9 329864 87796 ?        Sl   Nov18  40:32 thin server (0.0.0.0:8000) [g5k-api-3.0.16]
    

Statistics

  • Generate general statistics:

      $ bundle exec rake stats
    

    Example of output you'll get on the STDOUT:

      +----------------------+-------+-------+---------+---------+-----+-------+
      | Name                 | Lines |   LOC | Classes | Methods | M/C | LOC/M |
      +----------------------+-------+-------+---------+---------+-----+-------+
      | Controllers          |   447 |   352 |      14 |      31 |   2 |     9 |
      | Helpers              |    54 |    26 |       0 |       5 |   0 |     3 |
      | Models               |   351 |   288 |       7 |      25 |   3 |     9 |
      | Libraries            |     3 |     3 |       0 |       0 |   0 |     0 |
      | Model specs          |   340 |   315 |       0 |       0 |   0 |     0 |
      | Controller specs     |   550 |   523 |       0 |       0 |   0 |     0 |
      | Helper specs         |    15 |     3 |       0 |       0 |   0 |     0 |
      +----------------------+-------+-------+---------+---------+-----+-------+
      | Total                |  1760 |  1510 |      21 |      61 |   2 |    22 |
      +----------------------+-------+-------+---------+---------+-----+-------+
        Code LOC: 669     Test LOC: 841     Code to Test Ratio: 1:1.3
    
  • Generate the test coverage:

      $ bundle exec rake test:rcov
      $ open coverage/index.html
    

Maintenance

Kadeploy update process

Since Kadeploy3 uses DRb to communicate with clients, and that a lot of code is shared between the client and server, clients must have the whole kadeploy3 code accessible. So, each time a new version of Kadeploy is released and installed on the Grid5000 sites, you MUST remember to update the kadeploy-common package.

Authors

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Ruby 59.0%
  • JavaScript 23.3%
  • CSS 9.3%
  • HTML 7.4%
  • Other 1.0%