lvs 持久连接 80 和443 端口iptables mangle

一、建立私有CA,并给服务器签发:

在确定配置为CA的服务器上生成一个自签证书,并为CA提供所需要的目录及文件即可;

步骤:

(1) 生成私钥;

]# (umask 077; openssl genrsa -out /etc/pki/CA/private/cakey.pem 4096)

注意:文件名要与配置文件中的文件名一致;

]# ll /etc/pki/CA/private/:查看文件权限确保为600;

(2) 生成自签证书;

]# openssl req -new -x509 -key /etc/pki/CA/private/cakey.pem -out /etc/pki/CA/cacert.pem -days 3655

-new:生成新证书签署请求;

-x509:生成自签格式证书,专用于创建私有CA时;

-key:生成请求时用到的私有文件路径;

-out:生成的请求文件路径;如果自签操作将直接生成签署过的证书;

-days:证书的有效时长,单位是day;

根据提示输入相关信息,完成即可;

提示输入:Country Name (2 letter code) [XX]:CN

提示输入:State or Province Name (full name) []:Beijing

提示输入:Locality Name (eg, city) [Default City]:Beijing

提示输入:Organization Name (eg, company) [Default Company Ltd]:MageEdu

提示输入:Organizational Unit Name (eg, section) []:Ops

提示输入:Common Name (eg, your name or your server‘s hostname) []:ca.magedu.com

如果是个人通信为自己的名字,如果是服务器为服务器主机名;

提示输入:Email Address []:[email protected]

]# ls /etc/pki/CA/

查看要有certs crl newcerts这3个目录,如果没有要自行创建;

(3) 为CA提供所需的目录及文件;

]# mkdir -pv /etc/pki/CA/{certs,crl,newcerts}

]# touch /etc/pki/CA/{serial,index.txt}

]# echo 01 > /etc/pki/CA/serial

在用到证书的服务器上操作:

1.创建一个目录存放主机的私钥;

2.生成私钥;

3.生成证书签署请求

4.将.csr文件请求通过可靠方式发送给CA主机;

步骤:(以httpd为例)

(1) 用到证书的主机生成私钥;

]# mkdir /etc/httpd/ssl

]# cd /etc/httpd/ssl

]# (umask  077; openssl  genrsa -out  /etc/httpd/ssl/httpd.key  2048)

(2) 生成证书签署请求

]# openssl req -new -key /etc/httpd/ssl/httpd.key -out /etc/httpd/ssl/httpd.csr -days 365

根据提示输入相关信息,完成即可;

提示输入:Country Name (2 letter code) [XX]:CN

提示输入:State or Province Name (full name) []:Beijing

提示输入:Locality Name (eg, city) [Default City]:Beijing

提示输入:Organization Name (eg, company) [Default Company Ltd]:MageEdu

提示输入:Organizational Unit Name (eg, section) []:Ops

提示输入:Common Name (eg, your name or your server‘s hostname) []:www.magedu.com

此处一定要为客户端访问的地址;

提示输入:Email Address []:[email protected]

提示输入:A challenge password []:可为空

提示输入:An optional company name []:可为空

(3) 将请求通过可靠方式发送给CA主机;

]# ls:生成一个httpd.csr文件,把此文件用可靠方式发送给CA主机;

实际应用时,是CA公司来人到现场取走文件;

实验环境,就是以scp命令,可实现两主机间复制文件;

]# scp httpd.csr [email protected]:/tmp/

表示在本地复制httpd.csr文件,以远程主机172.18.250.131的root用户身份拷贝此文件到远程主机的/tmp/目录下

输入yes,确认连接,再输入远程主机root用户的登录密码,即可复制完成;

就是实现了把httpd.csr文件拷贝的CA主机上;

(4) 在CA主机上签署证书;

]# openssl ca -in /tmp/httpd.csr -out /etc/pki/CA/certs/httpd.crt -days 365

显示提示:Sign the certificate? [y/n]:y

显示提示:1 out of 1 certificate requests certified, commit? [y/n]y

把签署的证书httpd.crt发送给服务器主机:

在实验环境,还用scp两主机直接拷贝文件httpd.crt即可;

]# scp certs/httpd.crt [email protected]:/etc/httpd/ssl/

输入yes,确认连接,再输入远程主机root用户的登录密码,即可复制完成;

此时在服务器主机上的httpd.csr就没用了,可以删了;

在CA主机上的签署前的httpd.csr也没用了,也可以删了;

以上创建私有CA完成;

可在服务器主机或客户端主机上(只要有证书),都可查看证书;

]# openssl x509 -in /etc/pki/CA/certs/httpd.crt -noout -serial -subject

二、nginx启用ssl

# vim /etc/nginx/conf.d/ssl.conf

server {

listen       443;

server_name  _;

ssl                  on;

ssl_certificate      /etc/httpd/ssl/httpd.crt;

ssl_certificate_key  /etc/httpd/ssl/httpd.key;

ssl_session_timeout  5m;

ssl_protocols  SSLv2 SSLv3 TLSv1;

ssl_ciphers  ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP;

ssl_prefer_server_ciphers   on;

location / {

root   html;

index  index.html index.htm;

}

}

测试两台web服务器80和443正常。

三、添加iptables mangle

查看:

# iptables -t mangle -nvL --line-number

修改:

# iptables -t mangle -R  PREROUTING 2  -d 192.168.1.212 -p tcp --dport 443 -j MARK --set-mark 10

添加:

# iptables -t mangle -A PREROUTING -d 192.168.1.212 -p tcp --dport 80 -j MARK --set-mark 10

# iptables -t mangle -A PREROUTING -d 192.168.1.212 -p tcp --dport 80 -j MARK --set-mark 10

# iptables -t mangle -L -n -v

# iptables -t mangle -A PREROUTING -d 192.168.1.212 -p tcp --dport 443 -j MARK --set-mark 10

配置ipvsadm

# ipvsadm -C

# ipvsadm -l -n

[[email protected] ~]# ipvsadm -A -f 10 -s rr

[[email protected] ~]# ipvsadm -a -f 10 -r 192.168.1.213  -m -w 2

[[email protected] ~]# ipvsadm -a -f 10 -r 192.168.1.214  -m -w 2

[[email protected] ~]#  ipvsadm -E -f 10 -s rr -p

时间: 2024-10-14 11:12:45

lvs 持久连接 80 和443 端口iptables mangle的相关文章

Linux集群系列之六——LVS持久连接

DR: arp_ignore = 1 arp_announce = 2 数组:变量阵列 array_name=("" "" "" ) declare -a A 把一个变量明确申明为数组 LVS的持久连接:   无论使用什么算法,LVS持久连接都能实现在一定时间内将来自同一个客户端请求派发到同一个RS. 持久连接模版(内存缓冲区): 每一个客户端 及分配给它的RS的映射关系: ipvsadm -L -c 显示当前的持久连接数 ipvsadm -A|

lvs持久连接

在我们实现lvs负载均衡的同时是否想过这样的一个问题:当客户访问一台WEB服务器时,如果每次客户刷新页面后多会更变连接的realserver,那么这样客户是会非常苦恼的,因为客户一刷新前面的数据和保留的session信息就 找不到了. 对于这样的问题我们该怎么解决呢? 其实解决的这个问题是有很多方法的,下面我就来介绍关于lvs提出的解决方案吧--------------基于lvs持久连接. lvs持久连接的三种模型: 1.PCC 将某个客户的所用访问请求在超时时间内都定向到同一台server上

Cluster了解+LB{ LVS(四种模式)+ipvs+lvs持久连接 }

Cluster: 系统扩展的两种思路: scale up:向上扩展 -- 性能更好的主机,替换旧的主机 scale out:横向扩展 -- 添加服务器(但是服务是可以分开的,独立的) cookie:服务器端生成一个cookie-id,发送给客户端,客户端每次访问,都会将cookie发送给服务器端 session:服务器端会比对cookie和seesion的对应情况(服务器内存中) 实现 LB(负载均衡)-- 问题所在 1.DNS: 不要使用dns 去实现 LB,因为DNS 解析会缓存,所以效果很

skype默认占用80和443端口

今天把服务器的端口更改为80,结果起不来,报告"端口已经被占用"的错误. 使用下列命令找到了元凶: 1. netstat -ano | findstr 80 找到占用80端口的pid. 2. 使用tasklist | findstr 上面找到的pid 然后发现是skype. 至于为什么skype要使用80端口,好像是为了提高网络穿透力, 毕竟大家都使用浏览器上网,一般的不会禁止80端口. skype默认占用80和443端口

ServU与IIS冲突原因:80、443端口占用

Serv-U可以说是在 Win 服务器上最受欢迎的FTP客户端,因为他的使用方法和稳定性相对于其他FTP客户端来说,都是有绝对的优势. 但是总是看到Serv-U的图标有黄色感叹号出现,而且IIS中的网站在运行一段时间后,莫名其妙地会变成Serv-U的管理界面:重启IIS服务,IIS提示“另一个程序正在使用此文件,进程无法访问”,这就说明IIS的80端口被Serv-U抢占了. Serv-U与IIS冲突的原因是与IIS抢占80和443端口.Serv-U 从7.0版本以后增加了通过Web方式管理服务器

FWM及LVS持久连接

FWM防火墙标记 为什么使用防火墙标记? 将来自于同一个客户端的所有请求都定义到同一个realserver上:如使用防火墙标记将443和80定义为同一个集群服务,这样就可以实现统一调度到后端的real server. 比如:在电商站点中,如果往购物车中添加商品之后,需要付款:这个时候就需要访问direction,发起的连接就不是http,而是https,direction会认为这是一个新的连接,很可能会被分配到其他RS服务器,这个时候购物车中就没有了商品.为了解决这种问题,就需要把用户的http

Linux集群(四)-LVS持久连接与高可用

FWM:FireWall Mark MARK target 可用于给特定的报文打标记 --set-mark value 其中:value 为十六进制数字 借助于防火墙标记来分类报文,而后基于标记定义集群服务:可将多个不同的应用使用同一个集群服务进行调度 实现方法: 在VS主机打标记: iptables -t mangle -A PREROUTING -d $vip -p $proto –m multiport --dports $port1,$port2,- -j MARK --set-mark

LVS 持久连接 PPC模式、PCC模式、防火墙标记

持久连接 PPC模式.PCC模式.防火墙标记 [LVS]我的是X86的系统 ipvsadm 功能类似Iptables 管理集群服务 增删改 管理RS增删改 查看 –L [磨刀不误砍柴工]看清楚,不要配置错了 两台RS都安装 192.168.3.123     192.168.3.87 网关都一样 route add default gw 192.168.3.77 [做不同端口持久连接测试用] yum -y install telnet-server yum -y install httpd se

LVS持久连接(PPC+PCC+PNMPP)

无论使用哪种算法,LVS的持久连接都实现在一定时间内,将来自同一客户端的多种请求派发至此前选定的real-server. 持久连接模板(内存缓冲区): 记录每一个客户端及分配给它的RS. 查看当前的持久连接: ipvsadm -L -persistent-conn ipvsadm -L -c 设置持久连接: ipvsadm -A|-E ... -p timeout 默认timeout为300S. 在基于SSL会话的连接中,最需要使用持久连接. PPC(持久端口连接):将来自于同一个客户端对同一个