Nginx源码安装与调优

概述

Nginx 是一个高性能的 HTTP 和 反向代理服务器。
Nginx能够选择高效的epoll(Linux2.6内核)作为网络I/O)模型,在高连接并发的情况下,Nginx是Apache服务器不错的替代品,它能够支持高达5000个并发连接数的响应,而内存、CPU等系统资源消耗却非常低,运行非常稳定。

nginx的官方网站

http://nginx.org/en/download.html

Mainline version 主线版本
Stable version 稳定版本
Legacy versions 遗产版本 /历史版本
版本命名的常识:偶数为稳定,奇数是测试版或开发版本

解析PHP文件的区别

nginx或apache 服务器本身可以解析php文件吗?
apache和nginx在处理php代码时有什么区别?

Nginx是通过php-fpm这个服务来处理php文件
Apache是通过libphp5.so这个模块来处理php文件

Nginx

图片来源于网络

Apache

图片来源于网络

总结:
Apache的libphp5.so随着apache服务器一起运行,而Nginx和php-fpm是各自独立运行,所以在运行过程中,Nginx和php-fpm都需要分别启动!

nginx相对于apache的优点

轻量级,同样起web 服务,比apache 占用更少的内存及资源 ;

高并发,nginx 处理请求是异步非阻塞的,而apache 则是阻塞型的,在高并发下nginx 能保持低资源低消耗高性能;

高度模块化的设计,编写模块相对简单;

社区活跃,各种高性能模块出品迅速。

apache 相对于nginx 的优点

apache超稳定 ,一般来说,需要并发性高的web 服务,用nginx 。如果不需要性能只求稳定,那就apache 。

nginx处理动态请求是鸡肋,一般动态请求要apache去做,nginx只适合静态和反向。

安装nginx

1、安装nginx时必须先安装相应的编译工具

[root@localhost ~]# yum -y install gcc gcc-c++ autoconf automake 
[root@localhost ~]#yum -y install zlib zlib-devel openssl openssl-devel pcre pcre-devel

2、安装文件上传工具 lrzsz

[root@VM_113_253_centos ~]# yum install lrzsz -y

3、解压文件并创建用户 nginx

[root@localhost ~]# tar zxvf nginx-1.16.2.tar.gz

4、编译安装三部曲

[root@localhost nginx-1.16.2]# ./configure --prefix=/usr/local/nginx   --user=nginx --group=nginx --with-http_ssl_module --with-http_realip_module  --with-http_gzip_static_module  --with-pcre       #检查编译环境

检查是否执行成功

[root@localhost nginx-1.16.2]# echo $?
0

# 在进行源代码编译,或者执行命令无法确认所执行的命令是否成功执行的情况下,我们都会使用 echo $? 来进行测试
# 如果返回值是0,就是执行成功;如果是返回值是0以外的值,就是失败。

编译和安装

[root@localhost nginx-1.16.2]# make -j 4    #编译,把源代码编译成可执行的二进制文件。

-j 4  # 以4个进程同时编
​
[root@localhost nginx-1.16.2]# make  install   #安装

nginx主要目录结构

[root@VM_113_253_centos nginx-1.16.2]# ls /usr/local/nginx/
conf  html  logs  sbin
​
conf  #配置文件
html  #网站根目录
logs  #日志
sbin  #nginx启动脚本

启动nginx

[root@localhost ~]# /usr/local/nginx/sbin/nginx

测试

 curl localhost

Nginx 调优--隐藏版本信息

为什么要屏蔽nginx版本信息?

答:因为黑客可以扫描出nginx版本信息,可以查看对应的版本信息的漏洞,然后攻击

如何查nginx版本信息?

[root@localhost ~]# curl -I www.baidu.com 

Nginx ****漏洞

image

查看其他服务器

[root@localhost nginx-1.16.0]# curl -I processon.com
HTTP/1.1 302 Moved Temporarily
Server: nginx/1.16.2     #这里暴露了目标信息
Date: Sat, 22 Jun 2019 13:44:01 GMT
Content-Type: text/html
Content-Length: 161
Connection: keep-alive
Location: https://processon.com/
X-Cdn-Request-ID: c6ce60c84d701a64508c7677e5fb5f83  

查看自己的服务器

[root@localhost nginx-1.16.0]# curl -I localhost
HTTP/1.1 200 OK
Server: nginx/1.16.0     #这里暴露了目标信息
Date: Sat, 22 Jun 2019 13:45:54 GMT
Content-Type: text/html
Content-Length: 612
Last-Modified: Sat, 22 Jun 2019 13:12:32 GMT
Connection: keep-alive
ETag: "5d0e2940-264"
Accept-Ranges: bytes

彻底让版本等敏感信息消失

1、更改源码隐藏软件名称和版本号

[root@VM_113_253_centos nginx-1.16.2]# cd /root/nginx-1.16.2
[root@localhost nginx-1.9.12]# vim src/core/nginx.h    //目的更改源码隐藏软件名称和版本号

13行

#define NGINX_VERSION       "1.1.1"                 #此行修改的是你想要的版本号
#define NGINX_VER          "MWS/" NGINX_VERSION   #此行修改的是你想修改的软件名称

2、修改HTTP头信息中的connection字段,防止回显具体版本号

[root@localhost nginx-1.16.2]# vim src/http/ngx_http_header_filter_module.c

49行

改:static char ngx_http_server_string[] = "Server: nginx" CRLF;
为: static char ngx_http_server_string[] = "Server: MWS" CRLF;

3、修改报错

这个文件定义了http错误码的返回,有时候我们页面程序出现错误,Nginx会代我们返回相应的错误代码,回显的时候,会带上nginx和版本号,我们把他隐藏起来

[root@localhost nginx-1.16.2]# vim src/http/ngx_http_special_response.c

29行

static u_char ngx_http_error_full_tail[] =
"<hr><center>" NGINX_VER "</center>" CRLF
"</body>" CRLF
"</html>" CRLF
;
​
static u_char ngx_http_error_tail[] =
"<hr><center>MWS</center>" CRLF
"</body>" CRLF
"</html>" CRLF
;

重新进行nginx安装

[root@VM_113_253_centos ~]# /usr/local/nginx/sbin/nginx -s stop
[root@VM_113_253_centos ~]# rm -rf /usr/local/nginx/
[root@VM_113_253_centos nginx-1.16.2]# pwd
/root/nginx-1.16.2
[root@VM_113_253_centos nginx-1.16.2]# make clean 
rm -rf Makefile objs

编译和安装

[root@localhost nginx-1.16.2]# ./configure --prefix=/usr/local/nginx   --user=nginx --group=nginx --with-http_ssl_module --with-http_realip_module  --with-http_gzip_static_module  --with-pcre  && make && make install 

启动服务

[root@localhost nginx]# /usr/local/nginx/sbin/nginx

测试是否隐藏了版本和软件名

[root@localhost nginx-1.16.0]# curl -I localhost
HTTP/1.1 200 OK
Server: MWS/1.1.1
Date: Sat, 22 Jun 2019 13:57:46 GMT
Content-Type: text/html
Content-Length: 612
Last-Modified: Sat, 22 Jun 2019 13:54:20 GMT
Connection: keep-alive
ETag: "5d0e330c-264"
Accept-Ranges: bytes

访问不存在的页面

[root@localhost nginx-1.16.0]# curl localhost/a.html
<html>
<head><title>404 Not Found</title></head>
<body>
<center><h1>404 Not Found</h1></center>
<hr><center>MWS/1.1.1</center>
</body>
</html>
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 162,710评论 4 376
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 68,839评论 2 308
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 112,295评论 0 255
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,776评论 0 223
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 53,198评论 3 297
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 41,074评论 1 226
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 32,200评论 2 322
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,986评论 0 214
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,733评论 1 250
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,877评论 2 254
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,348评论 1 265
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,675评论 3 265
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,393评论 3 246
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,209评论 0 9
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,996评论 0 201
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 36,212评论 2 287
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 36,003评论 2 280

推荐阅读更多精彩内容