Apache httpd 入门实战(2)--简单使用

打印 上一主题 下一主题

主题 1720|帖子 1720|积分 5160

本文主要介绍 Apache 的实际使用,文中所使用到的软件版本:Centos 7.9.2009、Httpd 2.4.55。
1、反向代理

涉及到 Https 站点时,安装 Apache 时需要启用 ssl,可参考 Apache httpd 入门实战(1)--概念及安装
1.1、被代理站点为 Http 站点

打开 conf/httpd.conf 文件,修改或新增相应的配置项:
  1. Listen 8080
  2. ServerName 10.49.196.33:8080
  3. LoadModule proxy_module modules/mod_proxy.so
  4. LoadModule proxy_http_module modules/mod_proxy_http.so
  5. include conf/extra/my-vhosts.conf
复制代码
新建 conf/extra/my-vhosts.conf 文件:
  1. <VirtualHost *:8080>
  2.     ServerAdmin admin@abc.com
  3.     ServerName abc.com
  4.     ServerAlias abc.com
  5.     ErrorLog "logs/abc.com-error_log"
  6.     CustomLog "logs/abc.com-access_log" common
  7.     ProxyPass /qwe http://10.49.196.1:9090/qwe
  8.     ProxyPassReverse /qwe http://10.49.196.1:9090/qwe
  9. </VirtualHost>
复制代码
代理地址为 http://10.49.196.33:8080/qwe,被代理的地址为 http://10.49.196.1:9090/qwe。
1.2、被代理站点为 Https 站点

打开 conf/httpd.conf 文件,修改或新增相应的配置项:
  1. Listen 8080
  2. ServerName 10.49.196.33:8080
  3. LoadModule proxy_module modules/mod_proxy.so
  4. LoadModule proxy_http_module modules/mod_proxy_http.so
  5. LoadModule ssl_module modules/mod_ssl.so
  6. include conf/extra/my-vhosts.conf
复制代码
新建 conf/extra/my-vhosts.conf 文件:
  1. <VirtualHost *:8080>
  2.     ServerAdmin admin@abc.com
  3.     ServerName abc.com
  4.     ServerAlias abc.com
  5.     ErrorLog "logs/abc.com-error_log"
  6.     CustomLog "logs/abc.com-access_log" common
  7.     SSLProxyEngine On
  8.     ProxyPass /asd https://10.49.196.1:9091/asd
  9.     ProxyPassReverse /asd https://10.49.196.1:9091/asd
  10. </VirtualHost>
复制代码
代理地址为 http://10.49.196.33:8080/asd,被代理的地址为 https://10.49.196.1:9091/asd。
1.3、代理站点启用 Https

1.3.1、生成证书

代理站点启用 Https,需要使用 OpenSSL 创建证书。
A、生成根证书
  1. openssl genrsa -out ca.key
  2. openssl req -new -key ca.key -out ca.csr
  3. openssl x509 -req -days 3650 -in ca.csr -signkey ca.key -out ca.pem
复制代码
B、生成服务端证书
  1. openssl genrsa -out server.key
  2. openssl req -new -key server.key -out server.csr
  3. openssl ca -days 3650 -in server.csr -cert ca.pem -keyfile ca.key -out server.pem
复制代码
C、生成客户端证书
  1. openssl genrsa -des3 -out client.key 1024
  2. openssl req -new -key client.key -out client.csr
  3. openssl ca -days 1500 -in client.csr -cert ca.pem -keyfile ca.key -out client.pem
  4. openssl pkcs12 -export -clcerts -in client.pem -inkey client.key -out client.p12
复制代码
使用 OpenSSL 创建证书的详细说明可参考:OpenSSL 介绍(5)--数字证书;这里生成的证书假设都存放在 /home/mongo/ssl 目录下。
1.3.2、Apache 中配置 Https

打开 conf/httpd.conf 文件,修改或新增相应的配置项:
  1. Listen 8443
  2. ServerName 10.49.196.33:8443
  3. LoadModule proxy_module modules/mod_proxy.so
  4. LoadModule proxy_http_module modules/mod_proxy_http.so
  5. LoadModule ssl_module modules/mod_ssl.so
  6. include conf/extra/my-vhosts.conf
复制代码
新建 conf/extra/my-vhosts.conf 文件:
  1. <VirtualHost *:8443>
  2.     ServerAdmin admin@abc.com
  3.     ServerName abc.com
  4.     ServerAlias abc.com
  5.     ErrorLog "logs/abc.com-error_log"
  6.     CustomLog "logs/abc.com-access_log" common
  7.     SSLEngine on
  8.     SSLCertificateFile /home/mongo/ssl/server.pem
  9.     SSLCertificateKeyFile /home/mongo/ssl/server.key
  10.     ProxyPass /qwe http://10.49.196.1:9090/qwe
  11.     ProxyPassReverse /qwe http://10.49.196.1:9090/qwe
  12.     SSLProxyEngine On
  13.     ProxyPass /asd https://10.49.196.1:9091/asd
  14.     ProxyPassReverse /asd https://10.49.196.1:9091/asd
  15. </VirtualHost>
复制代码
代理地址为 https://10.49.196.33:8443/qwe、https://10.49.196.33:8443/asd,被代理的分别地址为 http://10.49.196.1:9090/qwe、https://10.49.196.1:9091/asd。
如果需要验证客户端,则配置如下:
  1. <VirtualHost *:8443>
  2.     ServerAdmin admin@abc.com
  3.     ServerName abc.com
  4.     ServerAlias abc.com
  5.     ErrorLog "logs/abc.com-error_log"
  6.     CustomLog "logs/abc.com-access_log" common
  7.     SSLEngine on
  8.     SSLCertificateFile /home/mongo/ssl/server.pem
  9.     SSLCertificateKeyFile /home/mongo/ssl/server.key
  10.    
  11.     SSLVerifyClient require
  12.     SSLCACertificateFile /home/mongo/ssl/ca.pem
  13.     ProxyPass /qwe http://10.49.196.1:9090/qwe
  14.     ProxyPassReverse /qwe http://10.49.196.1:9090/qwe
  15.     SSLProxyEngine On
  16.     ProxyPass /asd https://10.49.196.1:9091/asd
  17.     ProxyPassReverse /asd https://10.49.196.1:9091/asd
  18. </VirtualHost>
复制代码
2、负载均衡

打开 conf/httpd.conf 文件,修改或新增相应的配置项:
  1. Listen 8080
  2. ServerName 10.49.196.33:8080
  3. LoadModule watchdog_module modules/mod_watchdog.so
  4. LoadModule proxy_module modules/mod_proxy.so
  5. LoadModule proxy_http_module modules/mod_proxy_http.so
  6. LoadModule proxy_balancer_module modules/mod_proxy_balancer.so
  7. LoadModule proxy_hcheck_module modules/mod_proxy_hcheck.so
  8. LoadModule slotmem_shm_module modules/mod_slotmem_shm.so  
  9. LoadModule lbmethod_byrequests_module modules/mod_lbmethod_byrequests.so
  10. LoadModule lbmethod_bytraffic_module modules/mod_lbmethod_bytraffic.so
  11. LoadModule lbmethod_bybusyness_module modules/mod_lbmethod_bybusyness.so
  12. LoadModule lbmethod_heartbeat_module modules/mod_lbmethod_heartbeat.so
  13. include conf/extra/my-vhosts.conf
复制代码
2.1、不考虑 session

新建 conf/extra/my-vhosts.conf 文件:
  1. <VirtualHost *:8080>
  2.     ServerAdmin admin@abc.com
  3.     ServerName abc.com
  4.     ServerAlias abc.com
  5.     ErrorLog "logs/abc.com-error_log"
  6.     CustomLog "logs/abc.com-access_log" common
  7.     <Proxy balancer://mycluster>
  8.         BalancerMember http://10.49.196.1:9090 loadfactor=2
  9.         BalancerMember http://10.49.196.2:9090 loadfactor=3 timeout=3
  10.         ProxySet lbmethod=byrequests
  11.     </Proxy>
  12.     ProxyPass /xyz balancer://mycluster/xyz
  13.     ProxyPassReverse /xyz balancer://mycluster/xyz
  14. </VirtualHost>
复制代码
lbmethod:负载均衡算法
lbmethod=byrequests:按请求次数负载均衡
lbmethod=bytraffic:按流量负载均衡
lbmethod=bybusyness:按繁忙程度(挂起的请求数)负载均衡
lbmethod=heartbeat:按心跳数负载均衡
loadfactor:负载因子;timeout:超时时间,单位为秒。
代理地址为 http://10.49.196.33:8080/xyz,被代理的地址为 http://10.49.196.1:9090/xyz、http://10.49.196.2:9090/xyz。
2.2、session 粘滞

对应有 session 的情况,同一客户端需要把请求转发到同一个后端服务。新建 conf/extra/my-vhosts.conf 文件:
  1. <VirtualHost *:8080>
  2.     ServerAdmin admin@abc.com
  3.     ServerName abc.com
  4.     ServerAlias abc.com
  5.     ErrorLog "logs/abc.com-error_log"
  6.     CustomLog "logs/abc.com-access_log" common
  7.     <Proxy balancer://mycluster>
  8.         Header add Set-Cookie "ROUTEID=.%{BALANCER_WORKER_ROUTE}e; path=/tsp" env=BALANCER_ROUTE_CHANGED
  9.         BalancerMember http://10.49.196.1:9090 loadfactor=2 route=server1
  10.         BalancerMember http://10.49.196.2:9090 loadfactor=3 route=server2
  11.         ProxySet lbmethod=byrequests
  12.         ProxySet stickysession=ROUTEID
  13.     </Proxy>
  14.     ProxyPass /xyz balancer://mycluster/xyz
  15.     ProxyPassReverse /xyz balancer://mycluster/xyz
  16. </VirtualHost>
复制代码
Header add Set-Cookie:设置名称为 ROUTEID 的 cookie
ProxySet stickysession=ROUTEID:根据 cookie ROUTEID 的值路由到相应的后端服务
2.3、failover
  1. <Proxy balancer://myset>
  2.     BalancerMember http://www2.example.com:8080
  3.     BalancerMember http://www3.example.com:8080 loadfactor=3 timeout=1
  4.     BalancerMember http://spare1.example.com:8080 status=+R
  5.     BalancerMember http://spare2.example.com:8080 status=+R
  6.     BalancerMember http://hstandby.example.com:8080 status=+H
  7.     BalancerMember http://bkup1.example.com:8080 lbset=1
  8.     BalancerMember http://bkup2.example.com:8080 lbset=1
  9.     ProxySet lbmethod=byrequests
  10. </Proxy>
  11. ProxyPass "/images/"  "balancer://myset/"
  12. ProxyPassReverse "/images/"  "balancer://myset/"
复制代码
A、http://www2.example.com:8080 或 http://www3.example.com:8080 不可用时,才会把流量分配给 http://spare1.example.com:8080 和 http://spare2.example.com:8080。一个备用的节点会替换一个不可用的节点。
B、当 http://www2.example.com:8080、http://www2.example.com:8080、http://www2.example.com:8080、http://www2.example.com:8080 都不可用时,才会把流量分配给热备节点:http://hstandby.example.com:8080。
C、当所有 lbset=0(后端节点的优先级,默认为 0;数值越低的,优先级越高) 的节点(正常节点、备用节点、热备节点)都不可用时,才会把流量分配给备份节点:http://bkup1.example.com:8080 和 http://bkup2.example.com:8080。
2.4、负载均衡管理器
  1. <VirtualHost *:8080>
  2. ...
  3.   <Location "/balancer-manager">
  4.       SetHandler balancer-manager
  5.       Require ip 10.49.196.35
  6.   </Location>
  7. ...
  8. </VirtualHost>
复制代码
Require ip:设置可用访问负载均衡器的 ip。
通过负载均衡管理页面(http://10.49.196.33:6060/balancer-manager)可以查看负载均衡的配置和状态,还可以在页面上直接修改配置。

 
 
参考:https://httpd.apache.org/docs/2.4/howto/reverse_proxy.html。
 

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

何小豆儿在此

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表