Nginx
Nevermore 2023-12-17 CNET
# 安装
下载 (opens new window)后解压到相应目录
安装依赖库:libz-dev libprce3-dev libssl-dev
生成安装文件(root)
./configure --prefix=path #/usr/local/nginx make make install #会将make生成的文件copy到path
1
2
3将./contrib/vim文件拷贝到.vim中
# 第三方模块
拉取对应的模块,如nginx-rtmp-module (opens new window)
将模块添加到配置文件:./configure --add-dynamic-module=/ModulePath
make modules,在objs目录里有生成的文件,若有.so文件,将其拷贝到/usr/local/nginx/modules/
配置文件首行添加:load_module modules/动态库名字
# 基本使用
sbin/nginx
- -v/-V :版本信息
- -c :指定配置文件
- -t :检查配置文件语法错误
- -s :quit(优雅关闭) stop(立即关闭) reload
不能同时启动两个nginx进程,pid都会存到同一个pid_file里;若一定要启动两个,将pid打开,将两个nginx进程的pid存储到不同名字的文件,日志文件最好也修改。
# 配置文件
【1】MDN (opens new window)type查询
【3】正则匹配:location ~* /(.*)a
忽略大小写~后的*;
配置注释
#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; # 启动服务的pid
events {
worker_connections 1024; # 每个进程允许的最大连接数,最大65535
}
http {
include mime.types; # http首部字段MIME类型与文件后缀名的映射关系 【1】
default_type application/octet-stream;
# 格式查看 【2】
#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 / { # 前缀匹配【3】uri的path
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;
# }
#}
}
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
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
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
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
# 反向代理
upstream backend{ #目标服务器
server 127.0.0.1:8080;
# server 127.0.0.1:8081 weight = 3; #可以设置服务器的权重
# ... 添加多个服务器可以使用负载均衡
}
server {
listen 80;
server_name localhost;
location / {
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
# proxy_pass http://localhost:8080; # 代理转发
proxy_pass backend;
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17