skidu 发布的文章

bash整理 - 字符串

整理一下使用bash过程中遇到的字符串相关处理方法

  1. 取长度

    str="abcd"
    expr length $str   # 4
    echo ${#str}       # 4
    expr "$str" : ".*" # 4
  2. 查找子串位置

    str="abc"
    expr index $str "a"  # 1
    expr index $str "b"  # 2
    expr index $str "x"  # 0
    expr index $str ""   # 0
  3. 选取子串

    str="abcdef"
    expr substr "$str" 1 3  # 从第一个位置开始取3个字符, abc
    expr substr "$str" 2 5  # 从第二个位置开始取5个字符, bcdef 
    expr substr "$str" 4 5  # 从第四个位置开始取5个字符, def
     
    echo ${str:2}           # 从第二个位置开始提取字符串, bcdef
    echo ${str:2:3}         # 从第二个位置开始提取3个字符, bcd
    echo ${str:(-6):5}      # 从倒数第二个位置向左提取字符串, abcde
    echo ${str:(-4):3}      # 从倒数第二个位置向左提取6个字符, cde
  4. 截取子串

    str="abbc,def,ghi,abcjkl"
    echo ${str#a*c}     # 输出,def,ghi,abcjkl  一个井号(#) 表示从左边截取掉最短的匹配 (这里把abbc字串去掉)
    echo ${str##a*c}    # 输出jkl,             两个井号(##) 表示从左边截取掉最长的匹配 (这里把abbc,def,ghi,abc字串去掉)
    echo ${str#"a*c"}   # 输出abbc,def,ghi,abcjkl 因为str中没有"a*c"子串
    echo ${str##"a*c"}  # 输出abbc,def,ghi,abcjkl 同理
    echo ${str#*a*c*}   # 空
    echo ${str##*a*c*}  # 空
    echo ${str#d*f)     # 输出abbc,def,ghi,abcjkl, 
    echo ${str#*d*f}    # 输出,ghi,abcjkl   
     
    echo ${str%a*l}     # abbc,def,ghi  一个百分号(%)表示从右边截取最短的匹配 
    echo ${str%%b*l}    # a             两个百分号表示(%%)表示从右边截取最长的匹配
    echo ${str%a*c}     # abbc,def,ghi,abcjkl
  5. 字符串替换

    str="apple, tree, apple tree"
    echo ${str/apple/APPLE}   # 替换第一次出现的apple
    echo ${str//apple/APPLE}  # 替换所有apple
     
    echo ${str/#apple/APPLE}  # 如果字符串str以apple开头,则用APPLE替换它
    echo ${str/%apple/APPLE}  # 如果字符串str以apple结尾,则用APPLE替换它
  6. 比较

    [[ "a.txt" == a* ]]        # 逻辑真 (pattern matching)
    [[ "a.txt" =~ .*\.txt ]]   # 逻辑真 (regex matching)
    [[ "abc" == "abc" ]]       # 逻辑真 (string comparision) 
    [[ "11" < "2" ]]           # 逻辑真 (string comparision), 按ascii值比较
  7. 反转

    #使用rev
    echo "STRING" | rev
    
    # 自定义函数
    A="abcd def ghd;"
    B=$(echo $A | rev)
    echo "first way result= [$B]"
    
    len=$(echo -n $A | wc -c )
    rev=""
    while [ $len -gt 0 ]
    do
        B="$(echo -n $A | cut -b$len)"
        rev="$rev$B"
        len=$(($len-1))
    done
    echo "second way result=[$rev]"
    echo
  8. 某一列求和

    awk '{print $1}' file | awk '{sum+=$1}END{print sum}'

VMware clone之后虚拟机网络修复

因为公司项目需要,最近开始研究自建CA服务相关的东东。为了方便测试,俺翻出了很久没用的虚拟机克隆了一份~

可能的确是因为太久没有折腾它了,克隆完成之后虚拟机怎么也无法联网(NAT模式),几经周折后终于解决,感觉实在有必要记录一下以免将来再次忘记。

执行ifconfig -a,看见自动分配了eth1lo两个好基友,折腾开始

mv /etc/sysconfig/network-scripts/ifcfg-eth0 /etc/sysconfig/network-scripts/ifcfg-eth1
sed -i "s;^DEVICE=.*;DEVICE=eth1;g" /etc/sysconfig/network-scripts/ifcfg-eth1
vim /etc/udev/rules.d/70-persistent-net.rules 
# 会看见有两行SUBSYSTEM的记录
# 删除/注释第一行,将第二行的"NAME"值改为eht1
# 保存退出,重启服务
service network restart

搞定收工

Permission denied (publickey,gssapi-with-mic,password)

在公司给几台机器配置公钥认证后连接报错Permission denied (publickey,gssapi-with-mic,password)

习惯性的只检查了~/.ssh
~/.ssh/authorized_keys
这俩的权限,纠结N久后无果,索性tail了一下日志文件:/var/log/secure
终于发现缘由了
Authentication refused: bad ownership or modes for directory /xxoo
看来还是日志兄靠谱~

国庆将至,盆友们国庆快乐哦~

[转] U盘安装RHEL6.3的准备工作

今天skidu遇到个事,需要使用U盘安装一台RHEL6.3操作系统。。
按照惯例,俺下载好iso并刻录到U盘中,满心欢喜滴去装机了
于是乎就出问题了,分区完成后提示缺少iso 9660神马神马
上网搜索了一会终于搞明白缘由。。下面贴出解决办法:)

[code]
将下载好的iso,如rhel-server-6.0-x86_64-boot.iso刻录到U盘
提取iso文件/isolinux目录中的vmlinuz、initrd.img 到U盘根目录
提取iso文件/images目录中的efidisk.img、install.img 到U盘/images目录
再次复制iso文件到U盘根目录
[/code]

好吧,这下就可以拿着这个U盘安装了:)