Fabric/Python:AttributeError:'NoneType'对象没有'partition'属性

6 投票
1 回答
6710 浏览
提问于 2025-04-18 08:18

这里有一个在fabric中用来添加用户账户的函数。
~/scripts #fab -l

Python source code

Available commands:

    OS_TYPE
    adduser_createcmd  Create command line for adding user
    adduser_getinfo    Prompts for user input for adding user
    go                 The main launcher for adding user

这些是任务

@task
@runs_once

def go():
    """
    The main launcher for adding user 
    """
    user, uid, comment, group, Group, shell = adduser_getinfo()
    execute(adduser_createcmd(user, uid, comment, group, Group, shell))

@task
@runs_once
def adduser_getinfo ():
    """
    Prompts for user input for adding user 
    """
    with settings(warn_only=True):
        df_user = "test"
        df_uid = "6666"
        df_comment = "Test User"
        df_group = "1936"
        df_Group = "sshusers"
        df_shell = "/bin/bash"

        #read user input or use default values
        user = raw_input ("Enter Username [%s]:" %df_user) or df_user 
        uid = raw_input ("Enter UID # [%s]:" %df_uid) or df_uid
        comment = raw_input ("Enter comments [%s]:" %df_comment) or df_comment
        group = raw_input ("Enter main group [%s]:" %df_group) or df_group 
        Group = raw_input ("Enter supplemental group [%s]:" %df_Group) or df_Group 
        shell = raw_input ("Enter shell [%s]:" %df_shell) or df_shell
            return user, uid, comment, group, Group, shell

@task
def adduser_createcmd (user='', uid='', comment='', group='', Group='', shell=''):
    """
    Create command line for adding user 
    """

    #Linux uses the username for main group, solaris uses companyname
    TYPE = OS_TYPE()
    if TYPE == 'Linux':
            Group = "2222,9999"
            sudo ("useradd -u " + uid + " -c \"" + comment + "\" -G " + Group + " -m " + " -s " + shell + " " + user)
    else:
            env.sudo_prefix = "/usr/local/bin/sudo -S -p '%(sudo_prompt)s' "
            env.shell = "bash --noprofile -l -c "
            Group = "2345,500"
            sudo ("/usr/sbin/useradd -u " + uid + " -c \"" + comment + "\" -g " + group + " -G " + Group + " -m " + " -s " + shell + " " + user)

我刚接触fabric和python,想写一个脚本来在多台机器上添加用户。根据机器的类型,添加用户的命令会有所不同,因为不同的机器有不同的用户组。当我运行这个脚本时,它会在第一个指定的主机上添加用户,然后就出错了。我看到其他回答提到有些东西被设置为none,但我不太确定具体是什么被设置成了none。这是运行时的输出和错误信息。

~/scripts #fab -H ns1,ons2 go
Enter Username [test]:
Enter UID # [6666]:
Enter comments [Test User]:
Enter main group [1936]:
Enter supplemental group [sshusers]:
Enter shell [/bin/bash]:
Traceback (most recent call last):
  File "/usr/lib/python2.6/site-packages/fabric/main.py", line 743, in main
    *args, **kwargs
  File "/usr/lib/python2.6/site-packages/fabric/tasks.py", line 368, in execute    
    multiprocessing
  File "/usr/lib/python2.6/site-packages/fabric/tasks.py", line 264, in _execute
    return task.run(*args, **kwargs)
  File "/usr/lib/python2.6/site-packages/fabric/tasks.py", line 171, in run
    return self.wrapped(*args, **kwargs)
  File "/usr/lib/python2.6/site-packages/fabric/decorators.py", line 139, in decorated
    decorated.return_value = func(*args, **kwargs)
  File "/home/jespenc/scripts/fabfile.py", line 70, in go
    execute(adduser_createcmd(user, uid, comment, group, Group, shell))
  File "/usr/lib/python2.6/site-packages/fabric/tasks.py", line 321, in execute
    task = crawl(task, state.commands)
  File "/usr/lib/python2.6/site-packages/fabric/task_utils.py", line 23, in crawl
    result = _crawl(name, mapping)
  File "/usr/lib/python2.6/site-packages/fabric/task_utils.py", line 14, in _crawl
    key, _, rest = name.partition('.')
AttributeError: 'NoneType' object has no attribute 'partition'
Disconnecting from ns1... done.

我知道我的代码写得很糟糕,只是一些我拼凑起来的东西,用来学习python。

1 个回答

11

你应该把这一行改成:

 execute(adduser_createcmd(user, uid, comment, group, Group, shell))

改成:

 execute(adduser_createcmd, user, uid, comment, group, Group, shell)

第一行的意思是让Python执行一个叫做 adduser_createcmd 的函数,并且给它传入一些参数 (user, uid, comment, group, Group, shell),然后把结果传给 execute 函数。但是,Python无法直接执行 adduser_createcmd,因为这个函数是Fabric任务,应该在远程主机上由Fabric运行时来执行。

第二行则是把函数 adduser_createcmd 和参数 (user, uid, comment, group, Group, shell) 作为参数传给 execute 函数。这样,Fabric运行时会在你指定的远程主机上运行这个 adduser_createcmd 函数,并把参数传过去。

撰写回答