码迷,mamicode.com
首页 > 其他好文 > 详细

Nginx安装及配置

时间:2019-10-27 23:18:05      阅读:190      评论:0      收藏:0      [点我收藏+]

标签:匹配优先级   temp   dir   direct   live   client   ip地址   检查   标识   

Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器,同时也提供了IMAP/POP3/SMTP服务。Nginx是由伊戈尔·赛索耶夫为俄罗斯访问量第二的Rambler.ru站点(俄文:Рамблер)开发的,第一个公开版本0.1.0发布于2004年10月4日。 其将源代码以类BSD许可证的形式发布,因它的稳定性、丰富的功能集、示例配置文件和低系统资源的消耗而闻名。2011年6月1日,nginx 1.0.4发布。 Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,在BSD-like 协议下发行。其特点是占有内存少,并发能力强,事实上nginx的并发能力在同类型的网页服务器中表现较好,中国大陆使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝等。 一、nginx可以实现的功能 1、可以作为静态资源的web服务器、可以缓存文件的资源描述符——加速 2、支持对http、stmp、pop3等多种协议的反向代理 3、支持实现缓存和负载均衡 4、支持fcgi 5、支持uWSCGI 6、支持模块化 7、支持过滤器,对特定文件进行压缩传输 8、支持ssl 9、支持图像大小调整 二.、nginx的特性 1、模块 2、高性能 3、低内存消耗 4、支持热部署 5、支持异步IO 6、支持事件驱动 7、支持内存映射 三、核心模块 1、标准http模块 2、拓展http模块 3、邮件拓展模块 4、第三方模块 四、安装依赖 [root@156 ~]# yum groupinstall "Development Tools" -y [root@156 ~]# yum install pcre-devel openssl openssl-devel -y 五、安装nginx (1)创建nginx的运行用户 [root@156 ~]# groupadd -r nginx [root@156 ~]# useradd -r -s /sbin/nologin -g nginx nginx [root@156 ~]# tar xvf nginx-1.6.2.tar.gz [root@156 ~]# cd nginx-1.6.2 [root@156 nginx-1.6.2]# ./configure --help | more [root@156 nginx-1.6.2]# ./configure --prefix=/usr/local/nginx --conf-path=/etc/nginx/nginx.conf --user=nginx --group=nginx --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --pid-path=/var/run/nginx/nginx.pid --lock-path=/var/lock/nginx.lock --with-http_ssl_module --with-http_stub_status_module --without-http_gzip_module --with-http_mp4_module --with-http_flv_module --http-client-body-temp-path=/var/tmp/nginx/client --http-proxy-temp-path=/var/tmp/nginx/proxy --http-fastcgi-temp-path=/var/tmp/nginx/fcgi [root@156 nginx-1.6.2]# make && make install (2)创建临时文件的保存目录 [root@156 nginx-1.6.2]# mkdir /var/tmp/nginx/{client,proxy,fcgi} -pv mkdir: created directory `/var/tmp/nginxclient‘ mkdir: created directory `/var/tmp/nginxproxy‘ mkdir: created directory `/var/tmp/nginxfcgi‘ (3)启动nginx [root@156 ~]# /usr/local/nginx/sbin/nginx [root@156 ~]# ss -tnl | grep 80 LISTEN 0 128 *:80 [root@156 ~]# lsof -i :80 COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME nginx 8395 root 6u IPv4 20287 0t0 TCP *:http (LISTEN) nginx 8396 nginx 6u IPv4 20287 0t0 TCP *:http (LISTEN) [root@156 ~]# ps aux | grep nginx root 8395 0.0 0.1 44572 1040 ? Ss 22:05 0:00 nginx: master process /usr/local/nginx/sbin/nginx nginx 8396 0.0 0.1 45000 1620 ? S 22:05 0:00 nginx: worker process root 8513 0.0 0.0 103308 848 pts/0 S+ 22:39 0:00 grep nginx 测试:在浏览器上输入 服务器的IP地址即可访问nginx界面,例如 http://192.168.70.156/ nginx配置详解 六、和nginx正常运行相关的配置 1、worker_processes 1; 设置发起几个nginx的worker进程 2、user userName [groupName]; 指定nginx以谁的身份来运行 3、pid /path/to/file pid文件 4、worker_rlimit_nofile number; 设置所有worker进程一共可以打开的文件的最大数量值 (linux上默认每个用户可以打开1024个文件、套接字也是一个文件) 七、nginx性能优化相关配置 5、worker_processes number | auto; 设置发起几个nginx的worker进程 number:应该比物理核心少一个 auto:让系统自动判断 6、worker_cpu_affinity cpumask ……| auto; 设置cpu掩码,将worker进程绑定在一个固定的cpu 举例: worker_processes 4; worker_cpu_affinity 0001 0010 0100 1000; 举例: worker_processes 2; worker_cpu_affinity 0001 0100; 注意:可以用auto,但是是1.9.10之后可以用 7、time_resolution interval; 降低发起系统调用gettimeofday()次数 time_resolution 100ms; 8、worker_priority number; 修改worker进程的nice值(默认是0) 八、和事件相关的配置 9、accept_mutex on | off 设置master进程将客户端的请求调度到worker进程的 调度方式:轮询、随机 on:使用轮询 默认方式:off 10、accept_mutex_delay time; 默认500ms 设置master延迟多久才将客户端的请求调度到worker进程 11、user [epoll|poll|select] 通常是不需要指定连接的处理方法(起始就是所使用的事件模型)的 建议让系统自动判断所要使用的方法 12、worker_connections number; 指定每个worker进程可以处理的最大并发连接的数量 默认是1024 13、master_process on | off; 指定是否使用master-worker 默认是:on 九、和调试和定位bug相关配置 14、damon off | on 指定nginx工作在前台还是后台 默认是 on 15、error_log file [level]; 指定错误日志的保存位置以及日志级别 总结:经常要修改的参数 worker_processes worker_connections worker_cpu_affinity worker_priority 十、和http相关的配置 [root@156 ~]# vim /etc/profile.d/nginx.sh export PATH=$PATH:/usr/local/nginx/sbin [root@156 ~]# source /etc/profile.d/nginx.sh [root@156 ~]# nginx [root@156 ~]# nginx -s reload [root@156 ~]# ss -tnl | grep 80 上下文:http {指令} 例子:http{ 全局配置:对所有的虚拟主机都生效的配置 sendfile on; keepalive_timeout 10; …… 虚拟主机配置 server{ listen 80;指定该虚拟主机所监听的端口 server_name www.lichao.com;指定虚拟主机的域名 root /vhost/web1;指定虚拟主机的网站根目录 location /{ } } server{ } } 16、server_name 设定虚拟主机的域名,可以使用正则表达式来表示域名 适用范围:server上下文中 server{ server_name www.zxhk.com; } server { server_name *.zxhk.com; } server { server_name www.zxhk.*; } server { server_name *; } server { server_name ~ ^.*\.www.zxhk.com; } www.zxhk.com 注意:nginx在进行域名匹配的时候,是有一定的规则,匹配次序如下 1、做精确匹配,server_name中的内容必须和用户请求的内容完全一样 2、检查左侧的通配符 3、检查右侧的通配符 4、检查通配符 5、检查正则表达式 6、通过所有检查都失败,则访问default_server,如果没有指定default_server, 那么第一个server就是default_server 17、listen 指定所监听的套接字 例子: listen 127.0.0.1:80; listen 172.0.0.1; listen 80; listen *:80; listen localhost:80; 18、root 指定网站根目录 使用范围:http、server、location 注意:如果将root写在了http部分,则会对全部的server都有效 例子: [root@156 ~]# cd /etc/nginx/ [root@156 nginx]#cp nginx.conf{,.bak} [root@156 nginx]#vim nginx.conf [root@156 ~]# mkdir -pv /vhost/web1 [root@156 ~]# echo "<h1>test for web1</h1>">/vhost/web1/index.html [root@156 ~]# cat /vhost/web1/index.html [root@156 ~]# nginx -s reload http://192.168.70.156/ test for web1 19、location location [ = | ~ | ~* | ^~ ] uri {……} url:统一资源定位符 uri:统一资源标识符 server{ server_name www.zxhk.com; listen 80; location / { root /vhost/web1; } } 这里的location的含义就是将用户所访问的根映射为/vhost/web1路径 有多个location的例子 server{ server_name www.zxhk.com; listen 80; location / { root /vhost/web1; } location /img/ { root /tmp/img; } location ~ \.php$ { root /phpfile; } } location作路径映射的时候,有多种方式 不带符号 = ~ ~* ^~ 1、不带符号,如下 location /img { root /vhost/web1; } http://www.baidu.com/img http://www.baidu.com/a.html 2、= 表示的是精确匹配 location = /img { root /vhost/web1; } 要求只有用户所请求的uri和location所指定的uri必须 完全一致,否则匹配失败,如下 http://www.baidu.com/img <<匹配成功 http://www.baidu.com/img/index.html <<匹配失败 3、~表示对用户所请求的uri做正则表达式,检查过程中区分大小写 location ~ .jgp$ { root /vhost/web1; } 4、~*表示对用户所请求的uri做正则表达式,检查过程中不区分大小写 5、^~不对用户所请求的uri做正则表达式检查,而是只检查uri的左半部分 各种写法的优先级 精确匹配优先级最高(=) uri的左半部检查 区分大小写的正则表达式检查 不区分大小写的正则表达式检查 不带符号的location location /img { root /vhost/web1; } [root@156 ~]# cd /vhost/web1/ [root@156 web1]# mkdir img [root@156 web1]# echo "this is test" >index.html [root@156 web1]# echo "this is image" >img/index.html http://192.168.70.156/ this is test http://192.168.70.156/img/index.html this is image [root@156 ~]# vim /etc/nginx/nginx.conf server { listen 80; server_name www.zxhk.com; location / { root /vhost/web1/; } location /img/ { root /vhost/web2/; } } [root@156 ~]# cd /vhost/ [root@156 vhost]# mkdir web2 [root@156 vhost]# echo "this is web2" > web2/index.html [root@156 vhost]# source /etc/profile.d/nginx.sh [root@156 vhost]# nginx -s reload http://192.168.70.156/img 404 Not Found [root@156 vhost]# vim /var/log/nginx/error.log 2019/09/05 08:52:38 [error] 1915#0: *1 open() "/vhost/web1/favicon.ico" failed (2: No such file or directory), [root@156 vhost]# cd web2/ [root@156 web2]# ls index.html [root@156 web2]# mkdir img [root@156 web2]# mv index.html img/ http://192.168.70.156/img this is web2 20、alias path 将用户所请求的uri映射为一个指定的路径 server { listen 80; server_name www.zxhk.com; location /img1/ { root /vhost/web1/; } location /img2/ { alias /vhost/web1/; } } cd /vhost/web1 ls echo "/vhost/web1">index.html mkdir img1 echo "/vhost/web1/img1">img1/index.html source /etc/profile.d/nginx.sh nginx -t nginx -s reload ls mkdir img2 echo "/vhost/web2/img/2">img2/index.html tree http://192.168.70.156/img2/ /vhost/web1 http://192.168.70.156/img2 404 Not Found vim /var/log/nginx/error.log 2019/09/05 09:51:08 [error] 2392#0: *13 open() "/usr/local/nginx/html/img2" failed (2: No such file or directory), client: 192.168.70.1, server: www.zxhk.com, request: "GET /img2 HTTP/1.1", host: "192.168.70.156"

Nginx安装及配置

标签:匹配优先级   temp   dir   direct   live   client   ip地址   检查   标识   

原文地址:https://blog.51cto.com/14015577/2445810

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!