了解hadoop的pid文件

了解hadoop的pid文件,第1张

hadoop启动之后,pid文件是存储哪里?

我们可以通过查看 hadoop-env.sh文件

$ cat etc/hadoop/hadoop-env.sh

从下图可以看段李出hadoop默认的pid文件是存储到/tmp目录的

从下图可以看出,后缀名是.pid的就是hadoop的pid文件

我们启动的时候,是执行sbin/start-df.sh文件,我们看一看这个文件

cat sbin/start-dfs.sh

从上面这个图可以看出,启动namenode节点的时候,调用了hadoop-daemons.sh文件了,我们再看看这个文件

$ cat sbin/hadoop-daemons.sh

b) hadoop停止的时候,会到pid文件中获取进程号,然后停止进程,最后颤燃桐删除pid文件

下面我们做一下验证:

a) 看下namenode的进程号是不是和pid文件里的进程号一样

从上图可以看出,进程号是一样的,说明我们前面的推理是正确的

b) 我们把生成号的namenode的pid文件名字改一下,停止的时候脚本会找不到pid文件,也就不会停止namenode进程了

linux的/tmp目录会自动清理一段时间没有访问的文件,一般都是30天,假如hadoop启动了30天以上,那么pid文件会被删除,再调用停止的时候会停止不了,生产上一般不会放在/tmp目录下,下面茄坦我们自己创建个目录存放pid文件

然后修改etc/hadoop/hadoop-env.sh文件

vim /etc/hadoop/hadoop-env.sh

今枝蠢天在做LNMP环境的时候,mysql启动失败,LNMP环境是用的oneinstack一键安装脚本安装的。

大致意思是因为 /tmp 目录缺少启动文件( mysql.pid )导致的,恩,于是参照网上提供的方法,修改 /etc/my.cnf 文件

修改pid文件的存放目录,然后 chmod -R 777 /var/lib/mysql/

重新启动,恩?失败!!

那继续,还有大佬说查看mysql报让搭姿错日志

等会,好像有什么不对啊,今天明明是11-06,你这个坦绝11-04什么鬼!!!!

绝望~

然后冷静下来,想到,刚刚查看日志文件为什么会显示权限不够,什么时候vi都要超级管理员权限了。

然后 ll 看了一下文件的所属

嗯哼,这个1002是什么鬼,顿时发现问题

创建mysql用户和mysql组

nice启动成功了!!!

开心~~

参考 https://blog.51cto.com/12482328/2087535

1. 添加uwsgi相关文件

在之前的渗旅文章跟讲到过centos中搭建nginx+uwsgi+flask运行环境,本节就基于那一次的配置进行说明。

在www中创建uwsgi文件夹,用来存放uwsgi相关文件

在uwsgi文件夹中创建uwsgi.pid和uwsgi.status文件,uwsgi.pid文件用来重启和停止uwsgi服务,uwsgi.status用来查看uwsgi的服务状态

2. ****修改uwsgi****配置文件

基于我们之前配置的uwsgin.ini文件,做如下修改,添加pid文件和status文件的配置

stats=%(chdir)/uwsgi/uwsgi.status

pidfile=%(chdir)/uwsgi/uwsgi.pid

保存丛洞凳退出

3. ****使用命令

完成配置后,可以用如下命令 *** 作uwsgi服务

uwsgi --ini uwsgin.ini

执行完成后,我们可以cat一下pid文件,发现里面出现了一个pid号

同时我们用ps命令查看一下uwsgi的进程,发现主进程的pid与我们的pid文件里存的是一颤知样的

uwsgi --reload uwsgi/uwsgi.pid

uwsgi --connect-and-read uwsgi/uwsgi.status

这个命令返回一个json串,显示进程和worker的状态很详细

uwsgi --stop uwsgi/uwsgi.pid

停止uwsgi服务后,用ps命令查看uwsgi的进程,已经不存在了


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/12270064.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-24
下一篇 2023-05-24

发表评论

登录后才能评论

评论列表(0条)

保存