Nginx的英文官方网站是http://nginx.org,在这里可以查看Nginx的各个软件版本信息。Nginx软件有三种版本:稳定版、开发版和历史稳定版。开发版更新较快,包含最新的功能和bug的修复,但同时也可能会遇到新的bug,开发版的更新一旦稳定下来,就会被纳入稳定版中。但是,有些新功能不会被加入到旧的稳定版中去。稳定版本的更新较慢,但是软件bug也会较少,可以作为企业生产环境的首选,因此通常建议选择使用稳定版。当然,在实际工作中,选择稳定版时,尽量避免使用最新的版本,选择比已出来的最新版晚6~10个月的版本比较好。

1. 安装Nginx所需的依赖包。

分别是pcre-devel、openssl-devel包

pcre库是为了使Nginx支持具备URI重写功能的rewrite模块,如果不安装pcre库,则Nginx无法使用rewrite模块功能,Nginx的rewrite模块功能几乎是企业应用必须的。

openssl是Nginx在使用HTTPS服务的时候要用到此模块,如果不安装openssl,安装Nginx的过程中会报错。

# 安装方式

yum install pcre pcre-devel -y
yum install openssl openssl-devel -y

# 检查安装结果

rpm -qa pcre pcre-devel
rpm -qa openssl openssl-devel

2. 开始安装。

操作命令如下:

[root@120_234_2_74_centos7 ~]# cd /tools/
[root@120_234_2_74_centos7 tools]# wget -q http://nginx.org/download/nginx-1.12.1.tar.gz
[root@120_234_2_74_centos7 tools]# useradd nginx -s /sbin/nologin -M
[root@120_234_2_74_centos7 tools]# tar xf nginx-1.12.1.tar.gz
[root@120_234_2_74_centos7 tools]# cd nginx-1.12.1/
[root@120_234_2_74_centos7 nginx-1.12.1]# ./configure --user=nginx --group=nginx --prefix=/app/nginx-1.12.1/ --with-http_stub_status_module --with-http_ssl_module
[root@120_234_2_74_centos7 nginx-1.12.1]# make && make install

# 讲Nginx安装路径通过软连接的方式更改为/app/nginx/, 方便人员使用。安装时制定版本号路径是为了便于查看区分当前使用的Nginx版本,也方便以后升级。

[root@120_234_2_74_centos7 nginx-1.12.1]# ln -sv /app/nginx-1.12.1/ /app/nginx

3. 启动并检查安装结果。

(1)启动前检查配置文件语法

[root@120_234_2_74_centos7 tools]# /app/nginx/sbin/nginx -t
nginx: the configuration file /app/nginx-1.12.1//conf/nginx.conf syntax is ok
nginx: configuration file /app/nginx-1.12.1//conf/nginx.conf test is successful

(2)启动Nginx服务

[root@120_234_2_74_centos7 tools]# /app/nginx/sbin/nginx

(3)查看Nginx服务对应的端口是否成功启动

[root@120_234_2_74_centos7 tools]# lsof -i:80
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
nginx 6256 root 6u IPv4 21943 0t0 TCP *:http (LISTEN)
nginx 6257 nginx 6u IPv4 21943 0t0 TCP *:http (LISTEN)

也可以通过ss -lnt | grep 80查看:

[root@120_234_2_74_centos7 tools]# ss -lnt | grep 80
LISTEN 0 128 *:80 *:*

(4)检查Nginx启动的实际效果

打开浏览器输入http://x.x.x.x,然后回车,如看到如图的内容,就表示Nginx已经启动了。

注意,nginx -s reload 原理:

  新的请求会放到新的工作线程上。
旧的请求会一直处理,直到结束完旧的任务。

4.Nginx日志切割

Nginx 是一个非常轻量的 Web 服务器,体积小、性能高、速度快等诸多优点。但不足的是也存在缺点,比如其产生的访问日志文件一直就是一个,不会自动地进行切割,如果访问量很大的话,将导致日志文件容量非常大,不便于管理。

脚本内容:

#/bin/bash
#-----------desc-----------------------
# desc : nginx cut log
# create : 2017-11-21
# update : 2017-11-21
# version: 1.0.0
# author : luchuangao
#-----------desc----------------------- # 设置日志文件存放目录
logs_path=/usr/local/nginx/logs/ # 设置pid文件
pid_path=/usr/local/nginx/logs/nginx.pid # 重命名日志文件
mv ${logs_path}access.log ${logs_path}access_$(date -d yesterday +%Y%m%d).log
mv ${logs_path}error.log ${logs_path}error_$(date -d yesterday +%Y%m%d).log # 向nginx主进程发信号重新打开日志
kill -USR1 `cat ${pid_path}`

其他操作:

# 添加计划任务
crontab -e # nginx cut log
0 0 * * * /bin/bash /shell/nginx/nginx-cut-log.sh # 重启crond任务
systemctl restart crond

5. 添加代理认证

yum install httpd-tools -y
#第一次需要加-c
htpasswd -bc /usr/local/nginx/conf/htpasswd.users luchuangao 123456
#第二次需要把-c去掉,否则会覆盖原有得。
htpasswd -b /usr/local/nginx/conf/htpasswd.users luchuangao 123456
#查看tail /usr/local/nginx/conf/htpasswd.users
#...
#授权
chown nginx.nginx /usr/local/nginx/conf/htpasswd.users
#重启服务
/usr/local/nginx/sbin/nginx -s reload 添加进nginx配置文件:
vim /usr/local/nginx/conf/conf.d/kibana5612.conf
upstream kibana_server {
server 127.0.0.1:5601 weight=1 max_fails=3 fail_timeout=60;
} server {
listen 80;
server_name www.kibana5611.com;
auth_basic "Restricted Access";
auth_basic_user_file /usr/local/nginx/conf/htpasswd.users;
location /{
proxy_pass http://kibana_server;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection 'upgrade';
proxy_set_header Host $host;
proxy_cache_bypass $http_upgrade;
}
}

一键安装

yum install pcre pcre-devel -y
yum install openssl openssl-devel -y
cd /usr/local/src/
wget -q http://nginx.org/download/nginx-1.12.1.tar.gz
useradd nginx -s /sbin/nologin -M
tar xf nginx-1.12.1.tar.gz
cd nginx-1.12.1/
./configure --user=nginx --group=nginx --prefix=/usr/local/nginx-1.12.1/ --with-http_stub_status_module --with-http_ssl_module
make && make install
ln -sv /usr/local/nginx-1.12.1 /usr/local/nginx
/usr/local/nginx/sbin/nginx -t

启动脚本

vim /etc/init.d/nginx

#!/bin/bash
# chkconfig: - 85 15
PATH=/usr/local/nginx
DESC="nginx daemon"
NAME=nginx
DAEMON=$PATH/sbin/$NAME
CONFIGFILE=$PATH/conf/$NAME.conf
PIDFILE=$PATH/logs/$NAME.pid
SCRIPTNAME=/etc/init.d/$NAME
set -e
[ -x "$DAEMON" ] || exit 0
do_start() {
$DAEMON -c $CONFIGFILE || echo -n "nginx already running"
}
do_stop() {
$DAEMON -s stop || echo -n "nginx not running"
}
do_reload() {
$DAEMON -s reload || echo -n "nginx can't reload"
}
case "$1" in
start)
echo -n "Starting $DESC: $NAME"
do_start
echo "."
;;
stop)
echo -n "Stopping $DESC: $NAME"
do_stop
echo "."
;;
reload|graceful)
echo -n "Reloading $DESC configuration..."
do_reload
echo "."
;;
restart)
echo -n "Restarting $DESC: $NAME"
do_stop
do_start
echo "."
;;
*)
echo "Usage: $SCRIPTNAME {start|stop|reload|restart}" >&2
exit 3
;;
esac
exit 0

操作命令:

#设置执行权限
chmod a+x /etc/init.d/nginx #注册成服务
chkconfig --add nginx #设置开机启动
chkconfig nginx on #重启, 查看nginx服务是否自动启动
shutdown -h 0 -r
netstat -apn|grep nginx
#对nginx服务执行停止/启动/重新读取配置文件操作 #启动nginx服务
systemctl start nginx.service
#停止nginx服务
systemctl stop nginx.service
#重启nginx服务
systemctl restart nginx.service
#重新读取nginx配置(这个最常用, 不用停止nginx服务就能使修改的配置生效)
systemctl reload nginx.service

nginx 80端口重定向到443端口

https://blog.csdn.net/m0_37886429/article/details/72271983

Nginx服务基础的更多相关文章

  1. 企业级Nginx服务基础到架构优化详解

    1.隐藏nginx header版本号 2.更改源码隐藏软件名称 3.更改nginx默认用户及用户组 4.配置nginx worker进程个数 5.根据CPU核数进行nginx进程优化 6.nginx ...

  2. Linux基础系列:常用命令(6)_nfs服务与nginx服务

    NFS介绍: NFS 是Network File System的缩写,即网络文件系统.一种使用于分散式文件系统的协定,由Sun公司开发,于1984年向外公布.功能是通过网络让不同的机器.不同的操作系统 ...

  3. Linux基础系列:常用命令(5)_samba服务与nginx服务

    作业一:部署samba 每个用户有自己的目录,可以浏览内容,也可以删除 所有的用户共享一个目录,只能浏览内容,不能删 安装samba服务 1.准备环境 setenforce 0 2.安装软件包 yum ...

  4. linux基础(5)- nginx服务、nfs服务

    一.nginx服务 源码安装: yum install gcc-* glibc-* openssl openssl-devel pcre pcre-devel zlib zlib-devel -yls ...

  5. nginx 的基础配置[转]

    nginx 的基础配置 分类: 工具软件2013-11-13 23:26 11人阅读 评论(0) 收藏 举报   目录(?)[-] 管理配置文件 全局配置 虚拟机server配置 location配置 ...

  6. nginx的基础应用

    nginx的基础应用 一.简介 今天我们将介绍一些nginx的简单应用,启动.停止nginx,重载nginx的配置,nginx配置文件的格式,如何配置nginx服务静态资源,如何配置nginx作为反向 ...

  7. nginx的基础应用(续)

    nginx的基础应用(续) 一.简介 上一篇文章我们介绍了nginx的基础应用,其中讲到了nginx作为代理服务器的使用,但是漏了一个重要的,也是使用非常普遍的特性--负载均衡.今天,我们将这段内容补 ...

  8. 1.Nginx服务应用

    Nginx服务应用 Nginx的优点和作用 Nginx是一款高性能的HTTP和反向代理的服务器软件,还是一个IMAP/POP3/SMTP(邮件)代理服务器! Nginx在功能实现上都采用模块化结构设计 ...

  9. DNS服务基础原理介绍

    FQDN 全称域名 localhost(主机名或者是别名).localdomain(域名)    FQDN=主机名.域名 根域               . 顶级域名       .com   .n ...

随机推荐

  1. CentOS后台运行和关闭、查看后台任务命令

    fg.bg.jobs.&.nohup.ctrl+z.ctrl+c 命令 一.& 加在一个命令的最后,可以把这个命令放到后台执行,如 watch -n 10 sh test.sh &am ...

  2. MVC中用View.bag保存json字符串。在js中使用,不用ajax请求。。。。

    有时候我们只需要使用一次json数据,这时候直接在后台查出json,然后用view.bag传到前台使用,就会很方便..(在前台用ajax请求的话,感觉有点多余..) 上代码 后台: public Ac ...

  3. php多语言截取字符串函数

    <?php header("Content-Type:text/html;charset=utf-8"); function msubstr($str, $start = 0 ...

  4. spring如何引用properties文件里的配置

      1.PropertyPlaceholderConfigurer类它是把属性中的定义的变量(var)替代,spring的配置文件中使用${var}的占位符 <beans><bean ...

  5. mysql的MyISAM 和 InnoDB 的区别?优化MYSQL数据库的方法?

    MyISAM 和 InnoDB 的基本区别 1.InnoDB不支持FULLTEXT类型的索引. 2.InnoDB 中不保存表的具体行数,也就是说,执行select count(*) from tabl ...

  6. Spark Streaming源码分析 – Checkpoint

    PersistenceStreaming没有做特别的事情,DStream最终还是以其中的每个RDD作为job进行调度的,所以persistence就以RDD为单位按照原先Spark的方式去做就可以了, ...

  7. 在程序中使用命令行的方式来调用py文件

    做这个主要是程序可以做到直接调用一个脚本,而不是从脚本中把类或者函数import出来这样调用,比如我们写的python命令行文件,让java来调用,让c++来调用,都是可以的.这样不需要整个语言都用p ...

  8. 使用CXF为webservice添加拦截器

      拦截器分为Service端和Client端 拦截器是在发送soap消息包的某一个时机拦截soap消息包,对soap消息包的数据进行分析或处理.分为CXF自带的拦截器和自定义的拦截器 1.Servi ...

  9. 【VR】Leap Motion 官网文档 FingerModel (手指模型)

    前言: 感谢关注和支持这个Leap Motion系列翻译的朋友们,非常抱歉因为工作原因非常久没有更新,今后这个翻译还会继续(除非官方直接给出中文文档).本篇献给大家的是 <FingerModel ...

  10. Objective-C语法之KVC使用

    转自:http://www.cnblogs.com/stoic/archive/2012/07/20/2601315.html 除了一般的赋值和取值的方法,我们还可以用Key-Value-Coding ...