1、环境准备:

设备 IP地址 作用 系统版本
web1 10.0.0.18 Nginx-Web服务器 Rocky8.6
web2 10.0.0.28 Nginx-Web服务器 Rocky8.6
Haproxy 172.20.0.248、10.0.0.101 反向代理web+负载均衡 Ubuntu2004
DNS 172.20.0.247 DNS服务器 Ubuntu2004
client 172.20.0.43 测试 Rocky8.6

2、安装后端web服务器

 #web服务器(10.0.0.18、10.0.0.28):
 [root@rocky8 ~]#yum install -y nginx
 [root@rocky8 ~]#echo `hostname -I` > /usr/share/nginx/html/index.html

3、配置HAProxy

 [root@ubuntu2004 ~]#bash install_haproxy.sh        #脚本参见:https://blog.51cto.com/dayu/5795076
 [root@ubuntu2004 ~]#vim /usr/lib/systemd/system/haproxy.service
 ExecStartPre=/usr/sbin/haproxy -f /etc/haproxy/haproxy.cfg -f /etc/haproxy/conf.d/ -c -q
 ExecStart=/usr/sbin/haproxy -Ws -f /etc/haproxy/haproxy.cfg -f /etc/haproxy/conf.d/  -p /var/lib/haproxy/haproxy.pid
 #证书制作
 [root@ubuntu2004 ~]#mkdir /etc/haproxy/certs
 [root@ubuntu2004 ~]#cd /etc/haproxy/certs
 [root@ubuntu2004 certs]#openssl genrsa -out www.wang.org.key 2048
 Generating RSA private key, 2048 bit long modulus (2 primes)
 .......................+++++
 .+++++
 e is 65537 (0x010001)
 [root@ubuntu2004 certs]#openssl req -x509 -newkey rsa:2048 -subj "/CN=www.wang.org" -keyout www.wang.org.key -nodes -days 3650 -out www.wang.org.crt
 Generating a RSA private key
 ........................+++++
 ......................................+++++
 writing new private key to 'www.wang.org.key'
 -----
 [root@ubuntu2004 certs]#cat www.wang.org.key www.wang.org.crt > www.wang.org.pem
 # 配置Https
 [root@ubuntu2004 ~]#vim /etc/haproxy/conf.d/ha_test.cfg
 frontend http_80
    bind 172.20.0.248:80
    bind 172.20.0.248:443 ssl crt /etc/haproxy/certs/www.wang.org.pem
    redirect scheme https if !{ ssl_fc }
    http-request set-header X-forwarded-Port %[dst_port]
    http-request add-header X-forwarded-proto https if { ssl_fc }
 ​
    mode http
    balance roundrobin
    log global
    option httplog
    use_backend servers
 ​
 backend servers
    mode http
    server web01 10.0.0.18:80 check inter 3000 fall 3 rise 3
    server web02 10.0.0.28:8008 check inter 3000 fall 3 rise 3
 ​

4、配置DNS

 [root@ubuntu2004 ~]#apt install bind9 bind9-utils
 ​
 [root@ubuntu2004 ~]#vim /etc/bind/named.conf.options
 // dnssec-validation auto;      #注释
 ​
 [root@ubuntu2004 ~]#cd /etc/bind/
 [root@ubuntu2004 bind]#vim named.conf.default-zones
 zone "wang.org" {
    type master;
    file "/etc/bind/wang.org.zone";
 };
 [root@ubuntu2004 bind]#cp -p db.local wang.org.zone
 $TTL    604800
 @   IN SOA admin admin.wang.org. (
                   2     ; Serial
              604800     ; Refresh
               86400     ; Retry
             2419200     ; Expire
              604800 )   ; Negative Cache TTL
 ;
 @   IN NS admin
 admin   IN A   172.20.0.247
 www     IN A   172.20.0.248
 [root@ubuntu2004 bind]#systemctl restart bind9.service
 [root@ubuntu2004 bind]#dig www.wang.org @127.0.0.1
 ......
 ;; ANSWER SECTION:
 www.wang.org. 604800 IN A 172.20.0.248
 ......
 ​

5、客户端测试

 [root@rocky8 ~]#vim /etc/resolv.conf
 nameserver 172.20.0.247
 [root@rocky8 ~]#curl -Lk www.wang.org
 10.0.0.28
 [root@rocky8 ~]#curl -Lk www.wang.org
 10.0.0.18
 [root@rocky8 ~]#curl -Lk www.wang.org
 10.0.0.28
 [root@rocky8 ~]#curl -Lk www.wang.org
 10.0.0.18
 ​

最新文章

  1. CC2540重写按键
  2. Matlab中一些函数的区别
  3. 关于history的Linux命令行
  4. 转: CentOS安装jdk8
  5. mysql卸载(转)
  6. TCP与UDP在socket编程中的区别
  7. Underscore.js 初探
  8. Gym 100285G Cipher Message 3
  9. 对OCR文字识别软件的扫描选项怎么设置
  10. 深入理解ThreadLocal(二)
  11. 构建属于自己的ORM框架之二--IQueryable的奥秘
  12. linux乱码问题
  13. Java基础知识强化之集合框架笔记26:LinkedList的特有功能
  14. Configuring Network Configuration-RHEL7
  15. C# 中文转拼音类
  16. OC-多线程GCD的使用细节
  17. zepto.js swipe实现触屏tab菜单
  18. 关于Apache配置虚拟主机后在局域网中让其他电脑访问
  19. 微信小程序-用户拒绝授权使用 wx.openSetting({}) 重新调起授权用户信息
  20. python框架之Django(16)-接入Redis

热门文章

  1. MySQL启动报:[ERROR] The server quit without updating PID file
  2. 基础1:JS的原型和原型链究竟
  3. 使springAOP生效不一定要加@EnableAspectJAutoProxy注解
  4. Semaphore-停车场
  5. 全链路追踪体验—最简陋TraceId的生成
  6. 在Linux下配置RealVNC和TigerVNC
  7. KDB_Database_Link 使用介绍
  8. Mysql 实现 向上递归查找父节点并返回树结构
  9. 发布日志- kratos v2.1.4 发布!
  10. ProxySQL Cluster 概述