Linux版本: CentOS7 64位

nginx 安装

在安装nginx前首先要确认系统中安装了gcc、pcre-devel、zlib-devel、openssl-devel。安装的命令如下:

1
yum -y install gcc pcre-devel zlib-devel openssl openssl-devel

nginx 下载地址:http://nginx.org/download
下载:“nginx-1.9.9.tar.gz” 移动到/usr/local/ 下。

1
2
3
4
5
6
7
8
9
10
11
12
## 解压
tar -zxvf nginx-1.9.9.tar.gz

##进入nginx 目录:
cd nginx-1.9.9

##配置
./configure --prefix=/usr/local/nginx

## make
make
make install

注解:源码的安装一般有3个步骤组成:配置(configure)、编译(make)、安装(makeinstall)。 Configure是一个可执行脚本,它有很多选项,在待安装的源码路径下使用命令./configure -–help输出详细的选项列表。其中--prefix选项是配置安装的路径,如果不配置该选项,安装后可执行文件默认放在/usr/local/bin,库文件默认放在/usr/local/lib,配置文件默认放在/usr/local/etc,其它的资源文件放在/usr/local/share,比较凌乱。如果配置–prefix,如:./configure --prefix=/usr/local/nginx
可以把所有资源文件放在/usr/local/nginx的路径中,不会杂乱。
用了—prefix选项的另一个好处是卸载软件或移植软件。当某个安装的软件不再需要时,只须简单的删除该安装目录,就可以把软件卸载得干干净净;移植软件只需拷贝整个目录到另外一个机器即可(相同的操作系统)。

测试是否安装成功:

1
2
## cd 到安装目录 /usr/local/nginx
./sbin/nginx -t

安装成功的显示:

启动nginx:

1
2
cd /usr/local/nginx/sbin
./nginx

在浏览器输入ip 地址就可以看到结果了

修改默认访问地址:



根据访问路径在相应的位置创建好的文件夹:放入测试文件

重启nginx 服务:

1
2
## 进入到 /usr/local/nginx/sbin
./nginx -s reload

常用命令

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15

#查看nginx 的版本:
./nginx -v

#关闭nginx:
./nginx -s stop

# 启动nginx:
./nginx

#查看nginx的进程:
ps -ef | grep nginx

#重启nginx:
./nginx -s reload

配置文件

/usr/local/nginx/conf/nginx.conf

组成部分

全局块

从配置文件开始到events块之间的内容,主要会设置一些影响nginx服务器整体运行的配置指令。例如:
worker_processes 1 支持的并发处理量

events块

影响Nginx服务器与用户的网络链接,例如:
worker_connections 1024 支持最大链接数

http块

配置实例:

  1. 反向代理

prooxy_pass http://127.0.0.1:8080
访问ip 跳转到8080端口

  • 根据路径跳转到不同的端口

再写一个server

  1. 负载均衡

分配策略

  • 轮询策略 :每个请求安时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。默认策略
  • weight : 权重,默认为1,权重越高被分配的客户端越多
  • ip_hash : 每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器
  • fair(第三方):按后端服务器的响应时间来分配请求,响应时间短的服务优先分配

动静分离

动静分离:动态请求 和 静态请求 的两种请求。 两种方式 分开发布, 合并发布,用nginx分开

通过location 指定不同的后缀名实现不同的请求转发。通过expires 参数设置,可以

autoindex on; 列出文件夹下的列表

高可用

需要两台ngnix、keepalived、 虚拟ip.

1
2
3
4
5
6
7
8
9
10
## 安装keepalived
yum install keepalived -y

##启动keeplived
systemctl start keepalived.service

##停止keeplived
systemctl stop keeplived.service

##安装目录配置文件在:/etc/keepalived/keepalived.conf
  • 配置高可用
1
2
3
4
5
6
## 网卡查看:
ifconfig

## 查看主机与配置
vi /etc/hosts
## 添加:127.0.0.1 LVS_DEVEL (随便写)

keepalived.conf

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
## 全局配置
global_defs {
notification_email {
acassen@firewall.loc
failover@firewall.loc
sysadmin@firewall.loc
}
notification_email_from Alexandre.Cassen@firewall.loc
smtp_server 192.168.17.129
smtp_connect_timeout 30
router_id LVS_DEVEL ## 访问的主机
}
## 脚本配置
vrrp_script chk_http_port {
script "/usr/local/src/nginx_check.sh"
interval 2 #(检测脚本执行的间隔)
weight 2 # 权重
}

##虚拟ip 配置
vrrp_instance VI_1 {
state BACKUP # 备份服务器上将 MASTER 改为 BACKUP
interface ens33 # 网卡
virtual_router_id 51 # 主、备机的 virtual_router_id 必须相同
priority 90 # 主、备机取不同的优先级,主机值较大,备份机值较小
advert_int 1 # 每隔1秒发送一个心跳
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
192.168.17.50 # VRRP H 虚拟地址
}
}

/usr/local/src 添加检测脚本:nginx_check.sh

1
2
3
4
5
6
7
8
9
10
 #!/bin/bash
A=`ps -C nginx – no-header |wc -l`
if [ $A -eq 0 ];then
/usr/local/nginx/sbin/nginx
sleep 2
if [ `ps -C nginx --no-header |wc -l` -eq 0 ];then
killall keepalived
fi
fi

nginx 工作原理

1
2
## 查看nginx 进程
ps -ef |grep nginx


  • 首先,对于每个 worker 进程来说,独立的进程,不需要加锁,所以省掉了锁带来的开销,同时在编程以及问题查找时,也会方便很多。

  • 其次,采用独立的进程,可以让互相之间不会影响,一个进程退出后,其它进程还在工作,服务不会中断, master 进程则很快启动新的worker进程。

  • 当然, worker 进程的异常退出,肯定是程序有 bug 了,异常退出,会导致当前 worker 上的所有请求失败,不过不会影响到所有请求,所以降低了风险

参考:https://www.cnblogs.com/xxoome/p/5866475.html