Subnet reservation: Difference between revisions
mNo edit summary |
|||
Line 80: | Line 80: | ||
See [[Subnet_reservation#Authentication | Authentication]] | See [[Subnet_reservation#Authentication | Authentication]] | ||
=== Getting the g5k-subnet gem === | |||
The gemfile is located on a server in Grid'5000 that is not accessible from outside. The simplest way to install the gem is described in the following. | |||
First, get the gem file inside grid'5000: | |||
{{Term|location=frontend|cmd=<code class="command">gem fetch g5k-subnets --source http://gems;grid5000.fr </code>}} | |||
Then, copy it on your local machine: | |||
{{Term|location=localhost|cmd=<code class="command">scp frontend:g5k-subnets*.gem .</code>}} | |||
Finally, install it: | |||
{{Term|location=localhost|cmd=<code class="command">gem install g5k-subnets*.gem</code>}} | |||
=== Code example === | === Code example === | ||
Line 91: | Line 104: | ||
require 'restfully' # gem install restfully | require 'restfully' # gem install restfully | ||
require 'yaml' | require 'yaml' | ||
require ' | require 'g5k-subnets' | ||
config = YAML.load_file(File.expand_path("~/.restclient"))['grid5000'] | config = YAML.load_file(File.expand_path("~/.restclient"))['grid5000'] | ||
Line 101: | Line 114: | ||
end | end | ||
s = | s = Grid5000::Subnets.new(subnets, {:broadcast => false, :netmask => false, :prefix => true, :ips'=> false, :summarize => true, :gateway => false}) | ||
s.print | s.print | ||
</pre> | </pre> | ||
Line 115: | Line 128: | ||
== From inside Grid'5000 == | == From inside Grid'5000 == | ||
The simplest way to get the list of your allocated subnets is to use the <code class="command"> | The simplest way to get the list of your allocated subnets is to use the <code class="command">g5k-subnets</code> script provided on the head node of the submission. OAR provides a property file ($OAR_RESOURCE_PROPERTIES_FILE) where the resources are described. By default, the script uses this file if no other is specified with the <code>-f</code> option. | ||
<pre class="brush: bash"> | <pre class="brush: bash"> | ||
# | # g5k-subnets | ||
10.8.0.0 | 10.8.0.0 | ||
10.8.8.0 | 10.8.8.0 | ||
Line 126: | Line 139: | ||
<pre class="brush: bash"> | <pre class="brush: bash"> | ||
# | # g5k-subnets -p | ||
10.8.0.0/21 | 10.8.0.0/21 | ||
10.8.8.0/21 | 10.8.8.0/21 | ||
Line 133: | Line 146: | ||
Different other printing options are available (<code>-b</code> to display broadcast address, <code>-n</code> to see the netmask, and <code>-a</code> is equivalent to <code>-bnp</code>): | Different other printing options are available (<code>-b</code> to display broadcast address, <code>-n</code> to see the netmask, and <code>-a</code> is equivalent to <code>-bnp</code>): | ||
<pre class="brush: bash"> | <pre class="brush: bash"> | ||
# | # g5k-subnets -a | ||
10.8.0.0/21 10.11.255.255 255.255.252.0 10.11.255.254 | 10.8.0.0/21 10.11.255.255 255.255.252.0 10.11.255.254 | ||
10.8.8.0/21 10.11.255.255 255.255.252.0 10.11.255.254 | 10.8.8.0/21 10.11.255.255 255.255.252.0 10.11.255.254 | ||
Line 140: | Line 153: | ||
You can also summarize the subnets into a larger one if they are contiguous: | You can also summarize the subnets into a larger one if they are contiguous: | ||
<pre class="brush: bash"> | <pre class="brush: bash"> | ||
# | # g5k-subnets -sp | ||
10.8.0.0/20 | 10.8.0.0/20 | ||
</pre> | </pre> | ||
Line 146: | Line 159: | ||
However, when not contiguous, the networks are not merged. | However, when not contiguous, the networks are not merged. | ||
<pre class="brush: bash"> | <pre class="brush: bash"> | ||
# | # g5k-subnets -p | ||
10.8.0.0/21 | 10.8.0.0/21 | ||
10.8.16.0/21 | 10.8.16.0/21 | ||
# | # g5k-subnets -ps | ||
10.8.0.0/21 | 10.8.0.0/21 | ||
10.8.16.0/21 | 10.8.16.0/21 | ||
Line 157: | Line 170: | ||
<pre class="brush: bash"> | <pre class="brush: bash"> | ||
# | # g5k-subnets -j 123456 -p | ||
10.8.0.0/21 | 10.8.0.0/21 | ||
10.8.16.0/21 | 10.8.16.0/21 |
Revision as of 15:08, 24 March 2011
Problem statement
Users deploying VMs on Grid'5000 need to attribute IP addresses to them. Usually, what is done is that users take IPs from "free to use" IPs as described in Virtual Network Interlink. When several users use this technique, they may both provide the same IPs to their machines, thus creating a conflict.
To overcome this issue, OAR can reserve subnets, enabling scheduling and sharing among users.
Warning | |
---|---|
Using the subnet reservation in OAR, you will NOT get subnet isolation. For this purpose, you must use KaVLAN. The subnets obtained here just correspond to an IP range you can use. |
Available IP ranges
Each site of Grid'5000 is allocated a /14 ip block giving thus a total of 262142 different IPs. Therefore, the maximum range of IPs has to be in this /14 subnet.
The /14 address block available on each site is divided in four /16 blocks as described here. The first three /16 are used for IP reservation through OAR.
Concerning the smallest subnet size, it is a /22, which is equivalent to 1022 hosts per subnet. We do not allow smaller subnets to avoid a scheduling overhead in OAR. Therefore, there are 192 reservable /22 subnets.
Requesting subnets
Using the Grid'5000 API
For an understandable use of the Grid'5000 API, see the API page and the practicals
Authentication
This example using the Grid'5000 API uses the Restfully, a wrapper of REST requests.
If you operate from outside Grid'5000, you need to use your login and password to be able to connect to the API.
echo "grid5000: username: your-grid5000-login password: your-grid5000-password" >> ~/.restclient && chmod 600 ~/.restclient
If you operate from within Grid'5000, the authentication is currently automatically handled for you (since you already had to connect to the frontend via SSH).
Code example
The following code will reserve one /22 subnet and one node.
#!/usr/bin/env ruby require 'rubygems' require 'restfully' # gem install restfully require 'yaml' config = YAML.load_file(File.expand_path("~/.restclient"))['grid5000'] config[:base_uri] = "https://api.grid5000.fr/sid/grid5000/sites/rennes/jobs.json" Restfully::Session.new(config) do |jobs, session| jobs.submit({:resources => "slash_22=1+nodes=1,walltime=00:30:00", :command => "sleep 500"}) end
From inside G5K
Subnet reservation through OAR is similar to normal resource reservation.
To reserve 4 /22 subnets and 2 nodes, just type:
You can of-course have more complex request. To obtain 4 /22 on different /19 subnets, you can type:
Getting your networks
Using the Grid'5000 API
Authentication
See Authentication
Getting the g5k-subnet gem
The gemfile is located on a server in Grid'5000 that is not accessible from outside. The simplest way to install the gem is described in the following.
First, get the gem file inside grid'5000:
frontend :
|
gem fetch g5k-subnets --source http://gems;grid5000.fr |
Then, copy it on your local machine:
Finally, install it:
Code example
See the tutorial to learn to use the API. The following code will get the subnets of a job. Using the Subnet class, we compress the subnets returned by the API (only /21 are returned in the API). You can see different printing options in the cfg definition.
#!/usr/bin/env ruby require 'rubygems' require 'restfully' # gem install restfully require 'yaml' require 'g5k-subnets' config = YAML.load_file(File.expand_path("~/.restclient"))['grid5000'] config[:base_uri] = "https://api.grid5000.fr/sid/grid5000/sites/rennes/jobs/123456789.json" subnets = nil Restfully::Session.new(config) do |job, session| subnets = job['resources_by_type']['subnets'] end s = Grid5000::Subnets.new(subnets, {:broadcast => false, :netmask => false, :prefix => true, :ips'=> false, :summarize => true, :gateway => false}) s.print
If the job requested 3 /21 subnets, running this sample code may print:
#get_g5k_subnets_api.rb 10.8.0.0/20 10.8.32.0/21
From inside Grid'5000
The simplest way to get the list of your allocated subnets is to use the g5k-subnets
script provided on the head node of the submission. OAR provides a property file ($OAR_RESOURCE_PROPERTIES_FILE) where the resources are described. By default, the script uses this file if no other is specified with the -f
option.
# g5k-subnets 10.8.0.0 10.8.8.0
The -p
options prints the CIDR format
# g5k-subnets -p 10.8.0.0/21 10.8.8.0/21
Different other printing options are available (-b
to display broadcast address, -n
to see the netmask, and -a
is equivalent to -bnp
):
# g5k-subnets -a 10.8.0.0/21 10.11.255.255 255.255.252.0 10.11.255.254 10.8.8.0/21 10.11.255.255 255.255.252.0 10.11.255.254
You can also summarize the subnets into a larger one if they are contiguous:
# g5k-subnets -sp 10.8.0.0/20
However, when not contiguous, the networks are not merged.
# g5k-subnets -p 10.8.0.0/21 10.8.16.0/21 # g5k-subnets -ps 10.8.0.0/21 10.8.16.0/21
Another option available is to get the subnets of any job (running or terminated) using the -j
option. This can only be used from a computer where oarstat
is usable. Because it uses oarstat
that will query the OAR database, it is slower than just reading a property file
# g5k-subnets -j 123456 -p 10.8.0.0/21 10.8.16.0/21
Using Grid'5000 gateways
Gateways addresses of each site are given here.
You can also get the gateways addresses using the subnet class:
require 'subnets' s = Subnets.new(['10.8.0.0/21'], {:gateway => true}) puts s.gateway # will print 10.11.255.254
Subnets and properties
Subnets don't have properties themselves.
However, you may need a special kind of node or a particular cluster, you can not use the usual!
# oarsub -I -l slash_22=1+nodes=2 -p "cluster = 'parapluie'" [ADMISSION RULE] Set default walltime to 3600. [ADMISSION RULE] Modify resource description with type constraints Generate a job key... There are not enough resources for your request OAR_JOB_ID=-5 Oarsub failed: please verify your request syntax or ask for support to your admin.
To reach this objective, you must put the property just in from on the type of resource:
# oarsub -I -l slash_22=1+{"cluster='parapluie'"}nodes=2 [ADMISSION RULE] Set default walltime to 3600. [ADMISSION RULE] Modify resource description with type constraints Generate a job key... OAR_JOB_ID=377169 Interactive mode : waiting... Starting...