当前位置: 首页 > wzjs >正文

在北京做家教的网站wordpress设置页面加载js

在北京做家教的网站,wordpress设置页面加载js,n127网推广,公司注册资本可以随便填吗修改文件单行内容 ansible.builtin.lineinfile 可以按行修改文件内容,一次修改一行,支持正则表达式。 选项名 类型 默认值 描述 attributesstrnull 设置目标文件的 Linux 文件系统属性(attribute bits),作用类似于…

修改文件单行内容

ansible.builtin.lineinfile 可以按行修改文件内容,一次修改一行,支持正则表达式。

选项名

类型

默认值

描述

attributesstrnull

设置目标文件的 Linux 文件系统属性(attribute bits),作用类似于 chattr 命令。例如:+i 设置为不可变,+a 设置为只能追加写入等。

backrefsboolfalse

使用 regexp 和 line 时,是否启用后向引用替换。(使用正则分组时需要设置为 true)。

backupboolfalse

修改文件前是否创建备份。备份文件将带有时间戳后缀。

createboolfalse

文件不存在时是否创建新文件。

firstmatchboolfalse

如果为 true,当 regexp 匹配多行时,只对第一行执行操作。

groupstrnull

设置文件的属组。

insertafterstrEOF

在匹配到的行之后插入。如果为 EOF,则追加到末尾。

insertbeforestrnull

在匹配到的行之前插入。如果为 BOF,则追加到开头。

linestrnull

要插入或替换的行内容。

moderawnull

设置文件权限(八进制形式,或 preserve 保留现有)。

others

ansible.builtin.file

 模块接受的所有参数在这里也同样有效。

ownerstrnull

设置文件的属主。

pathpath

必需项

,目标文件的完整路径。

regexpstrnull

匹配要替换行的正则表达式。

search_stringstrnull

替代 regexp 的简易字符串匹配(不支持正则)。

selevelstrnull

SELinux context 中的 level。

serolestrnull

SELinux context 中的 role。

setypestrnull

SELinux context 中的 type。

seuserstrnull

SELinux context 中的 user。

statestrpresent

设置为 present 插入或修改行,或 absent 删除匹配行。

unsafe_writesboolfalse

是否禁用临时文件写入机制(兼容某些挂载类型如 NFS)。

validatestrnull

在写入前校验文件内容的命令(如 nginx -t -c %s)。

常用选项:

选项名

类型

默认值

描述

backrefsboolfalse

使用 regexp 和 line 时,是否启用后向引用替换。(使用正则分组时需要设置为 true)。

backupboolfalse

修改文件前是否创建备份。备份文件将带有时间戳后缀。

createboolfalse

文件不存在时是否创建新文件。

ownerstrnull

设置文件的属主。

groupstrnull

设置文件的属组。

insertafterstrEOF

在匹配到的行之后插入。如果为 EOF,则追加到末尾。

insertbeforestrnull

在匹配到的行之前插入。如果为 BOF,则追加到开头。

linestrnull

要插入或替换的行内容。

moderawnull

设置文件权限(八进制形式,或 preserve 保留现有)。

others

ansible.builtin.file

 模块接受的所有参数在这里也同样有效。

pathpath

必需项

,目标文件的完整路径。

regexpstrnull

匹配要替换行的正则表达式。

search_stringstrnull

替代 regexp 的简易字符串匹配(不支持正则)。

statestrpresent

设置为 present 插入或修改行,或 absent 删除匹配行。

validatestrnull

在写入前校验文件内容的命令(如 nginx -t -c %s)。

- name: Ensure SELinux is set to enforcing modeansible.builtin.lineinfile:path: /etc/selinux/configregexp: '^SELINUX='line: SELINUX=enforcing- name: Make sure group wheel is not in the sudoers configurationansible.builtin.lineinfile:path: /etc/sudoersstate: absentregexp: '^%wheel'- name: Replace a localhost entry with our ownansible.builtin.lineinfile:path: /etc/hostsregexp: '^127\.0\.0\.1'line: 127.0.0.1 localhostowner: rootgroup: rootmode: '0644'- name: Ensure the default Apache port is 8080ansible.builtin.lineinfile:path: /etc/httpd/conf/httpd.confregexp: '^Listen 'insertafter: '^#Listen 'line: Listen 8080- name: Add a line to a file if the file does not exist, without passing regexpansible.builtin.lineinfile:path: /tmp/testfileline: 192.168.1.99 foo.lab.net foocreate: yes- name: Ensure the JBoss memory settings are exactly as neededansible.builtin.lineinfile:path: /opt/jboss-as/bin/standalone.confregexp: '^(.*)Xms(\d+)m(.*)$'line: '\1Xms${xms}m\3'backrefs: yes- name: Validate the sudoers file before savingansible.builtin.lineinfile:path: /etc/sudoersstate: presentregexp: '^%ADMIN ALL='line: '%ADMIN ALL=(ALL) NOPASSWD: ALL'validate: /usr/sbin/visudo -cf %s

其他的选项都好理解,一眼就能看出来,insertafter 和 insertbefore 我解释一下,上边有个例子用了 insertafter,可以看到同时也使用了 regexp,加了这个和不加是有区别的,可以看下边的例子。

有个文件,内容如下:

[root@awx-1 ansible]# cat /tmp/test
#test
#test
Listen=80
#test
#test
#test

playbook 内容如下:

---
- name: testhosts: localhosttasks:- name: Lineinfile testansible.builtin.lineinfile:line: "Listen=8080"#regexp: "^Listen="insertafter: "^#Listen="path: /tmp/test

playbook 想实现的是在 #Listen= 后添加 Listen=8080,但是有个特殊情况,文件可能不包含 #Listen=regexp 被我注释了,我们看下没有 regexp 的结果:

[root@awx-1 ansible]# ansible-playbook test.yml
...output omitted...[root@awx-1 ansible]# cat /tmp/test
#test
#test
Listen=80
#test
#test
#test
Listen=8080

可以看到,结果是在最后一行添加了 Listen=8080,恢复 /tmp/test,在演示下加了 regexp 的结果:

[root@awx-1 ansible]# ansible-playbook test.yml
...output omitted...[root@awx-1 ansible]# cat /tmp/test
#test
#test
Listen=8080
#test
#test
#test

可以看到这回是将已有的 Listen=80 修改为 Listen=8080

也就是说 regexp 和 insertafter 或 insertbefore组合使用时,能够保证文件最后只有一个 Listen 存在。

最后做两个测试:

第一个

[root@awx-1 ansible]# cat /tmp/test
#test
#test
Listen=80
#Listen=80
#test
#test
#test
[root@awx-1 ansible]# cat test.yml
---
- name: testhosts: localhosttasks:- name: Lineinfile testansible.builtin.lineinfile:line: "Listen=8080"#regexp: "^Listen="insertafter: "^#Listen="path: /tmp/test
[root@awx-1 ansible]# ansible-playbook test.yml
...output omitted...[root@awx-1 ansible]# cat /tmp/test
#test
#test
Listen=80
#Listen=80
Listen=8080
#test
#test
#test

第二个:

[root@awx-1 ansible]# cat /tmp/test
#test
#test
#test
#test
#test
[root@awx-1 ansible]# cat test.yml
---
- name: testhosts: localhosttasks:- name: Lineinfile testansible.builtin.lineinfile:line: "Listen=8080"regexp: "^Listen="insertbefore: "^#Listen="path: /tmp/test
[root@awx-1 ansible]# ansible-playbook test.yml
...output omitted...[root@awx-1 ansible]# cat /tmp/test
#test
#test
#test
#test
#test
Listen=8080

第二个例子里,我特意使用了 insertbefore 可以看到在没有任何匹配时,只会在文件的最后进行追加。

最后总结下,regexp 跟 insertafter 或 insertbefore 进行匹配时,情况如下:

  • regexp 优先匹配,会修改 regexp 匹配的行

  • regexp 没有匹配到时,按照 insertafter 或 insertbefore 的逻辑进行匹配和修改

  • 都没有匹配到时,在文件的最后一行追加

修改文件多行内容

ansible.builtin.blockinfile 用于修改文件的多行内容。

说是修改,多数时候还是添加新的多行内容,这里强调一点,ansible.builtin.blockinfile 通过标记来查找文件中已添加的多行内容。

参数名

类型

默认值

描述

append_newlineboolfalse

如果插入 block 后,新末行没有换行符,则自动加一行换行,保持标准文本格式

attributesstrnull

用于设置文件的高级属性(extended attributes),如 i(不可变)、a(只能追加)。相当于执行 chattr,仅在支持该功能的文件系统(如 ext4)中有效

backupboolfalse

在修改文件前创建备份。

blockstrnull

要插入的文本块内容(多行字符串)

createboolfalse

如果文件不存在则创建

groupstrnull

设置文件的所属组

insertafterstrEOF

插入内容到匹配行之后,或 EOF 表示文件结尾

insertbeforestrnull

插入内容到匹配行之前,或 BOF 表示文件开头

markerstr# {mark} ANSIBLE MANAGED BLOCK

控制 block 标记的格式,{mark} 会被替换为 BEGIN 或 END

marker_beginstrBEGIN

自定义起始标记,用于替代 {mark}

marker_endstrEND

自定义结束标记,用于替代 {mark}

modestrnull

设置文件权限(如 0644

ownerstrnull

设置文件所有者

pathstrnull

目标文件路径

prepend_newlineboolfalse

是否在 block 前添加换行,防止与上一行粘连

selevelstrnull

SELinux 安全级别

serolestrnull

SELinux 角色

setypestrnull

SELinux 类型

seuserstrnull

SELinux 用户

statestrpresent

是否确保 block 存在或被删除(present/absent

unsafe_writesboolfalse

绕过临时文件机制直接写入文件(有风险)

validatestrnull

应用更改前对文件进行语法验证(如 nginx -t -c %s

常用选项:

参数名

类型

默认值

描述

append_newlineboolfalse

如果插入 block 后,新末行没有换行符,则自动加一行换行,保持标准文本格式

backupboolfalse

在修改文件前创建备份。

blockstrnull

要插入的文本块内容(多行字符串)

createboolfalse

如果文件不存在则创建

groupstrnull

设置文件的所属组

insertafterstrEOF

插入内容到匹配行之后,或 EOF 表示文件结尾

insertbeforestrnull

插入内容到匹配行之前,或 BOF 表示文件开头

markerstr# {mark} ANSIBLE MANAGED BLOCK

控制 block 标记的格式,{mark} 会被替换为 BEGIN 或 END(注意标记里必须含有 {mark} 字段)

marker_beginstrBEGIN

自定义起始标记,用于替代 {mark}

marker_endstrEND

自定义结束标记,用于替代 {mark}

modestrnull

设置文件权限(如 0644

ownerstrnull

设置文件所有者

pathstrnull

目标文件路径

prepend_newlineboolfalse

是否在 block 前添加换行,防止与上一行粘连

statestrpresent

是否确保 block 存在或被删除(present/absent

validatestrnull

应用更改前对文件进行语法验证(如 nginx -t -c %s

- name: Insert/Update "Match User" configuration block in /etc/ssh/sshd_config prepending and appending a new lineansible.builtin.blockinfile:path: /etc/ssh/sshd_configappend_newline: trueprepend_newline: trueblock: |Match User ansible-agentPasswordAuthentication no- name: Insert/Update eth0 configuration stanza in /etc/network/interfaces(it might be better to copy files into /etc/network/interfaces.d/)ansible.builtin.blockinfile:path: /etc/network/interfacesblock: |iface eth0 inet staticaddress 192.0.2.23netmask 255.255.255.0- name: Insert/Update configuration using a local file and validate itansible.builtin.blockinfile:block: "{{ lookup('ansible.builtin.file', './local/sshd_config') }}"path: /etc/ssh/sshd_configbackup: yesvalidate: /usr/sbin/sshd -T -f %s- name: Insert/Update HTML surrounded by custom markers after <body> lineansible.builtin.blockinfile:path: /var/www/html/index.htmlmarker: "<!-- {mark} ANSIBLE MANAGED BLOCK -->"insertafter: "<body>"block: |<h1>Welcome to {{ ansible_hostname }}</h1><p>Last updated on {{ ansible_date_time.iso8601 }}</p>- name: Remove HTML as well as surrounding markersansible.builtin.blockinfile:path: /var/www/html/index.htmlmarker: "<!-- {mark} ANSIBLE MANAGED BLOCK -->"block: ""- name: Add mappings to /etc/hostsansible.builtin.blockinfile:path: /etc/hostsblock: |{{ item.ip }} {{ item.name }}marker: "# {mark} ANSIBLE MANAGED BLOCK {{ item.name }}"loop:- { name: host1, ip: 10.10.1.10 }- { name: host2, ip: 10.10.1.11 }- { name: host3, ip: 10.10.1.12 }

这里举个例子来验证 ansible.builtin.blockinfile 是如何确认文本块的:

[root@awx-1 ansible]# cat /tmp/test
#test
#test
#block test
#test
#test
[root@awx-1 ansible]# cat test.yml
---
- name: testhosts: localhosttasks:- name: Lineinfile testansible.builtin.blockinfile:path: /tmp/testappend_newline: trueprepend_newline: trueblock: |address 192.168.1.1netmask 255.255.255.0gateway 192.168.1.254insertafter: "^#block"marker: "# {mark} block test"marker_begin: "one"marker_end: "two"#state: absent
[root@awx-1 ansible]# ansible-playbook test.yml
...output omitted...[root@awx-1 ansible]# cat /tmp/test
#test
#test
#block test# one block test
address 192.168.1.1netmask 255.255.255.0
gateway 192.168.1.254
# two block test#test
#test[root@awx-1 ansible]# cat test.yml
---
- name: testhosts: localhosttasks:- name: Lineinfile testansible.builtin.blockinfile:path: /tmp/testappend_newline: trueprepend_newline: trueblock: |address 192.168.1.1netmask 255.255.255.0gateway 192.168.1.254insertafter: "^#block"marker: "# {mark} block test"#marker_begin: "one"#marker_end: "two"#state: absent[root@awx-1 ansible]# ansible-playbook test.yml
...output omitted...[root@awx-1 ansible]# cat /tmp/test
#test
#test
#block test# BEGIN block test
address 192.168.1.1netmask 255.255.255.0
gateway 192.168.1.254
# END block test# one block test
address 192.168.1.1netmask 255.255.255.0
gateway 192.168.1.254
# two block test#test
#test

可以看到添加 block 的时候会在 block 的开头和结尾添加一个标记(标记一般是 # 开头,表示注释),通过 marker_begin 和 marker_end 修改标记的之后,会重新添加 block,由此可见 block 的管理依赖标记,所以在添加新的 block 的时候记得保证标记的唯一性。

还有个小问题,append_newline 可以在 block 的末尾添加一个换行符来和旧内容分隔,但是每次删除重新添加时都会多一个换行符:

[root@awx-1 ansible]# cat /tmp/test
#test
#test
#block test
#test
#test
[root@awx-1 ansible]# cat test.yml
---
- name: testhosts: localhosttasks:- name: Lineinfile testansible.builtin.blockinfile:path: /tmp/testappend_newline: trueprepend_newline: trueblock: |address 192.168.1.1netmask 255.255.255.0insertafter: "^#block"#state: absent
[root@awx-1 ansible]# ansible-playbook test.yml
...output omitted...[root@awx-1 ansible]# cat /tmp/test
#test
#test
#block test# BEGIN ANSIBLE MANAGED BLOCK
address 192.168.1.1netmask 255.255.255.0
# END ANSIBLE MANAGED BLOCK#test
#test
[root@awx-1 ansible]# cat test.yml
---
- name: testhosts: localhosttasks:- name: Lineinfile testansible.builtin.blockinfile:path: /tmp/testappend_newline: trueprepend_newline: trueblock: |address 192.168.1.1netmask 255.255.255.0insertafter: "^#block"state: absent
[root@awx-1 ansible]# ansible-playbook test.yml
...output omitted...[root@awx-1 ansible]# cat /tmp/test
#test
#test
#block test#test
#test
[root@awx-1 ansible]# ansible-playbook test.yml
...output omitted...[root@awx-1 ansible]# cat /tmp/test
#test
#test
#block test# BEGIN ANSIBLE MANAGED BLOCK
address 192.168.1.1netmask 255.255.255.0
# END ANSIBLE MANAGED BLOCK#test
#test

文章转载自:

http://wRYmQZJR.kbntL.cn
http://T6Iez9hn.kbntL.cn
http://vmbhdMzU.kbntL.cn
http://D2kuuqex.kbntL.cn
http://xwno2gWG.kbntL.cn
http://aiCSxzIF.kbntL.cn
http://hcsEGjvh.kbntL.cn
http://9rLpAx07.kbntL.cn
http://qjoaTr90.kbntL.cn
http://tEtsCb5t.kbntL.cn
http://xsQmneZS.kbntL.cn
http://orfp481O.kbntL.cn
http://s4ge5SLO.kbntL.cn
http://983VCH7y.kbntL.cn
http://hmxG9PgW.kbntL.cn
http://MsiSicNk.kbntL.cn
http://ZvK6mmFu.kbntL.cn
http://Wtg8StrF.kbntL.cn
http://rOEL8slj.kbntL.cn
http://06hk6keq.kbntL.cn
http://ftE1Zqto.kbntL.cn
http://sqbpDbIH.kbntL.cn
http://p8e3XnDJ.kbntL.cn
http://ojrvWdxE.kbntL.cn
http://zhy5MhkE.kbntL.cn
http://luPleVbM.kbntL.cn
http://ZhKqM0KG.kbntL.cn
http://EXazk2be.kbntL.cn
http://sFub8Lgu.kbntL.cn
http://VzWJmuwh.kbntL.cn
http://www.dtcms.com/wzjs/731978.html

相关文章:

  • Html手机浏览网站变形企业网站建设 ppt
  • 网站开发所遵循的南宁制作网站的公司
  • 核工业西南建设集团有限公司网站网站建设与搜索
  • 网站封装成app可以做热更新济南市公共资源交易中心官网
  • 网站建设 英文学网站开发哪里好
  • 做贷款的网站有哪些网络营销名词解释是什么
  • 专业设计网站有哪些山西响应式网页建设报价
  • 部队内网网站建设方案谷歌手机网页版入口
  • 网站平台多少钱网站开发开源框架
  • 湘西吉首市建设局网站烟台建站模板源码
  • 怎么做动漫网站电影网站建设教程
  • 网站建设的企业目标做网站的公司叫什么名字好
  • 班级网站源代码乐清新闻
  • wordpress退出登录四川成都网站优化
  • 专业的上海网站建设公司哪家好上海市教育网官网
  • 网站制作寻找客户知名企业招聘信息
  • 哈尔滨 做网站iapp源码
  • 连锁加盟网站制作罗湖网站建设报价
  • 东胜区教育网站入口html网页设计大赛
  • 泉州网站建设哪家好微信小程序低代码开发平台
  • 汽贸做网站有用处吗网站建设如何财务处理
  • 无锡自助建网站微商分销如何搭建分销模式
  • 查看邮箱注册过的网站系统总裁
  • 公众号开发合同泉州网络seo
  • 优秀排版设计图片seowhy什么意思
  • 有没有给宝宝做辅食的网站最热门的网络游戏排行
  • 泉州市住房和城乡建设部网站网站搜索排名优化价格
  • 如何做响应式的网站如何构建一个成交型网站
  • 南京市公共建设中心网站建设一个公司网站需要多少钱
  • 微信上做网站怎么做成都建设规划局网站