On Sep 28, 2015, at 8:03 PM, Joseph Wu 
<jos...@mesosphere.io<mailto:jos...@mesosphere.io>> wrote:

Hi Rinaldo,

I'd like to point out a small error in your ACLs.

If you want to specify "ANY", you should set the "type" field.  i.e. For the 
RegisterFramework ACL:
"register_frameworks": [
  {
    "principals": { "values": "mesos-mach5-beta" },
    "roles": { "type": 1 }
  }
]

Thanks — can’t keep my eyes open any more.  This is the response I get to the 
following request.

Invalid RESERVE operation: Cannot reserve resources without a principal.

The example shows -u principal:password in curl which is an auentycation string 
for the browser so I am totally confused on how to provide a principal.   The 
documentation for the framework reserve



curl -i  -d slaveId="$SLAVE_ID" -d @- -X POST http://$MESOS_HOST/master/reserve 
<<HERE
resources=[
{
  "name": "cpus",
     "type": "SCALAR",
     "scalar": { "value": 8 },
     "role": "mach5",
     "reservation": {
       "principal": "mach5"
     }
},
{
"name": "mem",
"type": "SCALAR",
"scalar": { "value": 4096 },
"role": "mach5",
"reservation": {
"principal": "mach5"
}
}
]
<<HERE


The ANY "type" is part of an enumeration, defined here:
https://github.com/apache/mesos/blob/master/include/mesos/authorizer/authorizer.proto#L33-L45

Hope that helps,
~Joseph

On Mon, Sep 28, 2015 at 2:51 PM, DiGiorgio, Mr. Rinaldo S. 
<rdigior...@pace.edu<mailto:rdigior...@pace.edu>> wrote:

On Sep 28, 2015, at 5:27 PM, Marco Massenzio 
<ma...@mesosphere.io<mailto:ma...@mesosphere.io>> wrote:

Hi Rinaldo,

sorry about the trouble you're having in getting this to work!
If I got this one right, the original requirement was...

I have some tasks that need to run on different types of agents.

for that, I think you can use either (or both) of `roles` and `attributes` (see 
the Configuration doc [0] for more info).

If you would like to run a 0.24 Mesos on your Mac for testing, you could use 
the Mesosphere published packages[1] or, if Vagrant is more your thing, feel 
free to "take inspiration" form [2].
Marco,

   Thanks — We  are running 0.23, 0.24 and the current branch as of this 
morning in three mesos environments with linux and mac nodes and working on 
porting Solaris. We have had various issues with building but are past most of 
them. We are making progess on the  Solaris build and there is an issue with 
libsvn-1 as you mentioned with OL7.


Why do we need Dynamic Reservations?

We are also working with the mesos-plugin 0.8 and 0.9 and would like to change 
some of the behaviors of the plugin. One of the changes we want to make and we 
may move this out of the meson-plugin into workflow plugin in jenkins is to be 
able to reserve all the resources we need before we start a series of tasks. 
That is what we want to use dynamic reservations for.  There may be issues with 
the jenkins workflow architecture in that “slaves” have to be requested via 
plugins.  Mesos is new and I am sure it will provide a framework to innovate  
on all the following currently supported scheduling options in LSF.

Fair share, preemptive, backfill and SLA scheduling
High throughput scheduling
Multicluster scheduling
Topology-, resource-, and energy-aware scheduling



I am trying to ask for a reservation and maybe I just don’t understand the 
definitions. I seem to be unsure about what a principal is.  Maybe that is the 
root of my current issue.   Unfortunately I am also a teacher so I notice 
things like I still can’t find a definition of principal on all those web pages.

Thanks for all the links below but Docker is not a good technology for us 
because it has the usual linuxism’s runs best and mostly on Linux. Vagrant has 
the same issues so we will have to put more ports on our list. Docker don’t 
have separation that is equal to the task so we need to match the resources of 
the machine to the size of the task and not share in some circumstances. Our 
apps tend to open lots of ports and use advanced features of the operating 
system that may not be supported in Docker native, but may actually work in 
Docker on a VM. Containers have different definitions of separation.

Rinaldo


Finally, to build on OSX, you'll need to install libsvn-1 as described in [3].

I'm afraid I don't know enough about Dynamic Reservation to really be able to 
help here; but I suspect that, if you run without authentication enabled, it 
will accept any principal (did you try that already? what error did you get?)

Feel free to drop me a line if you're still having trouble.


[0] http://mesos.apache.org/documentation/latest/configuration/
[1] http://mesosphere.com/downloads
[2] https://github.com/massenz/zk-mesos/tree/develop/vagrant
[3] http://mesos.apache.org/gettingstarted/ (see the OSX section; in particular:
`$ brew install autoconf automake libtool subversion maven`)

Marco Massenzio
Distributed Systems Engineer
http://codetrips.com<http://codetrips.com/>

On Mon, Sep 28, 2015 at 1:59 PM, DiGiorgio, Mr. Rinaldo S. 
<rdigior...@pace.edu<mailto:rdigior...@pace.edu>> wrote:

On Sep 21, 2015, at 7:33 PM, Guangya Liu 
<gyliu...@gmail.com<mailto:gyliu...@gmail.com>> wrote:

HI Rinaldo,

I think that you can use dynamic reservation feature to achieve this: You can 
launch your tasks after reservation succeeds.  Actually, all of the dynamic 
reservation feature with endpoint has been finished except ACL part, so you can 
use this feature now if you do not care ACL part.

Thanks,

Hi Guangya,

I have bene trying to get dynamic reservations to work. I downloaded the latest 
from git and created a small environment on OS X 10.10. I am trying to use 
reservations and I am not making much progress.  I tried to get it to work 
without authentication and was unable to. I used the ANY option and it still 
required a principal.  I am unable to configure the master to work without 
authentication.  Do you have some simple configs for starting a master with no 
authentication required so that it can be used to set dynamic reservations.

The output below is for authentication. I tried to authenticate from a slave 
and it failed with a coredump.



I start mesos like this:

mesos-master.sh —ip=nnn,nnn,nnn,nnn --work_dir=/var/lib/mesos --acls=$BASE/acls 
--credentials=$BASE/credentials

bash-3.2# cat attributes/acls
{
  "register_frameworks": [
    {
      "principals": { "type": "mesos-mach5-beta" },
      "roles": { "values": "ANY" }
    }
  ],
  "run_tasks": [
    {
      "principals": { "values": "ANY" },
      "users": { "values": "ANY" }
    }
  ],
  "shutdown_frameworks": [
    {
      "principals": { "values": "mesos-mach5-beta" },
      "framework_principals": { "values": "ANY" }
    }
  ]
}

bash-3.2# cat attributes/credentials
{
  "credentials": [
    {
      "principal": "mesos-mach5-beta",
      "secret": "password"
    }
  ]
}



When I try the following I am told I am not authorized.



Guangya

On Tue, Sep 22, 2015 at 6:32 AM, DiGiorgio, Mr. Rinaldo S. 
<rdigior...@pace.edu<mailto:rdigior...@pace.edu>> wrote:
Hi,

   I have some tasks that need to run on different types of agents. I don’t 
want the tasks to run unless I am going to have all the resources.  Can someone 
suggest how I could accomplish that with mesos.  I read about reservations 
here:  http://mesos.apache.org/documentation/latest/reservation/

   I could iterate over all the resources I need and if I get them proceed.

   Is that the only way to do it?

   Any idea when coming soon will be available?

/reserve (Coming Soon)

Suppose we want to reserve 8 CPUs and 4096 MB of RAM for the ads role on a 
slave with id=<slave_id>. We send an HTTP POST request to the /reserve HTTP 
endpoint like so:


Rinaldo








Reply via email to