Nginx (engine x) 是一个高性能的Web服务器和反向代理服务器,也可以作为邮件代理服务器。
反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器;
正向代理类似一个跳板机,代理访问外部资源。比如:我是一个用户,我访问不了某网站,但是我能访问一个代理服务器,这个代理服务器,它能访问那个我不能访问的网站,于是我先连上代理服务器,告诉它我需要那个无法访问网站的内容,代理服务器去取回来,然后返回给我。
Nginx 特点是占有内存少,并发处理能力强,以高性能、低系统资源消耗而闻名,Nginx官方测试为5万并发请求。
Nginx的安装需要确定Linux安装相关的几个库,否则配置和编译会出现错误, 具体的检查安装过程为:
yum install gcc openssl openssl-devel pcre pcre-devel zlib zlib-devel -y
将nginx-1.14.2.tar.gz文件上传后,解压下载下来的nginx文件,执行命令:
tar -zxvf nginx-1.14.2.tar.gz
切换至解压后的nginx主目录,执行命令:
cd nginx-1.14.2
在nginx主目录nginx-1.14.2下执行命令 (其中--prefix是指定nginx安装路径) 注意:等号左右不要有空格
./configure --prefix=/usr/local/nginx
执行命令进行编译:
make
执行命令进行安装:
make install
安装成功后,可以切换到/usr/local/nginx目录下,查看内容:
cd /usr/local/nginx
切换到nginx安装目录的sbin目录下,执行:
cd sbin
./nginx
./nginx -c /usr/local/nginx/conf/nginx.conf
/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
其中-c是指定配置文件,而且配置文件路径必须指定绝对路径
通过查看进程:
ps -ef | grep nginx
在开放端口后在外部浏览器访问ip:80可以看到:
找出nginx的进程号:
ps -ef | grep nginx
执行命令:
kill -QUIT 主pid
或者是:(选一个kill来关闭即可)
kill -TERM 主pid
./nginx
当修改Nginx配置文件后,可以使用Nginx命令进行配置文件语法检查,用于检查Nginx配置文件是否正确
/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf -t
查看版本
./nginx -v
在官方网站下载最新windows版的nginx:http://nginx.org/en/download.html
将下载下来的nginx压缩包解压到一个目录下,解压后该软件就可以启动使用了
启动方式1:双击解压目录下的nginx.exe文件即可运行nginx;
启动方式2:进入dos窗口,切换到nginx主目录下,在dos窗口执行命令:start nginx
关闭方式1:在资源管理器杀掉Nginx进程(有两个进程)
关闭方式2:在dos窗口切换到Nginx安装主目录下执行命令:nginx -s stop
学习Nginx首先需要对它的核心配置文件有一定的认识,这个文件位于Nginx的安装目录/usr/local/nginx/conf目录下,名字为nginx.conf
cd /usr/local/nginx/conf
Nginx是一个HTTP的web服务器,可以将服务器上的静态文件(如HTML、CSS、JS、图片等)通过HTTP协议返回给浏览器客户端,找一个简单的web项目上传到linux服务器/opt/static目录下,将名字改为ace
修改nginx.conf配置文件
cd /usr/local/nginx/conf/
为了避免后续使用寻找不到原来的配置,将复制一份nginx.conf配置文件
修改配置的访问路径:
vim 1.static-resource-web.conf
或者使用这个也行:
随后便通过指定的配置文件(1.static-resource-web.conf)来启动Nginx(检查配置文件和启动)
/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/1.static-resource-web.conf -t
/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/1.static-resource-web.conf
最后在外部浏览器即可访问:
在网站创立初期,我们一般都使用单台机器对外提供集中式服务。随着业务量的增大,我们一台服务器不够用,此时就会把多台机器组成一个集群对外提供服务,但是,我们网站对外提供的访问入口通常只有一个,比如 www.web.com。那么当用户在浏览器输入www.web.com进行访问的时候,如何将用户的请求分发到集群中不同的机器上呢,这就是负载均衡要做的事情。
负载均衡通常是指将请求"均匀"分摊到集群中多个服务器节点上执行,这里的均匀是指在一个比较大的统计范围内是基本均匀的,并不是完全均匀。
比如 F5、深信服、Array 等
优点是有厂商专业的技术服务团队提供支持,性能稳定
缺点是费用昂贵,对于规模较小的网络应用成本太高
比如 Nginx、LVS、HAProxy 等
优点是免费开源,成本低廉
Nginx通过在nginx.conf文件进行配置即可实现负载均衡。
配置如下:(配置2步即可)
第一步:在http模块加上upstream配置
upstream www.myweb.com {
server 127.0.0.1:9100 weight=3;
server 127.0.0.1:9200 weight=1;
}
其中weight=1表示权重,用于后端服务器性能不均的情况,访问比率约等于权重之比,权重越大访问机会越多
upstream是配置nginx与后端服务器负载均衡非常重要的一个模块,并且它还能对后端的服务器的健康状态进行检查,若后端服务器中的一台发生故障,则前端的请求不会转发到该故障的机器
第二步:在server模块里添加location,并配置proxy_pass
location /myweb {
proxy_pass http://www.myweb.com;
}
其中 www.myweb.com 字符串要和 upstream 后面的字符串相等