文章目录
1. 基本概念
1.1 nginx
Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器,同时也提供了IMAP/POP3/SMTP服务。
1.2 特点
占有内存少,并发能力强,能够支持高达 50,000 个并发连接数的响应,中国大陆使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝等。
1.3 应用场景
1、http服务器。Nginx是一个http服务可以独立提供http服务。可以做网页静态服务器。
2、虚拟主机。可以实现在一台服务器虚拟出多个网站。例如个人网站使用的虚拟主机。
3、反向代理,负载均衡。当网站的访问量达到一定程度后,单台服务器不能满足用户的请求时,需要用多台服务器集群可以使用nginx做反向代理。并且多台服务器可以平均分担负载,不会因为某台服务器负载高宕机而某台服务器闲置的情况。
1.4 进行安装
请点击这里进行安装
我的CentOS 版本为7.4
点击这里获取nginx的安装软件
提取码:z4kn
安装中途可能碰到没有C++,大家不要慌,
建议先安装C++
yum -y install gcc gcc-c++
安装成功会提示 Complete!
2. 反向代理
无论时正向代理还是反向代理,代理服务器都存在。举个例子:
我想要访问www.baidu.com时,即访问目标服务器(www.baidu.com),
我将请求提交给中间一个代理服务器,
代理服务器带着我的请求访问目标服务器,
目标服务器将结果返回给代理服务器,
代理服务器将结果返回给我。
2.1 正向代理
正向代理就是通过在客户端设置代理服务器,然后通过代理服务器访问目标服务器
将客户端和代理服务器看成一个局域网,目标服务器时另一个局域网。
目标服务器知道代理服务器的存在,但是不知道客户端(用户)的存在。
2.2反向代理
反向代理服务器位于用户与目标服务器之间,但是对于用户而言,反向代理服务器就相当于目标服务器,即用户直接访问反向代理服务器就可以获得目标服务器的资源。
反向代理服务器:将用户的请求进行转发,让其它的服务器进行处理,可以做到负载均衡。
同时,用户不需要知道目标服务器的地址,也无须在用户端作任何设定。反向代理服务器通常可用来作为Web加速,即使用反向代理作为Web服务器的前置机来降低网络和服务器的负载,提高访问效率.
2.3 使用nginx实现反向代理
Nginx只做请求的转发,后台有多个http服务器提供服务,nginx的功能就是把请求转发给后面的服务器,决定把请求转发给谁。
1.安装tomcat
点击获取链接
使用rz命令时,首先要进入linux中上传的目录
yum install lrzsz -y #安装rz命令
rz #从本地选择你上传的文件
2.配置tomcat
tar -zxvf apache-tomcat-7.0.103.tar.gz #解压缩
mv apache-tomcat-7.0.103 tomcat1 #修改名字为tomcat1
cp tomcat1/ tomcat2 #进行复制
mkdir /usr/local/tomcat #创建文件夹
#mv tomcat1/ tomcat2/ /usr/local/tomcat/将tomcat1 和 tomcat2 移动到tomcat中
vi /usr/local/tomcat/tomcat2/conf/server.xml #进行修改配置文件(两个tomcat端口会产生冲突,选择修改tomcat2)(下面第一二张图)
/usr/local/tomcat/tomcat1/bin/startup.sh #重启tomcat1
/usr/local/tomcat/tomcat2/bin/startup.sh #重启tomcat2
vi /usr/local/tomcat/tomcat2/webapps/ROOT/index.jsp# 在展示页面进行标注(第三张图)
- 配置hosts
- 配置nginx
在vi /usr/local/nginx/conf/nginx.conf
添加以下配置
当http://8081.taotao.com/
请求过来时,proxy_pass会将server_name的请求进行转发到proxy_pass指定的服务器上进行处理。
upstream tomcatserver1 {
server 192.168.121.131:8080;
}
upstream tomcatserver2 {
server 192.168.121.131:8081;
}
server {
listen 80;
server_name 8080.taotao.com;
location / {
#将域名为8080.taotao.com的请求转发到tomcatserver1的服务器上
proxy_pass http://tomcatserver1;
index index.html index.htm;
}
}
server {
listen 80;
server_name 8081.taotao.com;
location / {
proxy_pass http://tomcatserver2;
index index.html index.htm;
}
}
3. 负载均衡
负载均衡 建立在现有网络结构之上,它提供了一种廉价有效透明的方法扩展网络设备和服务器的带宽、增加吞吐量、加强网络数据处理能力、提高网络的灵活性和可用性。
负载均衡,英文名称为Load Balance,其意思就是分摊到多个操作单元上进行执行,例如Web服务器、FTP服务器、企业关键应用服务器和其它关键任务服务器等,从而共同完成工作任务。
请求量增大时,一台服务器应付不过来了,我们可以选择更换高级的服务器,一般不太适用;我们还可以增加服务器的数量,将请求分发到各个服务器上,将原来请求到单个服务器的情况改为请求到多个服务器上,将负载分发到多个服务器上,即负载均衡。
3.1 配置nginx的负载均衡
vi /usr/local/nginx/conf/nginx.conf #配置负载均衡
/usr/local/nginx/sbin/nginx -s reload #从新加载配置
节点说明:
在http节点里添加:
#定义负载均衡设备的 Ip及设备状态
upstream myServer {
server 127.0.0.1:9090 down;
server 127.0.0.1:8080 weight=2;
server 127.0.0.1:6060;
server 127.0.0.1:7070 backup;
}
在需要使用负载的Server节点下添加
proxy_pass http://myServer;
upstream 每个设备的状态:
down 表示单前的server暂时不参与负载
weight 默认为1.weight越大,负载的权重就越大。
max_fails :允许请求失败的次数默认为1.当超过最大次数时,返回proxy_next_upstream 模块定义的错误
fail_timeout:max_fails 次失败后,暂停的时间。
backup: 其它所有的非backup机器down或者忙的时候,请求backup机器。所以这台机器压力会最轻。
4. 动静分离
动静不分离时,服务器压力比较大哦
为了加快网站的解析速度,可以把静态页面和动态页面由不同的服务器来解析,降低原来单个服务器的压力。
5. nginx 实现虚拟主机
本地ip是192.168.121.131
可以实现在同一台服务运行多个网站,而且网站之间互相不干扰。
同一个服务器可能有一个ip,网站需要使用80端口。网站的域名不同。
区分不同的网站有三种方式:
1、ip区分
2、端口区
3、分域名区分
7.1 ip区分
需要一台服务器绑定多个ip地址。
- /etc/sysconfig/network-scripts/ifcfg-eth33文件复制一份,命名为ifcfg-eth33:1
修改其中内容:
NAME=ens33:1
DEVICE=eth33:1
IPADDR=192.168.121.132
其他项不用修改
cd /etc/sysconfig/network-scripts
ls
cp ifcfg-ens33 ifcfg-ens33:1
vi ifcfg-ens33:1
2. 重启系统并查看ip
reboot
ifconfig
3. 浏览器访问 192.168.121.132
7.2 基于nginx的配置
一个server就是一个虚拟主机,通过配置nginx中conf/nginx.conf的配置文件,来配置虚拟主机
server 虚拟主机的配置
listen 监听端口
root 根路径
index 打开的页面
命令:在nginx/sbin下执行
./nginx -s reload 重新加载配置文件
./nginx 启动nginx
nginx -t 查看配置文件是否正确
7.2.1 基于ip地址的虚拟主机
7.2.2 基于端口的虚拟主机
server {
listen 81;
server_name localhost;
location / {
root html-138;
index index.html index.htm;
}
location /images/ {
root /home/ftpuser/www;
autoindex on;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
7.2.3 基于域名的虚拟主机
最有用的虚拟主机配置方式。
一个域名只能绑定一个ip地址,一个ip地址可以被多个域名绑定。
- 配置nginx.conf的配置文件,添加一个server
server {
#监听端口
listen 80;
#域名可以有多个,用空格隔开
server_name www.taotao.com;
location / {
root html-www;
index index.html index.htm;
}
location /images/ {
root /home/ftpuser/www;
autoindex on;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
- 创建html-www的文件,在nginx目录下执行
修改标题便于观察,没有实质性作用
cp html/ html-www
vi html-www/index.html
可以修改hosts(C:\Windows\System32\drivers\etc\hosts)文件实现域名访问。
3. 浏览器访问
补充个小知识点:
域名解析:
定义:给一个域名绑定一个ip地址。
域名:ip地址=1:n
流程:
①用户要打开www.baidu.com时,
②首先查看本地DNS服务器,
如果有,则告诉用户,用户ip地址,用户通过ip地址直接访问该网站;
如果没有www.baidu.com的域名,则向下一级继续查找;
③该级查找方式和上一级一样,依此类推,进行查找。
④到最后访问的时DNS根服务器,它记录着所有的域名和ip的映射,
如果查到,则依次写入经过的服务器;
如果没有,不好意思,很抱歉,真的找不到了。