fab-user
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Fab-user] fabric2 cd with multiple servers


From: Lamont Nelson
Subject: Re: [Fab-user] fabric2 cd with multiple servers
Date: Fri, 13 Oct 2017 02:51:55 -0400

Thanks for the help. I did see the functionality in the invoke project, but it seems this is focused on running commands locally. 

I am trying to figure out the best way to chdir and run commands on a remote server using the Group objects. It seems that right now we need to call cd on each connection object in a group, and then call run on that connection. This works but it seems redundant for such a simple use case --- run a command in a directory on a group of servers. Since I will run complex commands I wanted to avoid the "cd foo && cmd" syntax.

It would be nice if we could specify the current directory (or provide a context) when calling the run method for Group objects. Alternatively, it seems that the execute method will pass in a context object to a @task, but this is not implemented yet.

I haven't tried the command line tool, so maybe I am overlooking something.

Regards, 

Lamont

On Thu, Oct 12, 2017 at 11:21 PM, Ben Abrams <address@hidden> wrote:
Lamont,

It's honestly been a while since I used fabric and have not really stayed up on it so apologies if my research was too hastily done and incorrect. There does seem to be the functionality you are looking for in both fabric 1 and 2 (alpha) though they have some slight differences.

In fabric 1.x it came from here: https://github.com/fabric/fabric/blob/1.14/fabric/context_managers.py like this: https://github.com/fabric/fabric/blob/1.14/fabric/context_managers.py#L20-L21

In fabric 2.x they broke out that into the invoke library here: https://github.com/pyinvoke/invoke/blob/master/invoke/context.py like this: https://github.com/pyinvoke/invoke/blob/master/invoke/context.py#L328-L329

Hope this helps,


On Tue, Oct 10, 2017 at 7:05 PM, Lamont Nelson <address@hidden> wrote:
I'm learning the fabric2 api and wanted to know the best way to run a command with a particular working directory on a set of servers.

The README indicates that there is a 'execute' method on Group, but this doesn't seem to be the case. I was able to get code below to work by calling run on each connection in the group. Is there a more succinct way to do this besides the "cd foo && cmd" method? Or am I overlooking something?

-----
from fabric import ThreadingGroup
g=ThreadingGroup('host1','host2')
g.run('cd /tmp && ls foo')

-- or --

from fabric import ThreadingGroup
g=ThreadingGroup('host1','host2')
for c in g:
    with c.cd('/tmp'):
        c.run('ls foo')
-----

Regards,
Lamont




_______________________________________________
Fab-user mailing list
address@hidden
https://lists.nongnu.org/mailman/listinfo/fab-user




--
Ben Abrams


reply via email to

[Prev in Thread] Current Thread [Next in Thread]