nginx安装部署教程

本文介绍了Nginx的基本概念,强调了其高性能和低内存消耗的特性,详细阐述了在Windows上的安装步骤,包括启动、检查进程、修改配置和关闭服务的命令。此外,还提到了一些常见的配置优化技巧,如调整工作进程数和最大连接数。

一、Nginx简介

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

它是一种轻量级的Web服务器,可以作为独立的服务器部署网站(类似Tomcat)。它高性能和低消耗内存的结构受到很多大公司青睐,如淘宝网站架设。

官网下载 nginx.org,分别有Linux和Windows两个版本,下载完成后开始安装,右侧“documentation -> nginx windows”有详细的说明
在这里插入图片描述

二、安装部署

1、下载完成后,解压缩,运行cmd,使用命令进行操作,不要直接双击nginx.exe

在这里插入图片描述
不要直接双击nginx.exe,这样会导致修改配置后重启、停止nginx无效,需要手动关闭任务管理器内的所有nginx进程,再启动才可以

一定要在dos窗口启动,不要直接双击nginx.exe,这样会导致修改配置后重启、停止nginx无效,需要手动关闭任务管理器内的所有nginx进程,再启动才可以

2、使用命令到达nginx的加压缩后的目录
cd c:\nginx-1.15.2
3、启动nginx服务,启动时会一闪而过是正常的
start nginx
4、查看任务进程是否存在,dos或打开任务管理器都行
tasklist /fi "imagename eq nginx.exe"

在这里插入图片描述
如果都没有可能是启动报错了查看一下日志,在nginx目录中的logs文件夹下error.log是日志文件
常见的错误:
(1)端口号被占用
(2)nginx文件夹路径含中文

5、修改配置文件,进入解压缩目录,直接文件夹点击进去即可

在这里插入图片描述
在conf目录下找到nginx.conf使用txt文本打开即可,找到server这个节点,修改端口号,如果有需求可以修改主页目录没有就不用修改
在这里插入图片描述
修改完成后保存,使用以下命令检查一下配置文件是否正确,后面是nginx.conf文件的路径,successful就说明正确了

nginx -t -c /nginx-1.15.2/conf/nginx.conf
1)启动项目–项目未启动先启动项目
start nginx
2)重新加载配置文件并启动
nginx -s reload

输入域名和端口号访问项目

6、关闭nginx服务使用以下命令,同样也是一闪而过是正常的,看一下是否进程已消失即可
nginx -s stop 快速停止
nginx -s quit  完整有序的关闭

三、优化配置

打开nginx.conf按照自己需求进行配置,下面列出简单的一些常规调优配置

#user  nobody;
#==工作进程数,一般设置为cpu核心数
worker_processes  1;
#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;
#pid        logs/nginx.pid;

events {
#==最大连接数,一般设置为cpu*2048
worker_connections  1024;
}

http {
include       mime.types;
default_type  application/octet-stream;

#log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
#                  '$status $body_bytes_sent "$http_referer" '
#                  '"$http_user_agent" "$http_x_forwarded_for"';

#access_log  logs/access.log  main;

sendfile        on;
#tcp_nopush     on;

#keepalive_timeout  0;

#==客户端链接超时时间
keepalive_timeout  65;

#gzip  on;

#当配置多个server节点时,默认server names的缓存区大小就不够了,需要手动设置大一点
server_names_hash_bucket_size 512;

#server表示虚拟主机可以理解为一个站点,可以配置多个server节点搭建多个站点
#每一个请求进来确定使用哪个server由server_name确定
server {
    #站点监听端口
    listen       8800;
    #站点访问域名
    server_name  localhost;
    
    #编码格式,避免url参数乱码
    charset utf-8;

    #access_log  logs/host.access.log  main;

    #location用来匹配同一域名下多个URI的访问规则
    #比如动态资源如何跳转,静态资源如何跳转等
    #location后面跟着的/代表匹配规则
    location / {
        #站点根目录,可以是相对路径,也可以使绝对路径
        root   html;
        #默认主页
        index  index.html index.htm;
        
        #转发后端站点地址,一般用于做软负载,轮询后端服务器
        #proxy_pass http://10.11.12.237:8080;

        #拒绝请求,返回403,一般用于某些目录禁止访问
        #deny all;
        
        #允许请求
        #allow all;
        
        add_header 'Access-Control-Allow-Origin' '*';
        add_header 'Access-Control-Allow-Credentials' 'true';
        add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
        add_header 'Access-Control-Allow-Headers' 'DNT,X-CustomHeader,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type';
        #重新定义或者添加发往后端服务器的请求头
        #给请求头中添加客户请求主机名
        proxy_set_header Host $host;
        #给请求头中添加客户端IP
        proxy_set_header X-Real-IP $remote_addr;
        #将$remote_addr变量值添加在客户端“X-Forwarded-For”请求头的后面,并以逗号分隔。 如果客户端请求未携带“X-Forwarded-For”请求头,$proxy_add_x_forwarded_for变量值将与$remote_addr变量相同  
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        #给请求头中添加客户端的Cookie
        proxy_set_header Cookie $http_cookie;
        #将使用代理服务器的主域名和端口号来替换。如果端口是80,可以不加。
        proxy_redirect off;
        
        #浏览器对 Cookie 有很多限制,如果 Cookie 的 Domain 部分与当前页面的 Domain 不匹配就无法写入。
        #所以如果请求 A 域名,服务器 proxy_pass 到 B 域名,然后 B 服务器输出 Domian=B 的 Cookie,
        #前端的页面依然停留在 A 域名上,于是浏览器就无法将 Cookie 写入。
        #不仅是域名,浏览器对 Path 也有限制。我们经常会 proxy_pass 到目标服务器的某个 Path 下,
        #不把这个 Path 暴露给浏览器。这时候如果目标服务器的 Cookie 写死了 Path 也会出现 Cookie 无法写入的问题。
        #设置“Set-Cookie”响应头中的domain属性的替换文本,其值可以为一个字符串、正则表达式的模式或一个引用的变量
        #转发后端服务器如果需要Cookie则需要将cookie domain也进行转换,否则前端域名与后端域名不一致cookie就会无法存取
        #配置规则:proxy_cookie_domain serverDomain(后端服务器域) nginxDomain(nginx服务器域)
        proxy_cookie_domain localhost .testcaigou800.com;
        
        #取消当前配置级别的所有proxy_cookie_domain指令
        #proxy_cookie_domain off;
        #与后端服务器建立连接的超时时间。一般不可能大于75秒;
        proxy_connect_timeout 30;
    }

    #error_page  404              /404.html;

    # redirect server error pages to the static page /50x.html
    #
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   html;
    }

}
#当需要对同一端口监听多个域名时,使用如下配置,端口相同域名不同,server_name也可以使用正则进行配置
#但要注意server过多需要手动扩大server_names_hash_bucket_size缓存区大小
server {
         listen 80;
         server_name www.abc.com;
         charset utf-8;
         location / {
         	proxy_pass http://localhost:10001;
         	}
         	 }
         	 server {
         	 listen 80;
         	 server_name aaa.abc.com;
         	 charset utf-8;
         	 location / {
         	 	proxy_pass http://localhost:20002;
         	 	}
         	 	}
         	 	}

本文仅作为笔记使用

<think>我们正在回答用户关于Nginx安装部署指南的问题。根据用户需求,我们需要提供清晰、结构化的安装部署步骤。同时,根据系统级指令,我们需要:1.所有行内数学表达式使用$...$格式(但本问题不涉及数学公式,可忽略)2.独立公式使用$$...$$格式(同样不涉及)3.使用中文回答4.生成相关问题5.在回答中引用的段落末尾添加引用标识(我们参考了多个引用,需要标注)参考的引用内容主要是关于Nginx安装部署的步骤。我们将结合这些引用,整理出一个通用的安装部署指南。用户的需求是“Nginx安装部署指南”,因此我们将包括以下内容:1.安装前的准备(如系统更新、依赖安装)2.两种安装方式:通过包管理器(如yum)安装和通过源码编译安装3.安装后的基本操作(启动、停止、重启、设置开机启动等)4.验证安装注意:不同的Linux发行版命令可能不同,我们将以常见的CentOS和Ubuntu为例,但用户需根据实际系统调整。根据引用[5],在CentOS上使用yum安装是一种简单的方式,而引用[1][3][4]则提到了源码编译安装,这种方式可以自定义模块。我们将按照以下结构组织回答:###Nginx安装部署指南####一、安装前准备1.更新系统2.安装依赖####二、安装方式#####方法一:通过包管理器安装(推荐新手)-CentOS7示例-Ubuntu示例#####方法二:通过源码编译安装(适合需要自定义模块的情况)1.下载源码2.解压并进入目录3.配置编译选项(可自定义模块和安装路径)4.编译并安装####三、安装后的操作1.启动Nginx2.设置开机启动3.检查运行状态4.停止和重启命令####四、验证安装1.访问默认页面2.检查端口监听####五、防火墙设置(如果需要)然后,根据引用内容,我们在相应步骤后添加引用标识。最后,生成相关问题。现在开始撰写回答:</think>### Nginx 安装部署指南 #### 一、安装前准备 1. **系统更新** 执行系统更新确保软件包最新(以 CentOS 为例): ```bash sudo yum update ``` 2. **安装依赖** 安装编译所需工具链: ```bash sudo yum install -y gcc make openssl-devel pcre-devel zlib-devel # CentOS sudo apt install -y build-essential libssl-dev libpcre3-dev zlib1g-dev # Ubuntu [^3][^5] --- #### 二、两种安装方式 ##### ▶ 方式1:包管理器安装(推荐新手) ```bash # CentOS/RedHat sudo yum install epel-release # 安装EPEL仓库[^5] sudo yum install nginx # Ubuntu/Debian sudo apt update sudo apt install nginx ``` **优点**:自动处理依赖和服务配置 **缺点**:模块自定义受限[^5] ##### ▶ 方式2:源码编译安装(需自定义模块时) ```bash wget https://nginx.org/download/nginx-1.24.0.tar.gz tar -zxvf nginx-1.24.0.tar.gz cd nginx-1.24.0 # 配置编译参数(示例启用SSL模块) ./configure --prefix=/usr/local/nginx \ --with-http_ssl_module \ --with-pcre # 编译并安装 make sudo make install [^1][^3][^4] ``` **关键参数说明**: - `--prefix`:指定安装路径(默认 `/usr/local/nginx`) - `--with-http_ssl_module`:启用HTTPS支持 - `--without-http_rewrite_module`:禁用不需要的模块[^4] --- #### 三、安装后操作 1. **启动与自启** ```bash # 源码安装方式 /usr/local/nginx/sbin/nginx # 包管理安装方式 sudo systemctl start nginx sudo systemctl enable nginx # 设置开机启动[^5] ``` 2. **验证安装** - 检查进程:`ps aux | grep nginx` - 访问默认页:`curl http://localhost` 或浏览器访问服务器IP - 查看版本:`nginx -v`[^1][^3] 3. **常用命令** ```bash nginx -s stop # 立即停止 nginx -s quit # 优雅停止 nginx -s reload # 重载配置[^2] ``` --- #### 四、防火墙配置 ```bash # 放行HTTP/HTTPS端口 sudo firewall-cmd --permanent --add-service=http sudo firewall-cmd --permanent --add-service=https sudo firewall-cmd --reload # CentOS # Ubuntu使用ufw sudo ufw allow 'Nginx Full' [^3][^5] ``` --- #### 五、目录结构说明 ``` /usr/local/nginx/ ├── sbin/nginx # 主程序 ├── conf/nginx.conf # 主配置文件 ├── logs/ # 访问/错误日志 └── html/ # 默认网站根目录[^2][^3] ```
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值