1. 简介

Nginx是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP代理服务器。

Nginx是一款轻量级的Web服务器/反向代理服务器以及电子邮件代理服务器,并在一个BSD-like协议下发行。由俄罗斯的程序设计师lgor Sysoev所开发,供俄国大型的入口网站及搜索引擎Rambler使用。其特点是占有内存少,并发能力强,事实上nginx的并发能力确实在同类型的网页服务器中表现较好。

Nginx相较于Apache\lighttpd具有占有内存少,稳定性高等优势,并且依靠并发能力强,丰富的模块库以及友好灵活的配置而闻名。在Linux操作系统下,nginx使用epoll事件模型,得益于此,nginx在linux操作系统下效率相当高。同时Nginx在OpenBSD或FreeBSD操作系统上采用类似于Epoll的高效事件模型kqueue.

2. Nginx的优势

① 作为Web服务器,Nginx处理静态文件、索引文件,自动索引的效率非常高

② 作为代理服务器,Nginx可以实现无缓存的反向代理加速,提高网站运行速度

③ 作为负载均衡服务器,Nginx既可以在内部直接支持Rails和php,也可以支持HTTP代理服务器对外进行服务,同时还支持简单的容错和利用算法进行负载均衡

④ 在性能方面,Nginx是专门为性能优化而开发的,实现上非常注重效率。它采用内核Poll模型,可以支持更多的并发连接,最大可以支持对5万个并发连接数的响应,而且只占用很低的内存资源

⑤ 在稳定性方面,Nginx采取了分阶段资源分配技术,使得CPU与内存的占用率非常低。Nginx官方表示,Nginx保持1万个没有活动的连接,而这些连接只占用2.5MB内存,因此,类似DOS这样的攻击对Nginx来说基本上是没有任何作用的

⑥ 在高可用性方面,Nginx支持热部署,启动速度特别迅速,因此可以在不间断服务的情况下,对软件版本或者配置进行升级,即使运行数月也无需重新启动,几乎可以做到7x24小时不间断地运行

Nginx具有很高的稳定性;

支持热部署;

代码质量非常高,代码很规范,手法成熟,模块扩展也很容易;

采用了一些os提供的最新特性如对sendfile(Linux2.2+),accept-filter(FreeBSD4.1+),TCP_DEFER_ACCEPT(Linux 2.4+)的支持,从而大大提高了性能。

3. 安装依赖包

# yum -y update
# yum -y install gcc gcc-c++ autoconf automake zlib zlib-devel openssl openssl-devel pcre* make gd-devel libjpeg-devel libpng-devel libxml2-devel bzip2-devel libcurl-devel

4. 创建用户

[root@zabbix ~]# useradd nginx -s /sbin/nologin -M

5. 编译安装

[root@zabbix opt]# wget http://nginx.org/download/nginx-1.9.15.tar.gz
[root@zabbix opt]# tar xvf nginx-1.9.15.tar.gz
[root@zabbix opt]# cd nginx-1.9.15
[root@zabbix nginx-1.9.15]# ./configure \
--prefix=/usr/local/product/nginx-1.9.15 \
--user=www \
--group=www \
--with-http_ssl_module \ #支持https
--with-http_v2_module \
--with-http_stub_status_module \ #支持nginx状态查询
--with-pcre #支持rewrite重写功能,必须制定pcre
[root@zabbix nginx-1.9.15]# make && make install
[root@zabbix nginx-1.9.15]# ln -s /usr/local/product/nginx-1.9.15 /usr/local/nginx ==>创建软链接

6. 启动nginx

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

7. Nginx启动错误告警:

[root@zabbix nginx-1.8.0]# /usr/local/nginx/sbin/nginx
nginx: [emerg] getpwnam(“www”) failed

解决方案一

在nginx.conf中 把user nobody的注释去掉既可

解决方案二

错误的原因是没有创建www这个用户,应该在服务器系统中添加www用户组和用户www,如下命令:

[root@zabbix ~]# groupadd -f www
[root@zabbix ~]# useradd -g www www

[root@zabbix nginx-1.8.0]# /usr/local/nginx/sbin/nginx
nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)
80端口被占用
[root@zabbix nginx-1.8.0]# netstat -tunlp
找到占用80端口的进程 kill掉就行了

8. 将nginx添加到service管理,编写脚本:

[root@zabbix ~]# vim /etc/rc.d/init.d/nginx
#!/bin/bash
# nginx Startup script for the Nginx HTTP Server
# it is v.0.0.2 version.
# chkconfig: - 85 15
# description: Nginx is a high-performance web and proxy server.
# It has a lot of features, but it's not for everyone.
# processname: nginx
# pidfile: /var/run/nginx.pid
# config: /usr/local/nginx/conf/nginx.conf nginxd=/usr/local/nginx/sbin/nginx
nginx_config=/usr/local/nginx/conf/nginx.conf
nginx_pid=/var/run/nginx.pid
RETVAL=0
prog="nginx" # Source function library.
. /etc/rc.d/init.d/functions # Source networking configuration.
. /etc/sysconfig/network # Check that networking is up.
[ ${NETWORKING} = "no" ] && exit 0
[ -x $nginxd ] || exit 0 # Start nginx daemons functions.
start() {
if [ -e $nginx_pid ];then
echo "nginx already running...."
exit 1
fi
echo -n $"Starting $prog: "
daemon $nginxd -c ${nginx_config}
RETVAL=$?
echo
[ $RETVAL = 0 ] && touch /var/lock/subsys/nginx
return $RETVAL
} # Stop nginx daemons functions.
stop() {
echo -n $"Stopping $prog: "
killproc $nginxd
RETVAL=$?
echo
[ $RETVAL = 0 ] && rm -f /var/lock/subsys/nginx /var/run/nginx.pid
} # reload nginx service functions.
reload() {
echo -n $"Reloading $prog: "
#kill -HUP `cat ${nginx_pid}`
killproc $nginxd -HUP
RETVAL=$?
echo
} # See how we were called.
case "$1" in
start)
start
;;
stop)
stop
;;
reload)
reload
;;
restart)
stop
start
;;
status)
status $prog
RETVAL=$?
;;
*)
echo $"Usage: $prog {start|stop|restart|reload|status|help}"
exit 1
esac
exit $RETVAL

添加执行权限,加入chkconfig管理

[root@zabbix ~]# chmod +x /etc/rc.d/init.d/nginx
[root@zabbix ~]# chkconfig --add nginx
[root@zabbix ~]# chkconfig --level 345 nginx on #随系统启动

9. 防火墙开放80端口

# iptables -A INPUT -p tcp -m state --state NEW -m tcp --dport 80 -j ACCEPT
# service iptables save
# service iptables restart

或者关闭防火墙

# service iptables stop

10. 浏览器检测

在浏览器中输入http://服务器IP地址/,出现以下页面,安装成功。

最新文章

  1. bzoj 1070 [SCOI2007]修车
  2. django中html过滤器filter
  3. python之SQLAlchemy
  4. Excel多条件筛选求和
  5. rails 项目部署中 nginx 报错及解决方法
  6. 【转】Android学习系列(1)--为App签名(为apk签名)
  7. c#编程:输入、输出
  8. JBoss AS 7性能调优(三)
  9. Oracle Data Provider for .NET 的使用经验
  10. [转]Numpy使用MKL库提升计算性能
  11. macOS安装beego的使用bee命令出现killed:9 解决办法
  12. # electron-vue 尝试做个网易云音乐
  13. Java + Selenium + TestNG + Maven
  14. 第十七节: EF的CodeFirst模式的四种初始化策略和通过Migration进行数据的迁移
  15. TableStore:多行数据操作
  16. 利用:before和:after伪类制作类似微信对话框
  17. CentOS 中 配置 Nginx 支持 https
  18. Where should we fork this repository?
  19. python学习两月总结_汇总大牛们的思想_值得收藏
  20. NY891 区间选点 找点

热门文章

  1. Spring+SpringMVC+MyBatis整合基础篇(二)牛刀小试
  2. 利用JS实现一个简单的二级联动菜单
  3. Android 测试之Monkey
  4. 利用链式队列(带头节点)解决银行业务队列简单模拟问题(c++)-- 数据结构
  5. FTP地址
  6. 实验---反汇编一个简单的C程序(杨光)
  7. 剑指offer:数值的整数次方
  8. (Alpha)Let's-Chronos分数分配规则
  9. Linux基础六(网络管理)
  10. 团队项目:安卓端用百度地图api定位显示跑道