Nginx安装、常用命令和配置文件
1. 在Linux系统中安装nginx
参考https://www.runoob.com/linux/nginx-install-setup.html
-
使用远程连接工具连接Linux操作系统。直接在Linux中安装也可。
-
nginx相关的素材(依赖)
(1)安装pcre依赖
- 把安装压缩文件
pcre-8.37.tar.gz
放到Linux系统中/usr/src
。 - 解压压缩文件
tar -zxvf pcre-8.35.tar.gz
- 进入解压之后的目录,执行
./configure
检查文件 - 使用
make && make install
编译安装
使用
pcre-config --version
可以查看pcre的版本,可以查看是否安装好。(2)安装openssl,zlib
yum -y install make zlib zlib-devel gcc-c++ libtool openssl openssl-devel
(3)安装nginx
- 把安装压缩文件
nginx-1.12.2.tar.gz
放到Linux系统中/usr/src
。 - 解压
tar -zxvf nginx-1.12.2.tar.gz
- 进入解压目录,执行
./configure
-
make && make install
编译安装
- 把安装压缩文件
在安装完成nginx之后,在/usr/local
下会有一个nginx目录。在nginx目录下有sbin目录里有nginx
启动脚本。
**启动nginx:**在/usr/local/nginx/sbin
目录下执行./nginx
在启动中如果出现如下错误: 80端口被占用问题
nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use) nginx: [emerg] still could not bind()
解决办法:
查看端口netstat -ntlp
,将占用80端口的进程杀掉kill xxx
。
查看页面:192.168.187.11:80
LinuxIP地址和nginx nginx/conf/nginx.conf
配置文件中的端口
Linux中:
查看开放的端口:firewall-cmd --list-all
设置开放的端口:firewall-cmd --add-port=80/tcp --permanent
永久生效
重启防火墙:firewall-cmd --reload
2. nginx常用命令
使用nginx操作命令前提条件:必须进入nginx的目录中/usr/local/nginx/sbin
。
-
查看nginx版本号
./nginx -v
-
启动nginx
./nginx
-
关闭nginx
./nginx -s stop
-
重新加载nginx
修改配置文件中的内容,不需要重启服务器,这个
nginx.conf
配置文件也会加载生效。./nginx -s reload
平滑重启nginx【用户访问无感知】 -
验证nginx配置文件是否正确
./nginx -t
3. nginx配置文件
-
nginx配置文件的位置
/usr/local/nginx/conf
下的nginx.conf
文件中 -
nginx配置文件的组成
(1)nginx的配置文件由三部分组成
第一部分:全局块
从配置文件开始到events块之间的内容,主要会设置一些影响nginx服务器整体运行的 配置指令。主要包括配置运行nginx服务器的用户(组),允许生成的worker_process数,进程 PID存放路径,日志存放路径和类型以及配置文件的引入等。
比如第一行配置的:
worker_process 1;
这是nginx服务器并发处理服务的关键配置, worker_process值越大,可以支持的并发数量也就越多,但是会受到硬件、软件等设备 的影响。 第二部分:events块
events块涉及的指令主要影响nginx服务器与用户的网络连接。常用的设置包括:是否 开启对多worker_process下的网络连接进行序列化,是否允许同时接受多个网络连接,选取 那种事件驱动模型来处理连接请求,每个worker_process可以同时支持的最大连接数等。
比如
events{worker_connections 1024};
表示每个worker_process支持的最大连接 数为1024。 这部分配置对nginx的性能影响较大,在实际中应该灵活配置。
第三部分:http块
nginx服务器配置中最频繁的部分。代理、缓存和日志定义等绝大多数功能和第三方模 块的配置都在这里。比如:反向代理,负载均衡,动静分离,高可用都在此配置。
注意:HTTP块又包括http全局块、server块
1. http全局块
http全局块配置的指令包括:文件引入、MIME-TYPE定义、日志自定义、连接超时 时间、单链接请求数上限等。
2. server块
这块和虚拟主机有密切关系。虚拟主机从用户角度看:和一台独立的硬件主机是完全 一样的,该技术的产生是为了节省互联网服务器硬件成本。(后面例子都在此配置)
每个HTTP块可以包括多个server块,而每个server块就相当于一个虚拟主机。
而每个server块也分为:全局server块,以及可以同时包含多个location块。
①全局server块
最常见的配置是:虚拟机主机的监听配置和本虚拟主机的名称或ip配置。
②location块
一个server块可以配置多个location块。
这块的主要作用是:基于nginx服务器接收到的请求字符串(例如server_name/uri- string),对虚拟主机名称(也可以是ip别名)之外的字符串(例如 前面server_name/uri- string)进行匹配,对特定的请求进行处理。地址定向、数据缓存和应答控制等功能, 还有许多第三方模块的配置也在这里进行。
需要安装包的可以私信哟!
少年易老学难成,一寸光阴不可轻。