• nginx反向代理,负载均衡,动静分离配置


    反向代理配置--实例一

    实现效果:使用 nginx 反向代理,访问 www.123.com 直接跳转到 http://www.123.com:5601

    server {
        listen       80;
        server_name  www.123.com;

        #charset koi8-r;
        #access_log  /var/log/nginx/log/host.access.log  main;

        location / {
           # root   /usr/share/nginx/html;
            proxy_pass   http://www.123.com:5601;
           # index  index.html index.htm;
        }

    修改完配置,需要执行重新加载配置 nginx -s reload 

    反向代理配置--实例二

    实现效果:

    访问 http://www.123.com:9000/seach/跳转到http://192.168.19.128:8085/search/

    访问 http://www.123.com:9000/detail/跳转到http://192.168.19.128:8085/detail/

    1. server {
    2. listen 9000;
    3. server_name www.123.com;
    4. #charset koi8-r;
    5. #access_log /var/log/nginx/log/host.access.log main;
    6. location / {
    7. # root /usr/share/nginx/html;
    8. proxy_pass http://www.baidu.com;
    9. # index index.html index.htm;
    10. }
    11. location ~ /search/ {
    12. proxy_pass http://192.168.19.128:8085;
    13. }
    14. location ~ /detail/ {
    15. proxy_pass http://192.168.19.128:8085;
    16. }
    17. }
    1、= :用于不含正则表达式的 uri 前,要求请求字符串与 uri 严格匹配,如果匹配
    成功,就停止继续向下搜索并立即处理该请求。
    2、~:用于表示 uri 包含正则表达式,并且区分大小写。
    3、~*:用于表示 uri 包含正则表达式,并且不区分大小写。
    4、^~:用于不含正则表达式的 uri 前,要求 Nginx 服务器找到标识 uri 和请求字
    符串匹配度最高的 location 后,立即使用此 location 处理请求,而不再使用 location
    块中的正则 uri 和请求字符串做匹配。
    注意:如果 uri 包含正则表达式,则必须要有 ~ 或者 ~* 标识。

    负载均衡配置 

    http块中添加上流

    1. upstream pingmoweb{
    2. server 192.168.19.128:8085;
    3. server 192.168.19.128:8081;
    4. }

    添加server 

    1. server {
    2. listen 9001;
    3. server_name www.123.com;
    4. location / {
    5. proxy_pass http://pingmoweb;
    6. }
    7. }

    负载均衡策略

    1、轮询(默认)
    每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器 down 掉,能自动剔除
    2、weight
    weight 代表权 , 重默认为 1, 权重越高被分配的客户端越多
    指定轮询几率, weight 和访问比率成正比,用于后端服务器性能不均的情况。 例如:
    1. upstream server_pool{
    2. server 192.168.5.21 weight=10;
    3. server 192.168.5.22 weight=10;
    4. }
    3、ip_hash
    每个请求按访问 ip hash 结果分配,这样每个访客固定访问一个后端服务器,可以解决 session 的问题。 例如:
    1. upstream server_pool{
    2. ip_hash;
    3. server 192.168.5.21:80;
    4. server 192.168.5.22:80;
    5. }
    4、fair(第三方)
    按后端服务器的响应时间来分配请求,响应时间短的优先分配。
    1. upstream server_pool{
    2. server 192.168.5.21:80;
    3. server 192.168.5.22:80;
    4. fair;
    5. }

    动静分离配置

    上传文件到指定目录 /usr/share/nginx/html/static,设置root目录

    实际存放目录结构:

    /usr/share/nginx/html/static/css/

    /usr/share/nginx/html/static/img/

    如果使用docker需放到容器内

    1. server {
    2. listen 9001;
    3. server_name www.123.com;
    4. location /css/ {
    5. root /usr/share/nginx/html/static;
    6. }
    7. location /img/ {
    8. root /usr/share/nginx/html/static;
    9. }
    10. location / {
    11. proxy_pass http://pingmoweb;
    12. }
    13. }

  • 相关阅读:
    什么是一致性哈希?一致性哈希是如何工作的?如何设计一致性哈希?
    基于手持技术的中学化学实验教学研究
    vue知识点--vuex+映射
    动态分配的分配算法——连续分配内存
    opengl,opengl es,egl,glfw,glew
    论文学习——多度量水文时间序列相似性分析
    1行代码提取6种TCGA表达矩阵和临床信息
    通过docker-compose部署elk日志系统,并使用springboot整合
    使用Docker安装运行RabbitMQ---阿里云服务器
    Docker 常用命令
  • 原文地址:https://blog.csdn.net/qq_29385297/article/details/127814784