返回顶部
首页 > 资讯 > 后端开发 > Python >集群-基础知识3
  • 944
分享到

集群-基础知识3

集群基础知识 2023-01-31 01:01:12 944人浏览 八月长安

Python 官方文档:入门教程 => 点击学习

摘要

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

纠正:报文进入内核空间后,当到达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




--结束END--

本文标题: 集群-基础知识3

本文链接: https://lsjlt.com/news/183426.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 集群-基础知识3
    纠正:报文进入内核空间后,当到达input链时发现是一个集群服务时,则直接发送到postrouting链,不经过forward链。调度算法:1、静态方法:rr:轮询,即依照次序从所有RS中进行挑选wrr:加权轮询,按照权重在RS中进行轮询s...
    99+
    2023-01-31
    集群 基础知识
  • mongodb 集群基础知识
    http://blog.csdn.net/luonanqin/article/details/8497860  Mongodb集群搭建的三种方式NoSQL = Not Only SQL  ...
    99+
    2024-04-02
  • mysql基础知识-3
    一、mysql修改用户密码方法:    方法一:mysqladmin -u username -h host -p password 'new_password';    方法二:mysql>set password for 'use...
    99+
    2023-01-31
    基础知识 mysql
  • Linux基础知识3
     Linux 命令的语法格式COMMAND options arguments 命令可分为:命令、应用程序、脚本文件三类命令按类型分为:内部命令:即集成在系统内核中的命令外部命令:独立的可执行程序,程序名即为命令名区分内部命令或外部命令可使...
    99+
    2023-01-31
    基础知识 Linux
  • (3)Powershell基础知识(一)
    上节介绍了Windows自带的Powershell开发工具:命令行行窗体和集成开发环境ISE的启动及一些配置注意事项,具体细节使劲戳Powershell开发工具。这一节介绍Powershell的基础知识,包含以下知识点Powershell的...
    99+
    2023-01-31
    基础知识 Powershell
  • VII Python(3)基础知识(if
    VII Python(3)基础知识(if、while、for、iterator、generator、文件、pickle) 表达式和语句:常用的表达式操作符:算术运算:+,-,*,/,//截断除法,%,**幂运算逻辑运算:x or y,x a...
    99+
    2023-01-31
    基础知识 VII Python
  • 34补3-3 rhcs集群基础应用
    03rhcs集群基础应用配置luci/ricci(图形界面,重点掌握)配置环境node1:192.168.1.151CentOS6.5node2:192.168.1.152CentOS6.5node3:192.168.1.153CentOS...
    99+
    2023-01-31
    集群 基础 rhcs
  • java基础知识集锦
    来源:Mblogger学生博客 作者: xsl 1 什么是Java、Java2、JDK?JDK后面的1.3、1.4.2版本号又是怎么回事?      答:Java是一种通用的,并发的,强类型的,面向对象的编程语言(摘自Java规范第二版) ...
    99+
    2023-06-03
  • CSharp基础知识3-循环语句
    第九课: for循环: 1、一到一百的和:  class Program     {         static void Main(string[] args)        ...
    99+
    2023-01-31
    语句 基础知识 CSharp
  • CCIE学习(3)——基础知识回顾
    ●以太网标准 1)10BASE5:粗同轴电缆传输 2)10BASE2:细同轴电缆传输 3)10BASE-T:第一个使用双绞线传输的以太网标准 4)DIX Ethernet Version 2:原始以太...
    99+
    2023-01-31
    基础知识 CCIE
  • python基础知识(三)set集合
    set集合不同元素组成无序集合中元素必须是不可变的类型s={1,2,3,4,5,6} #增加 s.add("s") #清空 s.clear() #弹出 s.pop() #删除指定值,删除元素不存在报错 s.remove("s") #删除指定...
    99+
    2023-01-31
    基础知识 python set
  • python基础知识3(列表和元组)
    # 列表(可变数据类型) ## 列表的定义 列表是打了激素的数组,数组只能存储同种类型的数据,而列表像一个仓库,存储不同类型的数据. l = []l = [1]l = [1,(1,2),"hello",[1,2]]  ## 列表的特性 - ...
    99+
    2023-01-31
    基础知识 列表 python
  • ADSL知识集合3
    本文来自:[url]http://bbs.51cto.com/thread-4623-1-1.html[/url]  ADSL宽带使用过程中常见的一些问题    ADSL(Asymmetrical Digital Subscriber Lo...
    99+
    2023-01-31
    知识 ADSL
  • python基础知识小结之集合
    集合 特点:集合对象是一组无序排列的可哈希的值:集合成员可以做字典的键,与列表和元组不同,集合无法通过数字进行索引。此外,集合中的元素不能重复。 定义 set() -> new empty ...
    99+
    2022-06-04
    小结 基础知识 python
  • MySQL基础知识
    1、MySQL查询 union和union all的区别: union和union all都可以将两边的查询结果合并,区别在于union的合并会去掉重复行,并且使用默认的排序规则。而un...
    99+
    2022-01-06
    MySQL基础知识
  • Oracle基础知识
    1、Oracle分页查询 现有表employee_tbl,要求按年龄降序,分页查询数据,每页3条数据。 ID  NAME         DATE                             SIGNIN   AGE 1 ...
    99+
    2018-10-23
    Oracle基础知识
  • nodejs基础知识
    什么是nodejs? node.js是基于Chrome javaScript运行时建立的平台,用于方便地搭建响应速度快、易于扩展的网络应用。(但nodejs不是javascript应用,nodejs...
    99+
    2022-06-04
    基础知识 nodejs
  • MongoDB基础知识
    NoSQL是什么?   非关系型数据库,有时也称作Not Only SQL的缩写,是对不同于传统的关系型数据库的数据库管理系统的统称 NoSQL的优势  &...
    99+
    2024-04-02
  • MHA基础知识
    环境: ...
    99+
    2024-04-02
  • Python 基础知识
    只是打印出 hello world 肯定是不够的,是吗?你会希望做得比这还要多——你想要输入一些内容,操纵它,然后从中得到一些输出出来的内容。我们可以在 Python 中通过使用变量与常量来实现这一目标,在本章中我们还会学习其它的一些概...
    99+
    2023-01-31
    基础知识 Python
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作