菜鸟学Linux 第084篇笔记 lvs持久连接和awk简单使用




内容总览

lvs持久连接

awk, gawk 简单使用

awk变量

awk操作符

awk 模式和动作 pattern action

awk 数组 array





LVS持久连接

无论使用任何算法,LVS持久都能实现在一定时间内,将来自同一个客户端请求派发至

此前选定的RS。


持久连接模板(内存缓冲区)

每一个客户端 及分配给它的RS的映射关系


在基于ssl,需要用到持久连接

PPC 将来自于同一个客户端对同一个服务的请求,始终定向至此前选定的RS

持久端口连接

ipvsadm -A -t 192.168.11.122:80 -p 300


PCC 将来自于同一个客户端对所有端口的请求,始终定向至此前选定的RS, 

持久客户端连接  (把所有端口全部都定义为集群服务,一律向RS转发)

ipvsadm -A -t 192.168.11.122:0 -p 300


PNMPP 持久防火墙标记连接

作用是将pcc的功能再进行优化,pcc虽然可以持久客户端连接,但是会将所有的

port都会转给real server, 而PNMPP则可以限制其只有某些个端口进行转发


原理, 是使用iptables标记某些端口将这些端口标记为一个数字

  然后ipvsadm -f flag支持接收标记,所以当收到所标记的数值时就会将

  其调度到real server



For example, say we want to create one-hour persistent port affinity between

ports 80 and 443 on VIP 172.16.100.6 for real servers 172.16.100.7 and 172.16.100.8 :

/sbin/iptables -F -t mangle 

/sbin/iptables -A PREROUTING -i eth0 -t mangle -p tcp  -d 172.16.100.6 

--dport 80 -j MARK --set-mark 1 (此为一行命令)

/sbin/iptables -A PREROUTING -i eth0 -t mangle -p tcp  -d 172.16.100.6

--dport 443 -j MARK --set-mark 1 (此为一行命令)

/sbin/ipvsadm -A -f  1 -s rr -p 3600 

/sbin/ipvsadm -a -f  1 -r 172.16.100.7 -m 

/sbin/ipvsadm -a -f  1 -r 172.16.100.8 -m 



配置持久连接

ipvsadm -A|E ... -p timeout

timeout: 持久连接时长,默认300秒,单位是秒



rsync server (inotify+rsync server)  

更新速度比较慢,尤其文件比较大时,再用此种方式不太合适


金山开发的工具 sersync 基于C++开发的

支持并发多线程复制,执行性能非常好

可以接收inotify发来的信息

适用服务器比较多, 需要复制大文件的环境比较适用

    (自行研究并配置使其可工作)







grep  文本过虑器

grep 'pattern' input_file ...


sed 流编辑器 实现对文本编辑

sed 'COMMAND/pattern/' input_file...


awk 报告生成器

格式化以后,显示

nawk

gawk


# awk [options] 'script' file file2, ...

# awk [options] 'PATTERN { action }' file file2 ...




$0 表示一整行

$1, $2, $.... 表示切片的第N个



print 打印其后边所定义的变量或字符

printf 打印其后边所定义的变量或字符(有格式的输出)

printf format, item1,item2..


format格式以%开头,后跟一个字符,如下:

%c character显示字符的ASCII码

%d, %i 十进制整数

%e, %E 科学计数法显示数值

%f  显示浮点数

%g, %G 以科学计数法的格式或浮点数的格式显示数值

%s  显示字符串

%u  无符号整数

%%  显示%自身


修饰符

N 显示宽度(N要替换为数值)

- 左对齐

+ 显示数值符号


如 # awk -F: '{printf "%-15s%i\n",$1,$3}' /etc/passwd




awk变量

记录变量

OFS="#" output Filed Separater,定义输出分隔符为#

FS=":"  定义输入分隔符为:

awk -F: 也可以定义输入分隔符


数据变量

NR  the number of input records, 

awk已经处理过的行数,如果多个文件,行数会累加

FNR 与NR不同的是,FNR是记录已经被处理过的当前文件的行数

NF Number of field, 显示行共有的字段个数,注意数值会随着分隔符不同而变化


自定义变量

定义变量test并打印出该变量

# awk -v test="hello test" 'BEGIN{print test}'

第二种定义变量并打印方式

# awk 'BEGIN{test="hello test";print test}'




awk的操作符:

1.算术操作符:

-x: 负值

+x: 转换为数值;

x^y: 

x**y: 次方

x*y: 乘法

x/y:除法

x+y:

x-y:

x%y:


2.字符串操作符:

只有一个,而且不用写出来,用于实现字符串连接;


3.赋值操作符:

=

+=

-=

*=

/=

%=

^=

**=


++

--

需要注意的是,如果某模式为=号,此时使用/=/可能会有语法错误,应以/[=]/替代;


4.布尔值

awk中,任何非0值或非空字符串都为真,反之就为假;


5.比较操作符:

x < y True if x is less than y. 

x <= y True if x is less than or equal to y. 

x > y True if x is greater than y. 

x >= y True if x is greater than or equal to y. 

x == y True if x is equal to y. 

x != y True if x is not equal to y. 

x ~ y True if the string x matches the regexp denoted by y. 

x !~ y True if the string x does not match the regexp denoted by y. 


subscript in array  True if the array array has an element with 

 the subscript subscript.


6.表达式间的逻辑关系符:

&&

||


7.条件表达式:C语言的语法

selector?if-true-exp:if-false-exp


8.函数调用:

function_name (para1,para2)




awk的模式和action:

awk 'program' input-file1 input-file2 ...

其中的program为:

pattern { action }

pattern { action }

...


一、常见的模式类型:

1、Regexp: 正则表达式,格式为/regular expression/

如: # awk -F: '/^\(/sbin\)/{print $NF}' /etc/passwd


2、expresssion: 表达式,其值非0或为非空字符时满足条件,

如:$1 ~ /oot$/ 或 $1 == "root",用运算符~(匹配)和!~(不匹配)。

# awk -F: '$7~"bash$"{print $1,$7}' /etc/passwd

匹配$7里以bash结尾的行 并显示$1,$7


3、Ranges: 指定的匹配范围,格式为pat1,pat2

# awk -F: '"^r","^m"{print $1,$3,$7}' /etc/passwd

表示匹配从第一个pattern到pattern所匹配到的行 


4、BEGIN/END:特殊模式,仅在awk命令执行前运行一次或结束前运行一次

如# awk -F: '$3<500{printf "%-20s%-5i%-20s\n",$1,$3,$7}BEGIN

{print "User ID Shell"}END{print "this is end of file"}' /etc/passwd

在匹配开始时会打印User ID Shell 结束时会显示this is end of file

(这里仅做测试使用)


5、Empty(空模式):匹配任意输入行;


二、常见的Action

1、Expressions:

2、Control statements

3、Compound statements

4、Input statements

5、Output statements




三、Control Statements 控制语句:

(需要读懂并会写)

3.1 if-else

语法:if (condition) {then-body} else {[ else-body ]}


例子:

awk -F: '{if ($1=="root") print $1, "Admin"; 

else print $1, "Common User"}' /etc/passwd


awk -F: '{if ($1=="root") printf "%-15s: %s\n", $1,"Admin"; 

else printf "%-15s: %s\n", $1, "Common User"}' /etc/passwd


awk -F: -v sum=0 '{if ($3>=500) sum++}END{print sum}' /etc/passwd


3.2 while循环 是对一行的每一个字段做循环

语法: while (condition){statement1; statment2; ...}


awk -F: '{i=1;while (i<=3) {print $i;i++}}' /etc/passwd

awk -F: '{i=1;while (i<=NF) { if (length($i)>=4) {print $i}; i++ }}' /etc/passwd


3.3 do-while

语法: do {statement1, statement2, ...} while (condition)

awk -F: '{i=1;do {print $i;i++}while(i<=3)}' /etc/passwd


3.4 for

语法: for ( variable assignment; condition; iteration process) 

{ statement1, statement2, ...}

awk -F: '{for(i=1;i<=3;i++) print $i}' /etc/passwd

awk -F: '{for(i=1;i<=NF;i++) { if (length($i)>=4) {print $i}}}' /etc/passwd


for循环还可以用来遍历数组元素: 与C相同

语法: for (i in array) {statement1, statement2, ...}

awk -F: '$NF!~/^$/{BASH[$NF]++}END{for(A in BASH)

{printf "%15s:%i\n",A,BASH[A]}}' /etc/passwd


3.5 case (与C相同)

语法:switch (expression) { case VALUE or /REGEXP/: statement1, 

statement2,... default: statement1, ...}


3.6 break 和 continue

常用于循环或case语句中


3.7 next

提前结束对本行文本的处理,并接着处理下一行;

例如,下面的命令将显示其ID号为奇数的用户:


# awk -F: '{if($3%2==0) next;print $1,$3}' /etc/passwd






四、awk中使用数组

4.1数组


array[index-expression]


index-expression可以使用任意字符串;需要注意的是,如果某数据组元素事先不

存在,那么在引用其时,awk会自动创建此元素并初始化为空串;因此,要判断某数

据组中是否存在某元素,需要使用index in array的方式。


要遍历数组中的每一个元素,需要使用如下的特殊结构:

for (var in array) { statement1, ... }

其中,var用于引用数组下标,而不是元素值;


例子:

netstat -ant | awk '/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}'

每出现一被/^tcp/模式匹配到的行,数组S[$NF]就加1,

NF为当前匹配到的行的最后一个字段,此处用其值做为数组S的元素索引;


awk '{counts[$1]++}; END {for(url in counts) print counts[url], url}'

/var/log/httpd/access_log(一行命令)

用法与上一个例子相同,用于统计某日志文件中IP地的访问量


4.2 删除数组变量

从关系数组中删除数组索引需要使用delete命令。使用格式为:


delete  array[index]