免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
123下一页
最近访问板块 发新帖
查看: 6179 | 回复: 21
打印 上一主题 下一主题

小问题 求教 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-07-29 21:46 |只看该作者 |倒序浏览
本帖最后由 alex_linux 于 2011-08-05 16:48 编辑

看了几位给的思路还是没套上去。。
下面是实际需求
2条命令的输出


  1. vgdisplay -v |grep -i "VG Name"

  2. VG Name                     /dev/vg00

  3. VG Name                     /dev/vgarc_oltp

  4. VG Name                     /dev/vgoltp1

  5. VG Name                     /dev/vgoltp2

  6. VG Name                     /dev/vgoltp3

  7. VG Name                     /dev/vgoltp4

  8. VG Name                     /dev/vgoltp5

  9. VG Name                     /dev/vgoltp6
复制代码
还有

  1. #!/bin/sh
  2. #aaa.sh
  3. VG_NAME=$1;

  4. vgdisplay -Fv $VG_NAME | sed -n -e "s/^.*pv_name=\([^:.]*\):.*$/\1/p"
复制代码
执行 得到 vg00 下包含的 pv
/aaa.sh /dev/vg00

/dev/disk/disk3

/dev/disk/disk4
  1.   # ioscan -m dsf
  2. Persistent DSF           Legacy DSF(s)
  3. ========================================
  4. /dev/rdisk/disk91        /dev/rdsk/c26t0d1
  5.                          /dev/rdsk/c22t0d1
  6. /dev/rdisk/disk140       /dev/rdsk/c26t1d7
  7.                          /dev/rdsk/c22t1d7
  8. /dev/rdisk/disk144       /dev/rdsk/c26t2d3
  9.                          /dev/rdsk/c22t2d3
  10. /dev/rdisk/disk148       /dev/rdsk/c26t2d4
  11.                          /dev/rdsk/c22t2d4
复制代码
一个命令得到的 pv name 和第二个命令得到第一列 比较  不属于某个vg就标记available
想得到结果

  1. PV Name                          VG Name            
  2. /dev/disk/disk144                /dev/cpicdwlogvg   
  3. /dev/disk/disk148              /dev/cpicdwlogvg
  4. /dev/disk/disk140             available
  5. /dev/disk/disk91               available
复制代码
帮忙给点思路
排序 以 A那列为准

假设
#命令1得到结果
1        A
2        A
3        B
4        B

# 命令2得到结果

5
6
7
8
1
2
3
4

想要得到结果

1           A
2           A
3           B
4           B
5           C
6            C
7           C
8           C


怎么做?请教了。

论坛徽章:
0
2 [报告]
发表于 2011-07-29 22:27 |只看该作者
本帖最后由 网中淫 于 2011-07-29 22:32 编辑
  1. $ cat a
  2. 1        A
  3. 2        A
  4. 3        B
  5. 4        B
  6. $ cat b
  7. 5
  8. 6
  9. 7
  10. 8
  11. 1
  12. 2
  13. 3
  14. 4
  15. $ awk 'NR==FNR{a[$1]=$0;next}{print ($0 in a)?a[$0]:$0"\tC"}' a b|sort -k2,1
  16. 1        A
  17. 2        A
  18. 3        B
  19. 4        B
  20. 5       C
  21. 6       C
  22. 7       C
  23. 8       C
复制代码

论坛徽章:
0
3 [报告]
发表于 2011-07-29 22:36 |只看该作者
网中淫 发表于 2011-07-29 22:27



    谢谢,周一有环境 测试下。

论坛徽章:
33
ChinaUnix元老
日期:2015-02-02 08:55:39CU十四周年纪念徽章
日期:2019-08-20 08:30:3720周年集字徽章-周	
日期:2020-10-28 14:13:3020周年集字徽章-20	
日期:2020-10-28 14:04:3019周年集字徽章-CU
日期:2019-09-08 23:26:2519周年集字徽章-19
日期:2019-08-27 13:31:262016科比退役纪念章
日期:2022-04-24 14:33:24
4 [报告]
发表于 2011-07-29 22:51 |只看该作者
回复 3# alex_linux


可以用Unix-Center的服务器做测试

论坛徽章:
0
5 [报告]
发表于 2011-07-29 23:05 |只看该作者
回复  alex_linux


可以用Unix-Center的服务器做测试
Shell_HAT 发表于 2011-07-29 22:51



   谢谢,我知道。但还有其他东西一起,不方便

论坛徽章:
3
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:51:162015年亚洲杯之阿曼
日期:2015-04-07 20:00:59
6 [报告]
发表于 2011-07-30 11:28 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
2
射手座
日期:2014-10-10 15:59:4715-16赛季CBA联赛之上海
日期:2016-03-03 10:27:14
7 [报告]
发表于 2011-07-30 11:36 |只看该作者
回复 1# alex_linux
  1. $ awk '!a[$1]++{print NF==1?$0"\t C":$0}' a b
  2. 1        A
  3. 2        A
  4. 3        B
  5. 4        B
  6. 5        C
  7. 6        C
  8. 7        C
  9. 8        C
复制代码

论坛徽章:
0
8 [报告]
发表于 2011-07-30 15:44 |只看该作者
回复 7# yinyuemi


    牛!

论坛徽章:
0
9 [报告]
发表于 2011-08-02 23:11 |只看该作者
自己问了下,又套了。还是不行,再请教了

论坛徽章:
2
射手座
日期:2014-10-10 15:59:4715-16赛季CBA联赛之上海
日期:2016-03-03 10:27:14
10 [报告]
发表于 2011-08-03 00:10 |只看该作者
回复 1# alex_linux
  1. $ awk 'NR==FNR{if(/^VG Name/)v=$3;if(/PV Name/)a[$3];next}FNR>2&&NF>1{t=gensub("rdisk","disk",1,$1);print t in a?t"\t\t"v:t"\t\tavailable"|"sort -k2"}' <(vgdisplay -v) <(ioscan -m dsf)
  2. /dev/disk/disk144               /dev/cpicdwlogvg
  3. /dev/disk/disk148               /dev/cpicdwlogvg
  4. /dev/disk/disk140               available
  5. /dev/disk/disk91                available
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP