都是我的错-Windows Nginx新手执行指令配置无效(下)

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: 都是我的错-Windows Nginx新手执行指令配置无效(下)

停止服务

执行-s stop指令,查看进程可以知道,第二次启动的进程已经结束,第一次的进程还存在,此时访问服务可以发现第一次的端口服务是正常的

>nginx -s stop
>tasklist /FI "IMAGENAME eq nginx.exe"
映像名称                       PID 会话名              会话#       内存使用
========================= ======== ================ =========== ============
nginx.exe                    23456 Console                    1      9,776 K
nginx.exe                    58692 Console                    1     10,304 K

执行停止指令或重启,发现已经无法启动,同时提示如下错误:

>nginx -s stop
nginx: [error] CreateFile() "./logs/nginx.pid" failed (2: The system cannot find the file specified)
>nginx -s reload
nginx: [error] CreateFile() "./logs/nginx.pid" failed (2: The system cannot find the file specified)

解决办法

查看该目录发现,改文件已经不存在,所有才会提示上述错误,意思就是不能够通过普通方式进行服务退出,这时候可以考虑直接执行taskkill指令进行处理,执行成功后,再查看对应进程nginx.exe,发现本地已经不存在对应镜像名称的进程了

>taskkill /F /IM nginx.exe /T
成功: 已终止 PID 50792 (属于 PID 58692 子进程)的进程。
成功: 已终止 PID 58692 (属于 PID 23456 子进程)的进程。
成功: 已终止 PID 23456 (属于 PID 57764 子进程)的进程。
>tasklist /FI "IMAGENAME eq nginx.exe"
信息: 没有运行的任务匹配指定标准。

再次执行start nginx启动,就能够访问对应修改之后的配置内容

最近一次配置异常

条件:下次服务重启前,不查看错误日志,无法发现问题

服务已经运行,页面能够正常访问到地址http://localhost:7080/nginx.conf配置如下:

......省略.......
http {
......省略.......
    server {
        listen       7080;
        server_name  localhost;
        location / {
            root   html;
            index  index.html index.htm;
        }
......省略.......
    }
}

最近一次修改时,造成配置疏忽:

......省略.......
http {
......省略.......
    server {
        listen       7080;
        server_name  localhost;
        location / {
            root   html;
            # 假定配置错误少些分号;结尾
            index  index.html index.htm
        }
......省略.......
    }
}

再次手误启动,无任何提示,运行时访问http://localhost:7080/,也是正常响应

>start nginx

查看nginx.exe中进程数也是正常的

>tasklist /FI "IMAGENAME eq nginx.exe"
映像名称                       PID 会话名              会话#       内存使用
========================= ======== ================ =========== ============
nginx.exe                    61380 Console                    1      1,280 K
nginx.exe                    59796 Console                    1      2,164 K

直到,哪天nginx.exe结束了程序再次重启,结果就是完了,服务不能用了,查看日志才发现,实际配置文件已经报错,当时在服务配置错误时,未查看系统中是否已经存在nginx服务前,就再次启动nginx服务,实际由于异常配置,实际服务并未启动,而是正常情况时的服务并未退出,造成的服务正常的假象

解决办法

善用nginx常规指令和良好的服务检测习惯

启动服务前,先核查本地是否已经启动服务

>tasklist /FI "IMAGENAME eq nginx.exe"

输出信息: 没有运行的任务匹配指定标准。,表示不存在对应镜像名称的进程存在服务时,过存在则会输出对应的进程列表清单,

已经存在进程时,对配置进行修改后,可以考虑先使用-t [confpath]对目标配置文件进行内容检测,不添加参数,默认为nginx.conf,以下为配置正常时的输出结果,配置异常时,会显示对应的异常配置位置大概位置,便于用户排查

>nginx -t
nginx: the configuration file 解压路径\nginx-1.21.1/conf/nginx.conf syntax is ok
nginx: configuration file 解压路径\nginx-1.21.1/conf/nginx.conf test is successful

确认配置无误后,使用-s reload进行服务重启,重启后的进程id和之前老的进程id是不一样的,可以规避对应的服务存存在假象,同时可以多看看异常日志,一般如果配置异常,日志中,有对应的异常日志输出

重启前

>tasklist /fi "imagename eq nginx.exe"
映像名称                       PID 会话名              会话#       内存使用
========================= ======== ================ =========== ============
nginx.exe                    38452 Console                    1     17,472 K
nginx.exe                    47260 Console                    1     17,824 K

重启后

>nginx -s reload
D:\Program Files\nginx-1.21.1>tasklist /fi "imagename eq nginx.exe"
映像名称                       PID 会话名              会话#       内存使用
========================= ======== ================ =========== ============
nginx.exe                    38452 Console                    1     17,392 K
nginx.exe                    22264 Console                    1     17,816 K

注意

实际进程不止俩,结束进程时,关联进程列表为,主进程,工作进程以及一个其他进程,上述文章中说的俩仅仅是限定范围到当前服务范围内,不过多延伸

如果想要获取上述例子中的nginx压缩包,可以评论留言或者私信笔者

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
15天前
|
应用服务中间件 BI nginx
Nginx的location配置详解
【10月更文挑战第16天】Nginx的location配置详解
|
22天前
|
缓存 负载均衡 安全
Nginx常用基本配置总结:从入门到实战的全方位指南
Nginx常用基本配置总结:从入门到实战的全方位指南
207 0
|
7天前
|
存储 负载均衡 Java
如何配置Windows主机MPIO多路径访问存储系统
Windows主机多路径(MPIO)是一种技术,用于在客户端计算机上配置多个路径到存储设备,以提高数据访问的可靠性和性能。本文以Windows2012 R2版本为例介绍如何在客户端主机和存储系统配置多路径访问。
47 13
如何配置Windows主机MPIO多路径访问存储系统
|
8天前
|
应用服务中间件 API nginx
nginx配置反向代理404问题
【10月更文挑战第18天】本文介绍了使用Nginx进行反向代理的配置方法,解决了404错误、跨域问题和302重定向问题。关键配置包括代理路径、请求头设置、跨域头添加以及端口转发设置。通过调整`proxy_set_header`和添加必要的HTTP头,实现了稳定的服务代理和跨域访问。
nginx配置反向代理404问题
|
2天前
|
应用服务中间件 网络安全 PHP
八个免费开源 Nginx 管理系统,轻松管理 Nginx 站点配置
Nginx 是一个高效的 HTTP 服务器和反向代理,擅长处理静态资源、负载均衡和网关代理等任务。其配置主要通过 `nginx.conf` 文件完成,但复杂设置可能导致错误。本文介绍了几个开源的 Nginx 可视化配置系统,如 Nginx UI、VeryNginx、OpenPanel、Ajenti、Schenkd nginx-ui、EasyEngine、CapRover 和 NGINX Agent,帮助简化和安全地管理 Nginx 实例。
|
12天前
|
缓存 负载均衡 应用服务中间件
Nginx配置
【10月更文挑战第22天】在实际配置 Nginx 时,需要根据具体的需求和环境进行调整和优化。同时,还需要注意配置文件的语法正确性和安全性。
31 7
|
21天前
|
前端开发 JavaScript 应用服务中间件
终极 Nginx 配置指南
本文介绍了Nginx的基本配置及其优化方法。首先,通过删除注释简化了Nginx的默认配置文件,使其更易于理解。接着,文章将Nginx配置文件分为全局块、events块和http块三部分进行详细解释。此外,还提供了如何快速上线网站、解决前端history模式404问题、配置反向代理、开启gzip压缩、设置维护页面、在同一IP上部署多个网站以及实现动静分离的具体配置示例。最后,附上了Nginx的基础命令,包括安装、启动、重启和关闭等操作。
|
23天前
|
缓存 前端开发 JavaScript
一、nginx配置
一、nginx配置
125 1
|
22天前
|
JavaScript 前端开发 应用服务中间件
vue前端开发中,通过vue.config.js配置和nginx配置,实现多个入口文件的实现方法
vue前端开发中,通过vue.config.js配置和nginx配置,实现多个入口文件的实现方法
111 0
|
25天前
|
缓存 监控 负载均衡
nginx相关配置及高并发优化
Nginx的高并发优化是一个综合性的过程,需要根据具体的业务场景和硬件资源量身定制。以上配置只是基础,实际应用中还需根据服务器监控数据进行持续调整和优化。例如,利用工具如ab(Apache Benchmarks)进行压力测试,监控CPU、内存、网络和磁盘I/O等资源使用情况,确保配置的有效性和服务的稳定性。
87 0