加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

bash – pathmunge优于grep的优势是什么?

发布时间:2020-12-16 01:34:30 所属栏目:安全 来源:网络整理
导读:目前在bash shell中使用Solaris 10. 在查看脚本时,我注意到设置了pathmunge过程以避免在PATH中重复文件夹路径(它似乎也具有在PATH的开头或结尾添加必要文件夹的功能). 除了能够追加/预先挂起(如果这是错误的术语,请原谅),为什么我们不能简单地做回声${PATH}
目前在bash shell中使用Solaris 10.
在查看脚本时,我注意到设置了pathmunge过程以避免在PATH中重复文件夹路径(它似乎也具有在PATH的开头或结尾添加必要文件夹的功能).

除了能够追加/预先挂起(如果这是错误的术语,请原谅),为什么我们不能简单地做回声${PATH} | grep<文件夹1希望添加> ?

如果我唯一的意图是在PATH中有一个特定的文件夹(而不是真正关心开头或结尾),那么grep会用于此目的吗?

pathmunge使用grep本身. (好吧,egrep,确切地说.)

在Red Hat,CentOS等中,pathmunge在/ etc / profile中定义:

pathmunge () {
        if ! echo $PATH | /bin/egrep -q "(^|:)$1($|:)" ; then
           if [ "$2" = "after" ] ; then
              PATH=$PATH:$1
           else
              PATH=$1:$PATH
           fi
        fi
}

正如您所看到的,它比您的建议略微复杂,但并不多.你的提案不起作用的原因是如果没有分隔符,它将进行部分匹配.

所以,如果我的路径是/usr/local / sbin:/usr/local / bin,则回显${PATH} | grep /usr/local将返回true,即使/usr/local不在我的路径中.所以你需要匹配分隔符.但是如果你grep:/usr/local:你也会失败,因为你永远不会匹配路径中的第一个或最后一个项目,因为$PATH既不以分隔符开始也不以分隔符结束.这就是使用egrep的原因. (^ | :)匹配冒号或行的开头. ($| :)匹配冒号或行尾.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读