liunx运维实战-----3 shell变量的核心基础知识和实践

  • 1定义环境变量并赋值的方法

    1 export 变量名=值

    2 source /etc/profile

    3 echo $变量名

    4 env | grep 变量名

  • 2 环境变量也叫全局变量

  • 3特殊情况:sed和grep没有问题

    因为 awk取用shell变量时 和之前的定义是相反的

    在awk取用shell变量时 我们更好的是先用echo加符号输出变量 然后通过管道给awk

参考代码

root@localhost data\]# echo $ETT oldgirl \[root@localhost data\]# awk 'BEGIN {print $ETT}' 输出为空格 \[root@localhost data\]# awk 'BEGIN {print '$ETT'}' 输出为空格 \[root@localhost data\]# awk 'BEGIN {print "$ETT"}' 输出为本身 KaTeX parse error: Expected 'EOF', got '#' at position 26: ...localhost data\]#̲ awk 'BEGIN {pr...ETT'"}' 输出命令的值 oldgirl \[root@localhost data\]# awk 'BEGIN {print '"$ETT"'}' 输出为空格 * 4 关于自定义普通字符串变量的建议 不带引号: 内容纯数字 简单的连续字符(不带空格) 双引号(弱引用):没有特殊情况,特别是带空格的 单引号(强引用):当变量里的内容需要原样输出时 * 5变量名及变量内容小结 1变量名只能为数字 字母 下划线,只能以字母或下划线开头 2变量名的定义要有一定的规范 并且要见名知意 * 6 shell 定义变量时使用"=" 的知识 "a=1"里等号是赋值的意思 比较变量是否相等 也可以用 "="或 "=="" * 7 补充:Awk 的两个特殊模式 BEGIN 和 END,BEGIN 被放置在没有读取任何数据之前,而 END 被放置在所有的数据读取完成以后执行 体现如下: BEGIN{}: 读入第一行文本之前执行的语句,一般用来初始化操作 {}: 逐行处理 END{}: 处理完最后以行文本后执行,一般用来处理输出结果 \[root@localhost data\]# awk -F : 'BEGIN{i=0}{if($3\<1000){i++}}END{print i}' /etc/passwd 19

相关推荐
shylyly_25 分钟前
Linux->多线程2
java·linux·多线程·线程安全·线程同步·线程互斥·可重入
ManageEngineITSM27 分钟前
云原生环境下的ITSM新趋势:从传统运维到智能化服务管理
大数据·运维·人工智能·云原生·itsm·工单系统
檀越剑指大厂34 分钟前
【Nginx系列】查看 Nginx 的日志
运维·nginx
高能态青1 小时前
网络攻防综合实践3-4
服务器·网络·php
倔强的石头_2 小时前
【Linux指南】Makefile进阶:通用化语法与实战技巧
linux
byte轻骑兵3 小时前
【Linux文件系统】Linux文件系统与设备驱动
linux·运维·服务器
Lethehong5 小时前
在 CentOS 7 上搭建 OpenTenBase 集群:从源码到生产环境的全流程指南
linux·运维·centos·tdsql·opentenbase·腾讯云数据库
Hard but lovely5 小时前
vim的使用
linux·编辑器·vim
yuxb735 小时前
集群与负载均衡:HAProxy 与 Nginx 实践
运维·nginx·负载均衡
知白守黑2676 小时前
KVM虚拟化
linux·运维·架构·centos