Tengine 是淘宝网基于 Nginx 开发的高性能 Web 服务器,针对大规模互联网场景进行了优化增强。本文基于 CentOS 7.6 环境,系统介绍 Tengine 2.3.2 的源码编译安装与完整配置流程。内容涵盖编译参数详解(--with-http_ssl_module、--with-http_realip_module、--with-jemalloc 等)、依赖安装、模块化配置(主配置与 conf.d 拆分)、HTTP 反向代理配置(upstream 负载均衡组),以及 HTTPS 配置(80 强制跳转 443、SSL 证书与加密套件配置)。同时提供配置检查、服务启动与热重启等运维命令。
本文适用于需要在生产环境部署 Tengine/Nginx 并配置 HTTP/HTTPS 反向代理的运维开发人员。
shell[root@localhost ~]# cat /etc/redhat-release CentOS Linux release 7.6.1810 (Core)
shellwget http://tengine.taobao.org/download/tengine-2.3.2.tar.gz
text–prefix= 指向安装目录 –sbin-path 指向(执行)程序文件(nginx) –conf-path= 指向配置文件(nginx.conf) –error-log-path= 指向错误日志目录 –pid-path= 指向pid文件(nginx.pid) –lock-path= 指向lock文件(nginx.lock)(安装文件锁定,防止安装文件被别人利用,或自己误操作。) –user= 指定程序运行时的非特权用户 –group= 指定程序运行时的非特权用户组 –builddir= 指向编译目录 –with-rtsig_module 启用rtsig模块支持(实时信号) –with-select_module 启用select模块支持(一种轮询模式,不推荐在高载环境下使用)禁用:–without-select_module –with-poll_module 启用poll模块支持(功能与select相同,与select特性相同,为一种轮询模式,不推荐在高载环境下使用) –with-file-aio 启用file aio支持(一种APL文件传输格式) –with-ipv6 启用ipv6支持 –with-http_ssl_module 启用ngx_http_ssl_module支持(使支持https请求,需已安装openssl) –with-http_realip_module 启用ngx_http_realip_module支持(这个模块允许从请求标头更改客户端的IP地址值,默认为关) –with-http_addition_module 启用ngx_http_addition_module支持(作为一个输出过滤器,支持不完全缓冲,分部分响应请求) –with-http_xslt_module 启用ngx_http_xslt_module支持(过滤转换XML请求) –with-http_image_filter_module 启用ngx_http_image_filter_module支持(传输JPEG/GIF/PNG 图片的一个过滤器)(默认为不启用。gd库要用到) –with-http_geoip_module 启用ngx_http_geoip_module支持(该模块创建基于与MaxMind GeoIP二进制文件相配的客户端IP地址的ngx_http_geoip_module变量) –with-http_sub_module 启用ngx_http_sub_module支持(允许用一些其他文本替换nginx响应中的一些文本) –with-http_dav_module 启用ngx_http_dav_module支持(增加PUT,DELETE,MKCOL:创建集合,COPY和MOVE方法)默认情况下为关闭,需编译开启 –with-http_flv_module 启用ngx_http_flv_module支持(提供寻求内存使用基于时间的偏移量文件) –with-http_gzip_static_module 启用ngx_http_gzip_static_module支持(在线实时压缩输出数据流) –with-http_random_index_module 启用ngx_http_random_index_module支持(从目录中随机挑选一个目录索引) –with-http_secure_link_module 启用ngx_http_secure_link_module支持(计算和检查要求所需的安全链接网址) –with-http_degradation_module 启用ngx_http_degradation_module支持(允许在内存不足的情况下返回204或444码) –with-http_stub_status_module 启用ngx_http_stub_status_module支持(获取nginx自上次启动以来的工作状态) –without-http_charset_module 禁用ngx_http_charset_module支持(重新编码web页面,但只能是一个方向–服务器端到客户端,并且只有一个字节的编码可以被重新编码) –without-http_gzip_module 禁用ngx_http_gzip_module支持(该模块同-with-http_gzip_static_module功能一样) –without-http_ssi_module 禁用ngx_http_ssi_module支持(该模块提供了一个在输入端处理处理服务器包含文件(SSI)的过滤器,目前支持SSI命令的列表是不完整的) –without-http_userid_module 禁用ngx_http_userid_module支持(该模块用来处理用来确定客户端后续请求的cookies) –without-http_access_module 禁用ngx_http_access_module支持(该模块提供了一个简单的基于主机的访问控制。允许/拒绝基于ip地址) –without-http_auth_basic_module禁用ngx_http_auth_basic_module(该模块是可以使用用户名和密码基于http基本认证方法来保护你的站点或其部分内容) –without-http_autoindex_module 禁用disable ngx_http_autoindex_module支持(该模块用于自动生成目录列表,只在ngx_http_index_module模块未找到索引文件时发出请求。) –without-http_geo_module 禁用ngx_http_geo_module支持(创建一些变量,其值依赖于客户端的IP地址) –without-http_map_module 禁用ngx_http_map_module支持(使用任意的键/值对设置配置变量) –without-http_split_clients_module 禁用ngx_http_split_clients_module支持(该模块用来基于某些条件划分用户。条件如:ip地址、报头、cookies等等) –without-http_referer_module 禁用disable ngx_http_referer_module支持(该模块用来过滤请求,拒绝报头中Referer值不正确的请求) –without-http_rewrite_module 禁用ngx_http_rewrite_module支持(该模块允许使用正则表达式改变URI,并且根据变量来转向以及选择配置。如果在server级 别设置该选项,那么他们将在 location之前生效。如果在location还有更进一步的重写规则,location部分的规则依然会被执行。如果这个URI重写是因为 location部分的规则造成的,那么 location部分会再次被执行作为新的URI。 这个循环会执行10次,然后Nginx会返回一个500错误。) –without-http_proxy_module 禁用ngx_http_proxy_module支持(有关代理服务器) –without-http_fastcgi_module 禁用ngx_http_fastcgi_module支持(该模块允许Nginx 与FastCGI 进程交互,并通过传递参数来控制FastCGI 进程工作。 )FastCGI一个常驻型的公共网关接口。 –without-http_uwsgi_module 禁用ngx_http_uwsgi_module支持(该模块用来医用uwsgi协议,uWSGI服务器相关) –without-http_scgi_module 禁用ngx_http_scgi_module支持(该模块用来启用SCGI协议支持,SCGI协议是CGI协议的替代。它是一种应用程序与HTTP服务接口标准。它有些像FastCGI但他的设计 更容易实现。) –without-http_memcached_module 禁用ngx_http_memcached_module支持(该模块用来提供简单的缓存,以提高系统效率) -without-http_limit_zone_module 禁用ngx_http_limit_zone_module支持(该模块可以针对条件,进行会话的并发连接数控制) –without-http_limit_req_module 禁用ngx_http_limit_req_module支持(该模块允许你对于一个地址进行请求数量的限制用一个给定的session或一个特定的事件) –without-http_empty_gif_module 禁用ngx_http_empty_gif_module支持(该模块在内存中常驻了一个1*1的透明GIF图像,可以被非常快速的调用) –without-http_browser_module 禁用ngx_http_browser_module支持(该模块用来创建依赖于请求报头的值。如果浏览器为modern ,则$modern_browser等于modern_browser_value指令分配的值;如 果浏览器为old,则$ancient_browser等于 ancient_browser_value指令分配的值;如果浏览器为 MSIE中的任意版本,则 $msie等于1) –without-http_upstream_ip_hash_module 禁用ngx_http_upstream_ip_hash_module支持(该模块用于简单的负载均衡) –with-http_perl_module 启用ngx_http_perl_module支持(该模块使nginx可以直接使用perl或通过ssi调用perl) –with-perl_modules_path= 设定perl模块路径 –with-perl= 设定perl库文件路径 –http-log-path= 设定access log路径 –http-client-body-temp-path= 设定http客户端请求临时文件路径 –http-proxy-temp-path= 设定http代理临时文件路径 –http-fastcgi-temp-path= 设定http fastcgi临时文件路径 –http-uwsgi-temp-path= 设定http uwsgi临时文件路径 –http-scgi-temp-path= 设定http scgi临时文件路径 -without-http 禁用http server功能 –without-http-cache 禁用http cache功能 –with-mail 启用POP3/IMAP4/SMTP代理模块支持 –with-mail_ssl_module 启用ngx_mail_ssl_module支持 –without-mail_pop3_module 禁用pop3协议(POP3即邮局协议的第3个版本,它是规定个人计算机如何连接到互联网上的邮件服务器进行收发邮件的协议。是因特网电子邮件的第一个离 线协议标 准,POP3协议允许用户从服务器上把邮件存储到本地主机上,同时根据客户端的操作删除或保存在邮件服务器上的邮件。POP3协议是TCP/IP协议族中 的一员,主要用于 支持使用客户端远程管理在服务器上的电子邮件) –without-mail_imap_module 禁用imap协议(一种邮件获取协议。它的主要作用是邮件客户端可以通过这种协议从邮件服务器上获取邮件的信息,下载邮件等。IMAP协议运行在 TCP/IP协议之上, 使用的端口是143。它与POP3协议的主要区别是用户可以不用把所有的邮件全部下载,可以通过客户端直接对服务器上的邮件进行操作。) –without-mail_smtp_module 禁用smtp协议(SMTP即简单邮件传输协议,它是一组用于由源地址到目的地址传送邮件的规则,由它来控制信件的中转方式。SMTP协议属于 TCP/IP协议族,它帮助每台计算机在发送或中转信件时找到下一个目的地。) –with-google_perftools_module 启用ngx_google_perftools_module支持(调试用,剖析程序性能瓶颈) –with-cpp_test_module 启用ngx_cpp_test_module支持 –add-module= 启用外部模块支持 –with-cc= 指向C编译器路径 –with-cpp= 指向C预处理路径 –with-cc-opt= 设置C编译器参数(PCRE库,需要指定–with-cc-opt=”-I /usr/local/include”,如果使用select()函数则需要同时增加文件描述符数量,可以通过–with-cc- opt=”-D FD_SETSIZE=2048”指定。) –with-ld-opt= 设置连接文件参数。(PCRE库,需要指定–with-ld-opt=”-L /usr/local/lib”。) –with-cpu-opt= 指定编译的CPU,可用的值为: pentium, pentiumpro, pentium3, pentium4, athlon, opteron, amd64, sparc32, sparc64, ppc64 –without-pcre 禁用pcre库 –with-pcre 启用pcre库 –with-pcre= 指向pcre库文件目录 –with-pcre-opt= 在编译时为pcre库设置附加参数 –with-md5= 指向md5库文件目录(消息摘要算法第五版,用以提供消息的完整性保护) –with-md5-opt= 在编译时为md5库设置附加参数 –with-md5-asm 使用md5汇编源 –with-sha1= 指向sha1库目录(数字签名算法,主要用于数字签名) –with-sha1-opt= 在编译时为sha1库设置附加参数 –with-sha1-asm 使用sha1汇编源 –with-zlib= 指向zlib库目录 –with-zlib-opt= 在编译时为zlib设置附加参数 –with-zlib-asm= 为指定的CPU使用zlib汇编源进行优化,CPU类型为pentium, pentiumpro –with-libatomic 为原子内存的更新操作的实现提供一个架构 –with-libatomic= 指向libatomic_ops安装目录 –with-openssl= 指向openssl安装目录 –with-openssl-opt 在编译时为openssl设置附加参数 –with-debug 启用debug日志
shellmv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo_bak curl http://mirrors.aliyun.com/repo/Centos-7.repo > /etc/yum.repos.d/CentOS-Base.repo curl http://mirrors.aliyun.com/repo/epel-7.repo > /etc/yum.repos.d/epel.repo sed -i -e '/mirrors.cloud.aliyuncs.com/d' -e '/mirrors.aliyuncs.com/d' /etc/yum.repos.d/CentOS-Base.repo sed -i -e '/mirrors.cloud.aliyuncs.com/d' -e '/mirrors.aliyuncs.com/d' /etc/yum.repos.d/epel.repo yum clean all yum makecache tar -xzvf tengine-2.3.2.tar.gz cd tengine-2.3.2 yum install pcre-devel openssl-devel jemalloc-devel -y ./configure --prefix=/usr/local/nginx --user=odboy --group=odboy --with-pcre --with-jemalloc --with-http_ssl_module --with-http_realip_module --with-http_gzip_static_module --with-http_stub_status_module
textcreating objs/Makefile Configuration summary + using system PCRE library + using system OpenSSL library + using system zlib library + using system jemalloc library nginx path prefix: "/usr/local/nginx" nginx binary file: "/usr/local/nginx/sbin/nginx" nginx modules path: "/usr/local/nginx/modules" nginx configuration prefix: "/usr/local/nginx/conf" nginx configuration file: "/usr/local/nginx/conf/nginx.conf" nginx pid file: "/usr/local/nginx/logs/nginx.pid" nginx error log file: "/usr/local/nginx/logs/error.log" nginx http access log file: "/usr/local/nginx/logs/access.log" nginx http client request body temporary files: "client_body_temp" nginx http proxy temporary files: "proxy_temp" nginx http fastcgi temporary files: "fastcgi_temp" nginx http uwsgi temporary files: "uwsgi_temp" nginx http scgi temporary files: "scgi_temp"
shell[root@localhost tengine-2.3.2]# make
......
make[1]: Leaving directory '/usr/local/tengine-2.3.2'
# 这里的make[1]直接忽略,然后执行make install
[root@localhost tengine-2.3.2]# make install
# 这里很快就执行完了,然后需要查看路径"/usr/local/nginx"存不存在,如果存在则编译成功,失败则编译失败
[root@localhost tengine-2.3.2]# cd /usr/local/nginx
[root@localhost nginx]# ls
conf html logs sbin
shell[root@localhost nginx]# cd /usr/local/nginx/conf
[root@localhost conf]# echo '' > nginx.conf
[root@localhost conf]# vi nginx.conf
# 复制粘贴以下内容
# ------------------ start
user root;
worker_processes auto;
events {
worker_connections 10240;
}
http {
include mime.types;
default_type application/octet-stream;
log_format main '"$http_x_forwarded_for" $remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for" "$upstream_addr"';
#access_log logs/access.log main;
sendfile on;
keepalive_timeout 65;
include /usr/local/nginx/conf/conf.d/*.conf;
}
# ------------------ end
# wq保存,退出
# 新建conf.d目录
[root@localhost conf]# mkdir conf.d
shell[root@localhost conf]# cd conf.d
[root@localhost conf]# vi www.odboy.cn.conf
# ------------------ start
# 组名为"www",四节点均衡负载
upstream www {
server localhost:8080 weight=10;
server localhost:8081 weight=10;
server localhost:8082 weight=10;
server localhost:8083 weight=10;
}
server {
listen 80;
server_name www.odboy.cn;
client_max_body_size 20m;
charset utf-8;
access_log /odboy/logs/www.odboy.cn_http_accesss.log main;
location / {
# 这里的www即为upstream的组名
proxy_pass http://www;
proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $remote_addr;
proxy_set_header X-Forwarded-Host $server_name;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
client_max_body_size 10m;
client_body_buffer_size 128k;
proxy_connect_timeout 90;
proxy_send_timeout 90;
proxy_read_timeout 90;
proxy_buffer_size 4k;
proxy_buffers 4 32k;
proxy_busy_buffers_size 64k;
proxy_temp_file_write_size 64k ;
proxy_headers_hash_max_size 51200 ;
proxy_headers_hash_bucket_size 6400 ;
}
}
# ------------------ end
# wq保存,退出
shell# 检查nginx配置
/usr/local/nginx/sbin/nginx -t
# 配置正确回显
the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
configuration file /usr/local/nginx/conf/nginx.conf test is successful
# 启动nginx服务
/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
# 扩展: 热重启
/usr/local/nginx/sbin/nginx -t
/usr/local/nginx/sbin/nginx -s reload
shell[root@localhost conf]# cd conf.d
[root@localhost conf]# vi www.odboy.cn.conf
# ------------------ start
# 组名为"www",四节点均衡负载
upstream www {
server localhost:8080 weight=10;
server localhost:8081 weight=10;
server localhost:8082 weight=10;
server localhost:8083 weight=10;
}
server {
listen 80;
server_name www.odboy.cn;
client_max_body_size 20m;
charset utf-8;
access_log /odboy/logs/www.odboy.cn_http_accesss.log main;
# 将所有80请求转发到https
rewrite ^(.*)$ https://${server_name}$1 permanent;
}
server {
listen 443;
server_name www.odboy.cn;
access_log /odboy/logs/www.odboy.cn_https_accesss.log main;
# 开启ssl
ssl on;
# ssl_certificate和ssl_certificate_key是从阿里云申请的免费证书,等阿里云下发证书之后,下载放到nginxSSL目录下,然后配置的
ssl_certificate /usr/local/nginx/ssl/2943501_www.odboy.cn.pem;
ssl_certificate_key /usr/local/nginx/ssl/2943501_www.odboy.cn.key;
ssl_session_timeout 5m;
ssl_protocols SSLv2 SSLv3 TLSv1 TLSv1.1 TLSv1.2;
ssl_ciphers HIGH:!aNULL:!MD5;
ssl_prefer_server_ciphers on;
location / {
proxy_pass http://www;
proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $remote_addr;
proxy_set_header X-Forwarded-Host $server_name;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
client_max_body_size 10m;
client_body_buffer_size 128k;
proxy_connect_timeout 90;
proxy_send_timeout 90;
proxy_read_timeout 90;
proxy_buffer_size 4k;
proxy_buffers 4 32k;
proxy_busy_buffers_size 64k;
proxy_temp_file_write_size 64k ;
proxy_headers_hash_max_size 51200 ;
proxy_headers_hash_bucket_size 6400 ;
}
}
# ------------------ end
# wq保存,退出
# 然后只需再次执行"检查配置,启动nginx"的步骤即可.


本文作者:Odboy
本文链接:
版权声明:本博客所有文章除特别声明外,均采用 CC 4.0 BY-SA 许可协议。转载请注明出处!