我的编程空间,编程开发者的网络收藏夹
学习永远不晚

集群-基础知识3

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

集群-基础知识3

纠正:报文进入内核空间后,当到达input链时发现是一个集群服务时,则直接发送到postrouting链,不经过forward链。

调度算法:

1、静态方法:

rr:轮询,即依照次序从所有RS中进行挑选

wrr:加权轮询,按照权重在RS中进行轮询

sh:source hashing,源地址哈希,即对来自相同客户端的请求发送至同一RS,这样会破坏负载均衡效果。可以基于cookie实现session绑定。

dh:destination hash,目标地址哈希,将同样的请求发给同一个RS。可以提高缓存命中率。

2、动态方法:

lc:最少连接。(活动连接数*256+非活动连接数),谁的最小就是谁。

wlc:加权最少连接。(活动连接数*256+非活动连接数)/weight,谁的最小就是谁。

sed:最少期望延迟。不再考虑非活动连接。(活动连接数+1)*256/weight,谁的最小就是谁。

nq:最少队列调度,改进的sed算法,也不考虑非活动连接数。无需队列。如果有台realserver的连接数=0就直接分配过去,不需要在进行sed运算。

lblc:基于本地的最少连接。和dh一样,考虑cache的连接数。可能破坏缓存命中率。

lblcr:基于本地的带复制功能的最少连接。如果一台服务器的访问过高,可以将缓存复制给其他服务器前面的缓存服务器,然后由其他服务器提供服务。缓存服务器之间会部分复制缓存。

生产环境中比较理想的是wlc,因为非活动连接可能是无法忽略的。

安装ipvsadm及命令详解:

yum直接安装ipvsadm即可。

grep -i 'vs' /boot/config-2.6.32-504.el6.x86_64   #即可查看ipvsadm的相关算法等信息

主要功能:

1、管理集群服务:
    添加:ipvsadm -A|E -t|u|f service-address [-s scheduler] [-p [timeout]] [-M netmask]
        -t|u|:tcp|udp
            service-address:ip:port
        -f:防火墙标记
            service-address:mark number
        默认使用wlc算法
    修改:同上
    删除:ipvsadm -D -t|u|f service-address
2、管理集群中RS:
    添加:ipvsadm -a|e -t|u|f service-address -r server-address [-g|i|m] [-w weight] [-x upper] [-y lower]
        service-address:先定义的集群服务
        -r server-address:RS地址,在NAT模型中可以使用ip:port来做端口映射
        [-g|i|m]:g,DR模型;i,TUN模型;m,地址伪装NAT模型,默认为DR模型
        -w weight:权重,若集群不指定权重,则此处无意义 
    修改:同上
    删除:ipvsadm -d -t|u|f service-address -r server-address
3、查看
    -L|l:查看
        -n:数字格式显示ip和端口
        --stats:显示统计信息
        --rate:显示速率
        --timeout:显示tcp,tcpfin,udp超时
        --daemon:显示多播等信息
        --sort:排序
        -c:显示连接状态
-Z:清空计数器
-C:清空所有集群服务
保存规则:
    -S > 文件(使用输出重定向)
    或者service ipvsadm save,自动保存至/etc/sysconfig/ipvsadm中
导入规则:
    -R < 文件(使用输入重定向)

实验:

前提:

1、时间得同步。尤其是以后的高可用模型对时间同步要求很严格。

2、改主机名

3、directory(调度器)的两块网卡之间得打开转发功能

blob.png

IP规划如上图

开启网卡转发功能:

blob.png

Directory网络配置(eth0设置为桥接,eth1设置为仅主机模式):

blob.png

RS网络设置

RS1:(网卡设置为仅主机模式)

blob.png

RS2:(网卡设置为仅主机模式)

blob.png

添加集群服务并查看 

blob.png

blob.png

在RS中添加默认网页:

echo “RS1” > /var/www/html/index.html
echo “RS2” > /var/www/html/index.html

再RS中启动httpd服务:service httpd start

查看一下index.html文件:

blob.png(此处未改主机名)

blob.png(此处未改主机名)

在网页中输入192.168.0.20并刷新

blob.png

blob.png

保存规则并查看:

blob.png

blob.png

清空规则并查看:

blob.png

此时已无规则。

导入规则并查看:

blob.png

DR模型:

blob.png

Director配置:(配置DIP,VIP,添加路由)

blob.png

blob.png

RS1配置:

blob.png

(此处未改主机名)

[root@RS1 ~]# echo 1 > /proc/sys/net/ipv4/conf/all/arp_ignore 
[root@RS1 ~]# echo 1 > /proc/sys/net/ipv4/conf/eth0/arp_ignore 
[root@RS1 ~]# echo 2 > /proc/sys/net/ipv4/conf/eth0/arp_announce 
[root@RS1 ~]# echo 2 > /proc/sys/net/ipv4/conf/all/arp_announce

配置vip:

[root@RS1 ~]# ifconfig lo:0 192.168.0.21 broadcast 192.168.0.21 netmask 255.255.255.255 up

添加路由:

[root@RS1 ~]# route add -host 192.168.0.21 dev lo:0

RS2配置:

blob.png

(此处未改主机名)

[root@RS2 ~]# echo 1 > /proc/sys/net/ipv4/conf/all/arp_ignore 
[root@RS2 ~]# echo 1 > /proc/sys/net/ipv4/conf/eth0/arp_ignore 
[root@RS2 ~]# echo 2 > /proc/sys/net/ipv4/conf/eth0/arp_announce 
[root@RS2 ~]# echo 2 > /proc/sys/net/ipv4/conf/all/arp_announce

配置VIP:

[root@RS2 ~]# ifconfig lo:0 192.168.0.21 broadcast 192.168.0.21 netmask 255.255.255.255 up

配置路由:

[root@RS2 ~]# route add -host 192.168.0.21 dev lo:0

Director添加集群服务并查看

blob.png

浏览器查看:

blob.pngblob.png




免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

集群-基础知识3

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

集群-基础知识3

纠正:报文进入内核空间后,当到达input链时发现是一个集群服务时,则直接发送到postrouting链,不经过forward链。调度算法:1、静态方法:rr:轮询,即依照次序从所有RS中进行挑选wrr:加权轮询,按照权重在RS中进行轮询s
2023-01-31

Linux基础知识3

Linux 命令的语法格式COMMAND options arguments 命令可分为:命令、应用程序、脚本文件三类命令按类型分为:内部命令:即集成在系统内核中的命令外部命令:独立的可执行程序,程序名即为命令名区分内部命令或外部命令可使用
2023-01-31

mysql基础知识-3

一、mysql修改用户密码方法:    方法一:mysqladmin -u username -h host -p password 'new_password';    方法二:mysql>set password for 'userna
2023-01-31

(3)Powershell基础知识(一)

上节介绍了Windows自带的Powershell开发工具:命令行行窗体和集成开发环境ISE的启动及一些配置注意事项,具体细节使劲戳Powershell开发工具。这一节介绍Powershell的基础知识,包含以下知识点Powershell的
2023-01-31

34补3-3 rhcs集群基础应用

03rhcs集群基础应用配置luci/ricci(图形界面,重点掌握)配置环境node1:192.168.1.151CentOS6.5node2:192.168.1.152CentOS6.5node3:192.168.1.153CentOS
2023-01-31

VII Python(3)基础知识(if

VII Python(3)基础知识(if、while、for、iterator、generator、文件、pickle) 表达式和语句:常用的表达式操作符:算术运算:+,-,*,/,//截断除法,%,**幂运算逻辑运算:x or y,x a
2023-01-31

java基础知识集锦

来源:Mblogger学生博客 作者: xsl 1 什么是Java、Java2、JDK?JDK后面的1.3、1.4.2版本号又是怎么回事?      答:Java是一种通用的,并发的,强类型的,面向对象的编程语言(摘自Java规范第二版)
2023-06-03

CSharp基础知识3-循环语句

第九课:for循环:1、一到一百的和: class Program    {        static void Main(string[] args)        {            double sum = 0;       
2023-01-31

CCIE学习(3)——基础知识回顾

●以太网标准1)10BASE5:粗同轴电缆传输2)10BASE2:细同轴电缆传输3)10BASE-T:第一个使用双绞线传输的以太网标准4)DIX Ethernet Version 2:原始以太网的第1层和第2层规范5)IEEE 802.3:
2023-01-31

python基础知识(三)set集合

set集合不同元素组成无序集合中元素必须是不可变的类型s={1,2,3,4,5,6}#增加s.add("s")#清空s.clear()#弹出s.pop()#删除指定值,删除元素不存在报错s.remove("s")#删除指定值,删除元素不存在
2023-01-31

python基础知识3(列表和元组)

# 列表(可变数据类型) ## 列表的定义 列表是打了激素的数组,数组只能存储同种类型的数据,而列表像一个仓库,存储不同类型的数据. l = []l = [1]l = [1,(1,2),"hello",[1,2]]  ## 列表的特性 -
2023-01-31

python基础知识小结之集合

集合 特点:集合对象是一组无序排列的可哈希的值:集合成员可以做字典的键,与列表和元组不同,集合无法通过数字进行索引。此外,集合中的元素不能重复。定义set() -> new empty set objectset(iterable) ->
2022-06-04

ADSL知识集合3

本文来自:[url]http://bbs.51cto.com/thread-4623-1-1.html[/url]  ADSL宽带使用过程中常见的一些问题    ADSL(Asymmetrical Digital Subscriber Lo
2023-01-31

python3基础知识

字符串截取:利用下标进行截取py_str = 'python'len(py_str)py_str[:3]py_str + '123''python123'py_str * 3'pythonpythonpython'Str将数字转换成字符串L
2023-01-31

基础知识—3.12

1、二叉树:结点:所有的叶子。叶子结点:最后一层的叶子数。性质1:二叉树第i层上的结点数目最多为 2{i-1} (i≥1)。性质2:深度为k的二叉树至多有2{k}-1个结点(k≥1)。性质3:包含n个结点的二叉树的高度至少为log2 (n+
2023-01-30

MySQL基础知识

1、MySQL查询 union和union all的区别: union和union all都可以将两边的查询结果合并,区别在于union的合并会去掉重复行,并且使用默认的排序规则。而union all返回所有行(包括重复行),且对结果不进行排序。 举例如现在创
MySQL基础知识
2022-01-06

Python 基础知识

只是打印出 hello world 肯定是不够的,是吗?你会希望做得比这还要多——你想要输入一些内容,操纵它,然后从中得到一些输出出来的内容。我们可以在 Python 中通过使用变量与常量来实现这一目标,在本章中我们还会学习其它的一些概念。
2023-01-31

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录