ad hoc,ad infinitum,ad interim,ad lib(英语中的直接拉丁外来词短语)用法
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ad hoc,ad infinitum,ad interim,ad lib(英语中的直接拉丁外来词短语)用法相关的知识,希望对你有一定的参考价值。
参考技术A 1 ad hoc /ˌæd ˈhɒk/ adj. 特别的;临时;专设 adv.特别地,专门地这是一个英语中的直接拉丁语借词,这是一个短语,本意是“to this,with respect to this,for this (specific perpose)”,ad在拉丁语中表示“to”,
hoc在拉丁语中表示hic(意为this)的中性宾格形式。短语含义为“to this (specific perpose)”。例如:
(1) Every inch of green grass outside the mall had been transformed into ad hoc parking lots. [Dallas Morning News]
商场外的每一寸绿草都变成了临时停车场。
(2) An ad hoc committee voted unanimously Wednesday to recommend the city implement cell phone restrictions in school zones. [Amarillo Globe-News]
一个特设委员会周三一致投票建议该市在学区实施手机限制。
(3) Bagley is the chief transportation planner for Montgomery County and part of an ad hoc mobility task force that sprung up when the bridge closed in October … [Pottstown Mercury]
巴格利是蒙哥马利县的首席交通规划师,也是 10 月份桥梁关闭时涌现的临时机动特遣队的成员。
2. ad infinitum /ˌæd ɪnfɪˈnaɪtəm/ adv. 无限地;永久地;无止境地
同ad hoc一样,也是直接的拉丁语借词,这是一个短语,意为“endlessly,to infinity”。由拉丁词ad(to,unto)+infinitum(infinity)构成,
形容词 infinitus "endless"的中性宾格形式。例如:
(1) On Sunday, President Hugo Chavez won the right to seek reelection ad infinitum. [Los Angeles Times]
周日,乌戈·查韦斯总统赢得了无限期连任的权利。
(2) You go round in a circle ad infinitum; the trick is to make sure each new item fits into a story in your imagination. [Guardian]
你无限循环; 诀窍是确保每个新项目都适合您想象中的故事。
(3) Mistrust, violence, intimidation and psychological abuse will continue, ad infinitum, as West Papuans are pushed further aside. [Sydney Morning Herald]
随着西巴布亚人被进一步推到一边,不信任、暴力、恐吓和心理虐待将无休止地继续下去。
(4) It is almost certain their backers are already planning the next round, in a process that will continue in one form or another ad infinitum. [Wired]
几乎可以肯定,他们的支持者已经在计划下一轮,这个过程将以一种或另一种形式无限期地继续下去。
3. ad interim/æd'intərim/ 拉丁语借词,拉丁语ad(to,unto),interim含义为“time intervening”,“in the meantime, meanwhile”。
adj. 含义为“Temporary”,暂时的,暂时的 。例如:
The ad interim government ended with the inauguration of Sam Houston as president on October 22, 1836.’
临时政府以山姆休斯顿于 1836 年 10 月 22 日就任总统而告终。
adv. 含义为“For an intervening or temporary period of time”,暂时地,暂时地。例如:
Since 15th September 2006 Piet Van Roe is the Managing Director ad interim of the public broadcaster.
自 2006 年 9 月 15 日起,Piet Van Roe 担任公共广播公司的临时董事总经理。
4. ad lib /ˌæd ˈlɪb/ 拉丁语借词,拉丁语ad libitum的缩写,含义为“to (one's) pleasure, as much as one likes”(adv. 没有限制地;即席地),其中,ad含义为“to,unto”,libitum含义为“pleasure”。
Ansible Ad-Hoc命令集
一 Ad-Hoc使用场景
Ad-Hoc更倾向于解决简单、临时性任务。
1.1 Ad-Hoc基础命令
基本语法:
1 ansible <host-pattern> [options]
<host-pattern>:指Inventory中定义的主机或主机组,可以为ip、hostname、Inventory中的group组名等。同时支持具有“.”、“*”或“:”等特殊字符的匹配型字符串。
提示:<>表示该选项为必选,[]表述是该选项中的参数任选其一或多个。
1 [options]: 2 -v,--verbose:输出更详细的执行过程信息,-vvv可得到执行过程所有信息; 3 -i PATH,--inventory=PATH:指定inventory信息,默认/etc/ansible/hosts; 4 -f NUM,--forks=NUM:并发线程数,默认5个线程; 5 --private-key=PRIVATE_KEY_FILE:指定秘钥文件; 6 -m NAME,--module-name=NAME:指定执行使用的模块。
提示:-m指定模块名称, 默认情况下是指command模块, 可以省略不写。
1 -M DIRECTORY,--module-path=DIRECTORY:指定模块存放路径,默认/usr/share/ansible; 2 -a ‘ARGUMENTS‘,--args=‘ARGUMENTS’"模块参数; 3 -k,--ask-pass SSH:认证密码; 4 -K,ask-sudo=pass sudo:用户的密码(--sudo时使用); 5 -o,--one-line:标准输出至一行; 6 -s,--sudo:相当于Linux系统下的sudo命令; 7 -t DIRECTORY,--tree=DIRECTORY:输出信息至DIRECTORY目录下,结果文件以远程主机命名; 8 -T SECONDS,--timeout=SECONDS:指定连接远程主机的最大超时,单位是秒; 9 -B NUM,--background=NUM:后台执行命令,超NUM秒后中止正在执行的任务; 10 -P NUM,--poll=NUM:定期返回后台任务进度; 11 -u USERNAME,--user=USERNAME:指定远程主机以USERNAME运行命令; 12 -U SUDO_USERNAME,--sudo-user=SUDO_USERNAME:使用sudo,相当于Linux系统下的sudo命令; 13 -c CONNECTION,--connection=CONNECTION:指定连接方式,可用选项paramiko(SSH)、ssh、local,local方式常用于crontab和kickstarts; 14 -l SUBSET,--limit=SUBSET:指定运行主机; 15 -l ~REGEX,--limit=~REGEX:指定运行主机(正则); 16 --list-hosts:列出符合条件的主机列表,不执行任何命令。
- 场景1:检查myhost主机组所有主机是否存活.
1 [[email protected] ~]# ansible myhost -f 5 -m ping
解析:
172.24.8.32:表示执行命令的主机;
SUCCESS:表示命令成功执行;
=> {……}:表示详细返回结果;
"changed": false,:表示没有对主机做变更;
"ping": "pong":表示执行ping命令返回结果为pong。
- 场景2:返回myhost组所有主机的hostname,并打印最详细的执行过程到标准输出。
1 [[email protected] ~]# ansible myhost1 -s -m command -a ‘hostname‘ -vvv
解析:
执行过程图如下:
- 场景3:列出myhost组所有主机列表。
1 [[email protected] ~]# ansible myhost --list-hosts
- 场景4:将172.24.8.31服务器以root执行sleep 20,设置最大连接超时为2s,且设置为后台运行模式,执行过程每2s输出一次进度,如5s还未执行完则终止该任务。
1 [[email protected] ~]# time ansible 172.24.8.31 -B 5 -P 2 -T 2 -m command -a ‘sleep 20‘ -u root
1.2 通过Ad-Hoc查看系统设置
- 场景1:批量查看myhost组所有主机的磁盘容量(command模块)。
1 [[email protected] ~]# ansible myhost -a "df -hl"
解析:rc=0表示ResultCode=0,即命令执行成功。
- 场景2:批量查看远程主机内存使用情况(shell模块)。
1 [[email protected] ~]# ansible myhost -m shell -a "free -m"
二 Ansible模块使用
2.1 Ad-Hoc查看模块介绍
ansible-doc
ansible-doc是Ansible模块文档说明,针对每个模块都有详细的用法及应用案例介绍,类似Linux的man。
基本语法:
1 ansible-doc [-l|-F|-s] [options] [-t <plugin type> ] [plugin]
参数:
-v,--version:显示工具版本号;
-h,--help:显示该help说明;
-M MODULE_PATH,--module-path=MODULE_PATH:指定Ansible模块的默认加载目录;
-l,--list:列出所有可用模块;
-s,--snippet:只显示playbook说明的代码段;
示例:
1 [[email protected] ~]# ansible-doc -l #列出支持的模块 2 [[email protected] ~]# ansible-doc yum #查看模块功能说明
- 场景1:安装redhat-lsb并查看服务器系统版本号。
1 [[email protected] ~]# ansible myhost -m yum -a ‘name=redhat-lsb state=present‘ #安装软件
解析:
"changed":true:主机是否有变更,true表示有,false表示没有;
"msg":安装过程信息;
"rc":0,resultcode:结果返回码,非0返回码往往是红色并且错误的返回。
1 [[email protected] ~]# ansible myhost -a ‘lsb_release -a‘
- 场景2:为服务器安装MySQL,并启动,同时设置为开机启动.
1 [[email protected] ~]# ansible myhost -m yum -a ‘name=mariadb,mariadb-server state=present‘ 2 [[email protected] ~]# ansible myhost -m service -a ‘name=mariadb state=started enabled=yes‘
三 Ansible主机、用户与组管理
3.1 主机变更
- 情景1:指定组内特定主机变更。
1 [[email protected] ~]# ansible myhost -m service -a ‘name=ntpd state=started‘ --limit "172.24.8.31"
--limit:通过limit参数限定主机做变更
- 场景2:通过指定具体IP限定主机做变更。
1 [[email protected] ~]# ansible 172.24.8.32 -m command -a "systemctl start ntpd"
- 场景3:指定多台主机做变更。
1 [[email protected] ~]# ansible 172.24.8.31:172.24.8.33 -m command -a "systemctl start ntpd"
解析:使用:指定多台服务器,:非31-33,而是31和33两台主机。
1 [[email protected] ~]# ansible 172.24.8.3* -m command -a "systemctl stop ntpd"
3.2 Linux用户管理模块user
参数
|
必填
|
默认值
|
选项
|
说明
|
append
|
否
|
No
|
Yes/no
|
yes:增量添加group
no:全量变更group,只设置groups指定的group组
|
comment
|
否
|
|
|
用户的描述信息
|
createhome
|
否
|
yes
|
Yes/no
|
yes:添加用户同时创建家目录;
no:添加用户时不创建家目录;
|
force
|
否
|
No
|
Yes/no
|
强制,结合state=absent使用,
相当于userdel --force
|
generate_ssh_key
|
否
|
No
|
Yes/no
|
是否生成秘钥,不会覆盖已有SSH key
|
group
|
否
|
|
|
可选,设定用户的主组
|
groups
|
否
|
|
|
设置用户附属组,用逗号分隔的组;
当groups设定为空,则会移除除主组外其他所有组
|
home
|
否
|
|
|
可选,设定为用户的home目录
|
login_class
|
否
|
|
|
可选,设定FreeBSD/OpenBSD/NetBSD系统的用户
登陆class
|
name
|
是
|
|
|
用户名
|
move_home
|
否
|
No
|
Yes/no
|
若为yes,则会临时迁移家目录到特定目录
|
non_unique
|
否
|
No
|
Yes/no
|
可选,结合-u使用,允许改变用户ID为非唯一值
|
password
|
否
|
|
|
可选,设定用户的密码(加密后的密码)
|
remove
|
否
|
No
|
Yes/no
|
结合state=absent使用,
相当于userdel --remove
|
seuser
|
否
|
可选,设置seuser类型启用SELinux
|
||
shell
|
否
|
|
|
可选,设定用户的shell
|
skeleton
|
否
|
可选,设置用户skel目录,
需和createhome参数结合使用
|
||
ssh_key_bits
|
否
|
2048
|
|
可选,设定SSH key的加密位数
|
ssh_key_comments
|
否
|
$HOSTHOME
|
|
可选,定义SSH key注释信息
|
ssh_key_file
|
否
|
.sha/id_rsa
|
|
可选,定义SSH key文件名
|
ssh_key_passphrase
|
否
|
|
|
设置SSH key密码,若没有提供,则默认不加密
|
ssh_key_type
|
否
|
Rsa
|
|
可选,指定SSH key类型
|
state
|
否
|
Present
|
Present
Absent
|
present:新增用户
absent:删除用户
|
system
|
否
|
No
|
Yes/no
|
创建为系统账号,不会改变已经存在的用户
|
uid
|
否
|
|
|
可选,设定为用户的uid
|
update_password
|
否
|
Always
|
Always
On_create
|
always:只有当用户密码不同才会更新密码
on_create:只为新用户设置密码
|
- 场景1:新增用户
需求描述:为myhost1服务器,新增用户dba,使用BASH Shell,附加组为adm、mysql,家目录为/home/dba。
1 [[email protected] ~]# ansible myhost1 -m user -a "name=dba shell=/bin/bash append=yes groups=adm,mysql home=/home/dba state=present"
- 场景2:修改用户属组
需求描述:修改DBA附加组为mysql(即删除adm属组)。
1 [[email protected] ~]# ansible myhost1 -m user -a "name=dba groups=mysql append=no"
- 场景3:设置用户密码
需求描述:设置dba用户密码为x120952576。
- 步骤一:生成加密后的密码
- 方式一:使用passlib生成密码
1 [[email protected] ~]# pip install passlib #使用pip安装psslib
提示:pip安装参考《001.Pip简介及使用》,passlib对于不同Python版本使用方式略有差异,Python多版本管理参考《Python多环境管理》。
1 [[email protected] ~]# python -c "from passlib.hash import sha512_crypt;import getpass;print (sha512_crypt.encrypt(getpass.getpass()))" #使用Python3.x sha512加密算法加密 2 Password: #输入密码x120952576
提示:sha512加密的密码包括特殊元字符,如 ,在传输至远程服务器可能导致密码被转移异常的问题。
1 [[email protected] ~]# python -c ‘import crypt;print(crypt.crypt("x120952576","dba"))‘ #使用Python3.x 普通加密算法加密
- 使用Python2.x sha512加密算法加密
略
- 使用Python3.x 普通加密算法加密
略
- 方式二:使用mkpasswd生成密码
略
- 步骤二:执行加密操作
1 [[email protected] ~]# ansible myhost1 -m user -a "name=dba password=dbX.h0rUHw3Kc update_password=always"
参考文档:http://blog.51cto.com/hellocjq/2064114
- 场景4:删除用户
需求描述:删除用户dba,并删除其家目录和邮件列表。
1 [[email protected] ~]# ansible myhost1 -m user -a "name=dba remove=yes state=absent"
四 其他模块应用
4.1 Windows用户管理
需求描述:新增用户dba,并设置密码为x123456.
1 [[email protected] ~]# ansible myhost2 -m win_user -a "name=dba passwd=x123456 group=Administrator"
4.2 MySQL应用
需求描述:新增MySQL用户dba,设置登录密码为x123456,对mysql.host表有ALL权限。
1 [[email protected] ~]# ansible myhost1 -m mysql_user -a "login_host=localhost login_password=x120952576 login_user=root name=dba password=x123456 priv=mysql.host:ALL state=present"
提示:mysql_user需要MySQL-python模块,可先安装mysql-devel和MySQL-python组件。