都是我的错-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日志并进行多维度分析。
相关文章
|
1月前
|
缓存 应用服务中间件 网络安全
Nginx中配置HTTP2协议的方法
Nginx中配置HTTP2协议的方法
79 7
|
3天前
|
存储 应用服务中间件 nginx
nginx反向代理bucket目录配置
该配置实现通过Nginx代理访问阿里云OSS存储桶中的图片资源。当用户访问代理域名下的图片URL(如 `http://代理域名/123.png`)时,Nginx会将请求转发到指定的OSS存储桶地址,并重写路径为 `/prod/files/2024/12/12/123.png`。
30 5
|
27天前
|
缓存 负载均衡 算法
如何配置Nginx反向代理以实现负载均衡?
如何配置Nginx反向代理以实现负载均衡?
|
1月前
|
存储 负载均衡 中间件
Nginx反向代理配置详解,图文全面总结,建议收藏
Nginx 是大型架构必备中间件,也是大厂喜欢考察的内容,必知必会。本篇全面详解 Nginx 反向代理及配置,建议收藏。
Nginx反向代理配置详解,图文全面总结,建议收藏
|
18天前
|
负载均衡 前端开发 应用服务中间件
负载均衡指南:Nginx与HAProxy的配置与优化
负载均衡指南:Nginx与HAProxy的配置与优化
39 3
|
27天前
|
负载均衡 监控 应用服务中间件
配置Nginx反向代理时如何指定后端服务器的权重?
配置Nginx反向代理时如何指定后端服务器的权重?
48 4
|
27天前
|
安全 应用服务中间件 网络安全
如何测试Nginx反向代理实现SSL加密访问的配置是否正确?
如何测试Nginx反向代理实现SSL加密访问的配置是否正确?
50 3
|
27天前
|
安全 应用服务中间件 网络安全
配置Nginx反向代理实现SSL加密访问的步骤是什么?
我们可以成功地配置 Nginx 反向代理实现 SSL 加密访问,为用户提供更安全、可靠的网络服务。同时,在实际应用中,还需要根据具体情况进行进一步的优化和调整,以满足不同的需求。SSL 加密是网络安全的重要保障,合理配置和维护是确保系统安全稳定运行的关键。
96 3
|
29天前
|
应用服务中间件 网络安全 nginx
轻松上手Nginx Proxy Manager:安装、配置与实战
Nginx Proxy Manager (NPM) 是一款基于 Nginx 的反向代理管理工具,提供直观的 Web 界面,方便用户配置和管理反向代理、SSL 证书等。本文档介绍了 NPM 的安装步骤,包括 Docker 和 Docker Compose 的安装、Docker Compose 文件的创建与配置、启动服务、访问 Web 管理界面、基本使用方法以及如何申请和配置 SSL 证书,帮助用户快速上手 NPM。
186 1
|
1月前
|
Dart 搜索推荐 IDE
Windows下Zed编辑器配置Dart环境
本文介绍了Dart编程语言及其主要框架Flutter的优势,并推荐使用轻量级编辑器Zed进行Dart开发。详细步骤包括Dart环境的安装与配置,Zed编辑器的安装与个性化设置,以及如何在Zed中编写并运行Dart的HelloWorld程序。通过自定义任务实现Dart文件的快速运行,提高了开发效率。