Java回顾(二十)Nginx使用

1、Nginx基础(安装和网站部署)

1.1 安装(在Java回顾十九 那个文章有)

https://blog.csdn.net/hongweisong666/article/details/106564378

1.2 Nginx静态网站部署

【步骤一】
先进入nginx目录,打开nginx.conf目录,
在这里插入图片描述
【步骤二】
打开配置文件,并且修改,这里使用一个软件工具(EditPlus)来进行对配置文件的修改
安装激活教程请看这个链接https://www.cnblogs.com/CSAH/p/10807492.html

这个软件可以配置连接到Linux系统上的一些配置文件
在这里插入图片描述
在这里插入图片描述
如下图所示,就是连接成功了
在这里插入图片描述
nginx的配置源文件,我先备份下


#user  nobody;
worker_processes  1;

#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

#pid        logs/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       mime.types;
    default_type  application/octet-stream;

    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';

    #access_log  logs/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;

    #gzip  on;

    server {
        listen       80;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            root   html;
            index  index.html index.htm;
        }

        #error_page  404              /404.html;

        # redirect server error pages to the static page /50x.html
        #
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }

        # proxy the PHP scripts to Apache listening on 127.0.0.1:80
        #
        #location ~ \.php$ {
        #    proxy_pass   http://127.0.0.1;
        #}

        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
        #
        #location ~ \.php$ {
        #    root           html;
        #    fastcgi_pass   127.0.0.1:9000;
        #    fastcgi_index  index.php;
        #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
        #    include        fastcgi_params;
        #}

        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
        #location ~ /\.ht {
        #    deny  all;
        #}
    }


    # another virtual host using mix of IP-, name-, and port-based configuration
    #
    #server {
    #    listen       8000;
    #    listen       somename:8080;
    #    server_name  somename  alias  another.alias;

    #    location / {
    #        root   html;
    #        index  index.html index.htm;
    #    }
    #}


    # HTTPS server
    #
    #server {
    #    listen       443 ssl;
    #    server_name  localhost;

    #    ssl_certificate      cert.pem;
    #    ssl_certificate_key  cert.key;

    #    ssl_session_cache    shared:SSL:1m;
    #    ssl_session_timeout  5m;

    #    ssl_ciphers  HIGH:!aNULL:!MD5;
    #    ssl_prefer_server_ciphers  on;

    #    location / {
    #        root   html;
    #        index  index.html index.htm;
    #    }
    #}

}

删除注释后的conf文件夹


#user  nobody;
worker_processes  1;


events {
    worker_connections  1024;
}


http {
    include       mime.types;
    default_type  application/octet-stream;

    sendfile        on;

    keepalive_timeout  65;


    server {
        listen       80;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            root   html;
            index  index.html index.htm;
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }


    }

}

在这里插入图片描述
在这里插入图片描述

以后要传静态网页的话,就只要把那个目录传到这个nginx目录下即可,比如那个文件夹的名称是index,那么root 后面就要写index (也就是 root index),它的默认首页是index.html或者index.htm
在这里插入图片描述
在这里插入图片描述
修改完成后,记得保存,然后上传

【步骤三】
进入sbin目录下,进行对nginx重启即可

./nginx

在这里插入图片描述

将静态页面/index目录下的所有内容上传到服务器的/usr/local/ngin/html下即可访问

1.3 配置虚拟主机

1.3.1 端口绑定

在这里插入图片描述
修改conf文件,配置多个端口,即可显示多个项目信息

server {
        listen       81; # 监听的端口
        server_name  localhost; # 域名或ip
        location / {	# 访问路径配置
            root   index;# 根目录
            index  index.html index.htm; # 默认首页
        }
        error_page   500 502 503 504  /50x.html;	# 错误页面
        location = /50x.html {
            root   html;
        }
    }


     server {
        listen       82; # 监听的端口
        server_name  localhost; # 域名或ip
        location / {	# 访问路径配置
            root   regist;# 根目录
            index  regist.html; # 默认首页
        }
        error_page   500 502 503 504  /50x.html;	# 错误页面
        location = /50x.html {
            root   html;
        }
    }

1.3.2 域名绑定

一个域名对应一个 ip 地址,一个 ip 地址可以被多个域名绑定。
本地测试可以修改 hosts 文件(C:\Windows\System32\drivers\etc)
可以配置域名和 ip 的映射关系,如果 hosts 文件中配置了域名和 ip 的对应关系,不需要走dns 服务器。

在这里插入图片描述
在这里插入图片描述
可以在host文件夹下面绑定不同的域名(但是对应的是同一个服务器),然后将域名的信息,放到 server_name localhost; # 域名或ip 里面去即可。

2、Nginx 反向代理和负载均衡

2.1 反向代理

2.1.1 反向代理的原理

反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器。

正向代理如下所示:
在这里插入图片描述
正向代理是针对你的客户端,而反向代理是针对服务器的,如下图
在这里插入图片描述
在这里插入图片描述

2.1.2 反向代理的实现

【步骤一】
准备工作
(1) 将案例部署到tomcat中(ROOT目录),上传到服务器。
(2)启动TOMCAT,输入网址http://192.168.177.129:8080 可以看到网站首页

【步骤二】
配置反向代理
主要是加入以下两段代码
在这里插入图片描述

upstream 名字(可以随便起){
	   server 192.168.125.172:8080;
    }

proxy_pass http://名字(可以随便起,对应上面的那个);

在这里插入图片描述

2.2 负载均衡

2.2.1 概念

负载均衡 建立在现有网络结构之上,它提供了一种廉价有效透明的方法扩展网络设备和服务器的带宽、增加吞吐量、加强网络数据处理能力、提高网络的灵活性和可用性。
负载均衡,英文名称为Load Balance,其意思就是分摊到多个操作单元上进行执行,例如Web服务器、FTP服务器、企业关键应用服务器和其它关键任务服务器等,从而共同完成工作任务。

2.2.2 配置

【步骤一】
配置负载均衡-准备工作
(1)将刚才的存放工程的tomcat复制三份,修改端口分别为8080 ,8081,8082 。
(2)分别启动这三个tomcat服务。
(3)为了能够区分是访问哪个服务器的网站,可以在首页标题加上标记以便区分

cp -r apache-tomcat-7.0.57 tomcat1
cp -r apache-tomcat-7.0.57 tomcat2
cp -r apache-tomcat-7.0.57 tomcat3

在这里插入图片描述
这三个tomcat的话,ROOT目录下面是之前上传的war包
然后要在tomcat的配置文件下改端口(要改很多端口,不只是改一个端口),修改好了之后,去index的页面中,修改页面的标题,以便后续可以区分是哪一个tomcat进行展示页面的。

修改 Nginx配置文件:

 upstream tomcat-travel {
   server 192.168.125.172:8081;
   server 192.168.125.172:8082;
   server 192.168.125.172:8083;
}

server {
    listen       80; # 监听的端口
    server_name  www.hws.com; # 域名或ip
    location / {	# 访问路径配置
        # root   index;# 根目录
    proxy_pass http://tomcat-travel;

        index  index.html index.htm; # 默认首页
    }
    error_page   500 502 503 504  /50x.html;	# 错误页面
    location = /50x.html {
        root   html;
    }
}

地址栏输入http:// www.hws.com / 刷新观察每个网页的标题,看是否不同。
经过测试,三台服务器出现的概率各为33.3333333%,交替显示。

如果其中一台服务器性能比较好,想让其承担更多的压力,可以设置权重weight,默认的权重是1。
比如想让NO.1出现次数是其它服务器的2倍,则修改配置如下:

upstream tomcat-web {
   server 192.168.125.172:8081  weight=2;
   server 192.168.125.172:8082;
   server 192.168.125.172:8083;

经过测试,每刷新四次,有两次是8081

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

隐形的稻草人HWS

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值