1、Nginx基础(安装和网站部署)
1.1 安装(在Java回顾十九 那个文章有)
1.2 Nginx静态网站部署
【步骤一】
先进入nginx目录,打开nginx.conf目录,
【步骤二】
打开配置文件,并且修改,这里使用一个软件工具(EditPlus)来进行对配置文件的修改
安装激活教程请看这个链接
这个软件可以配置连接到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