python中的os.path.dirname(__file__)的使用
os.path.dirname(__file__)的作用是返回当前脚本的路径
os.path.dirname(os.path.abspath(__file__)),os.path.abspath(__file__)返回的是.py文件的绝对路径
Python vars() 函数解析
vars() 函数返回对象object的属性和属性值的字典对象。如果没有参数,就打印当前调用位置的属性和属性值 类似 locals()。
python的ConfigParser模块
ConfigParser
模块在python3中修改为configparser,
是一个内置模块,不需要独立安装。这个模块定义了一个ConfigParser类,
创建一个对象使用对象的方法对指定的配置文件做增删改查操作。该类的作用是使用配置文件生效,配置文件的格式和windows的INI文件的格式相同
简单读取配置文件示例
read(filename)
直接读取文件内容get(section, option)
获取section
下具体某一配置项的值(返回的是字符串)sections()
得到所有的section,并以列表的形式返回options(section)
得到该section的所有optionitems(section)
键值对的形式 得到该section的所有optiongetint(section,option)
、cnf.getboolean(section,option)
、getfloat(section,option)
获取整型、布尔型和浮点型的option
的值
get(section, option)
获取section
下具体某一配置项的值(返回的是字符串)
In [6]: cnf.get('mysql', 'db_port')
Out[6]: '3306'
参考:https://www.jianshu.com/p/2f0636e27477
关于python中的“__name__”变量
“__name__”是一个python内建的系统变量,这个系统变量显示了当前模块执行过程中的名称,如果当前程序运行在这个模块中,__name__
的名称就是__main__
如果不是,则为这个模块的名称。
Python 字典(Dictionary) setdefault()方法
Python 字典 setdefault() 函数和 get()方法 类似, 如果键不存在于字典中,将会添加键并将值设为默认值。setdefault() 方法语法:
dict.setdefault(key, default=None) key -- 查找的键值。default -- 键不存在时,设置的默认键值。如果字典中包含有给定键,则返回该键对应的值,否则返回为该键设置的值。
参考;https://www.runoob.com/python/att-dictionary-setdefault.html
python参数传递的*args和**kwargs
*args
的使用
*args
用来表示函数接收可变长度的非关键字参数列表作为函数的输入。
**kwargs
的使用
**kwargs
表示函数接收可变长度的关键字参数字典作为函数的输入。当我们需要函数接收带关键字的参数作为输入的时候,应当使用**kwargs
。
参考:https://www.jianshu.com/p/be92113116c8
Python远程部署利器Fabric详解(参考:http://www.bjhee.com/fabric.html
http://www.fabfile.org/)
Fabric是一个Python的库,它提供了丰富的同SSH交互的接口,可以用来在本地或远程机器上自动化、流水化地执行Shell命令。因此它非常适合用来做应用的远程部署及系统维护。其上手也极其简单,你需要的只是懂得基本的Shell命令。
第一个例子
万事从Hello World开始,我们创建一个”fabfile.py”文件,然后写个hello函数:
1 2 | def hello(): print "Hello Fabric!" |
现在,让我们在”fabfile.py”的目录下执行命令:
$ fab hello
你可以在终端看到”Hello Fabric!”字样。
简单解释下,”fabfile.py”文件中每个函数就是一个任务,任务名即函数名,上例中是”hello”。”fab”命令就是用来执行”fabfile.py”中定义的任务,它必须显式地指定任务名。你可以使用参数”-l”来列出当前”fabfile.py”文件中定义了哪些任务:
$ fab -l
任务可以带参数,比如我们将hello函数改为:
1 2 | def hello(name, value): print "Hello Fabric! %s=%s" % (name,value) |
此时执行hello任务时,就要传入参数值:
$ fab hello:name=Year,value=2016
Fabric的脚本建议写在”fabfile.py”文件中,如果你想换文件名,那就要在”fab”命令中用”-f”指定。比如我们将脚本放在”script.py”中,就要执行:
$ fab -f script.py hello
执行本地命令
“fabric.api”包里的”local()”方法可以用来执行本地Shell命令,比如让我们列出本地”/home/bjhee”目录下的所有文件及目录:
1 2 3 4 | from fabric.api import local
def hello(): local('ls -l /home/bjhee/') |
“local()”方法有一个”capture”参数用来捕获标准输出,比如:
1 2 | def hello(): output = local('echo Hello', capture=True) |
这样,Hello字样不会输出到屏幕上,而是保存在变量output里。”capture”参数的默认值是False。
执行远程命令
Fabric真正强大之处不是在执行本地命令,而是可以方便的执行远程机器上的Shell命令。它通过SSH实现,你需要的是在脚本中配置远程机器地址及登录信息:
1 2 3 4 5 6 7 8 | from fabric.api import run, env
env.hosts = ['example1.com', 'example2.com'] env.user = 'bjhee' env.password = '111111'
def hello(): run('ls -l /home/bjhee/') |
“fabric.api”包里的”run()”方法可以用来执行远程Shell命令。上面的任务会分别到两台服务器”example1.com”和”example2.com”上执行”ls -l /home/bjhee/”命令。这里假设两台服务器的用户名都是”bjhee”,密码都是6个1。你也可以把用户直接写在hosts里,比如:
1 | env.hosts = ['bjhee@example1.com', 'bjhee@example2.com'] |
如果你的”env.hosts”里没有配置某个服务器,但是你又想在这个服务器上执行任务,你可以在命令行中通过”-H”指定远程服务器地址,多个服务器地址用逗号分隔:
$ fab -H bjhee@example3.com,bjhee@example4.com hello
另外,多台机器的任务是串行执行的,关于并行任务的执行我们在之后会介绍。