linux后台启动程序,处理nohup日志太大的问题

本文详细介绍了LINUX命令nohup的用法,包括其如何使进程在后台持续运行,即使用户退出。文章还讲解了nohup.out文件的作用、查看方法及管理策略,提供了清空nohup.out文件而不影响服务的两种方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.nohup.out的由来及作用

用途:LINUX命令用法,不挂断地运行命令。 

语法:nohup Command [ Arg ... ] [ & ] 

描述:nohup 命令运行由 Command 参数和任何相关的 Arg 参数指定的命令,忽略所有挂断(SIGHUP)信号。在注销后使用 nohup 命令运行后台中的程序。要运行后台中的 nohup 命令,添加 & ( 表示“and”的符号)到命令的尾部。 

例子: nohup ./startWeblogic.sh  &  意思是即使退出ssh界面,命令仍然在后台执行,并且打印过程日志到nohup.out,当然也可以将nohup.out的输出转向到其他文件,高级应用请参考扩展阅读。

2.nohup.out的查看方式与方法

实际使用过程中,往往人们为了省心(嗯,没错,就是懒),经常没有给nohup.out进行重定向输出,也没有按日期分割文件,会造成这个文件特别巨大,达到2G或者3G,这个使用想查看文件,搜索出错内容就比较痛苦了。一般有两种方式

1.linux本机查看:使用tail 命令,查看最新的日志,或滚动监控日志打印。

例如命令 tail -1000 nohup.out (查看最后1000行日志文本) tail -f nohup.out(监控日志打印)

2.ftp下载到windown主机查看:一般小的log文件都没有问题,但是过G的,一般的文本文档查看就显得无力了。推荐使用UltraEdit进行打开。

3.nohup.out维护管理方法(清空nohup.out)

如上文所述出现了超大号的文件简直是令人讨厌的事情,而且nohup.out会一直一直自己增长下去,如果你的服务器硬盘不给力的话,很容易把应用也挂掉(硬盘没空间 ,啥都玩不转),但是又不能一味的直接删。因为直接删除,可能会造成应用无法打印后续的错误日志,该问题常见于weblogic服务器,jboss服务器等这些大型中间件,这个在生产环境上要尤为注意。

因此就有了我们不停止服务直接,清空nohup.out文件的方法。

两个可以不用停止WEB服务就可以清空nohup.out的命令。

第一种:cp /dev/null nohup.out

第二种:cat /dev/null > nohup.out

两个我都用过,不用担心网上所说的性能问题,通常2/3  个G的文件都是1-2秒执行完毕

4.扩展阅读

1.nohup的重定向,一劳永逸解决nohup.out文件过大的问题
以下是定义日志打印级别,除了高于级别2的告警信息记录到log文件外,其余直接不记录
只输出错误信息到日志文件

nohup ./program >/dev/null 2>log &

什么信息也不要

nohup ./program >/dev/null 2>&1 &
2.Linux的3中重定向
0:表示标准输入
1:标准输出,在一般使用时,默认的是标准输出
2:标准错误信息输出
可以用来指定需要重定向的标准输入或输出。例如,将某个程序的错误信息输出到log文件中:./program 2>log。这样标准输出还是在屏幕上,但是错误信息会输出到log文件中。另外,也可以实现0,1,2之间的重定向。2>&1:将错误信息重定向到标准输出。

3.关于/dev/null文件

Linux下还有一个特殊的文件/dev/null,它就像一个无底洞,所有重定向到它的信息都会消失得无影无踪。这一点非常有用,当我们不需要回显程序的所有信息时,就可以将输出重定向到/dev/null。
 基本IO

  cmd > file                        把 stdout 重定向到 file 文件中
  cmd >> file                        把 stdout 重定向到 file 文件中(追加)
  cmd 1> fiel                        把 stdout 重定向到 file 文件中
  cmd > file 2>&1                把 stdout 和 stderr 一起重定向到 file 文件中
  cmd 2> file                        把 stderr 重定向到 file 文件中
  cmd 2>> file                        把 stderr 重定向到 file 文件中(追加)
  cmd >> file 2>&1                把 stderr 和 stderr 一起重定向到 file 文件中
  cmd < file >file2                cmd 命令以 file 文件作为 stdin,以 file2 文件作为 stdout
  cat <>file                             以读写的方式打开 file
  cmd < file                        cmd 命令以 file 文件作为 stdin
  cmd << delimiter                Here document,从 stdin 中读入,直至遇到delimiter 分界符
<think>嗯,用户问的是“es后台启动”,我需要先弄清楚这里的“es”指的是什么。通常,“ES”可以代表多个技术相关的术语,最常见的是Elasticsearch,也可能是指Eclipse Scout或者其他东西。不过结合“后台启动”这个上下文,可能性最的应该是Elasticsearch,因为它在服务器环境中经常需要以后台进程运行。 首先,我应该确认用户的环境,比如操作系统是Linux还是Windows。不过用户没有具体说明,可能需要给出两种系统的解决方案。但根据经验,Elasticsearch在Linux服务器上更常见,所以可能重点放在Linux上,但也要涵盖Windows的情况。 接下来,用户可能想知道如何将Elasticsearch作为后台服务启动,而不仅仅是前台运行。通常,直接运行elasticsearch命令会在前台启动,退出终端后进程就结束了,所以需要后台运行的方法。 对于Linux系统,常见的方法包括使用nohup配合&符号,或者使用systemd服务来管理。如果是使用tar.gz包安装的话,可能需要手动配置systemd服务文件。而如果是通过deb或rpm包安装的,可能已经自动配置好了systemd,可以直接使用systemctl命令。 然后,Windows系统的话,可能需要以服务的形式安装,使用--install参数,然后通过net start来启动。不过用户可能对Windows服务管理不太熟悉,需要给出具体步骤。 另外,用户可能没有明确说明是否已经安装Elasticsearch,或者是否配置了正确的环境变量。这时候可能需要提醒用户确保安装正确,并且JAVA_HOME设置正确,因为Elasticsearch依赖Java。 还有,后台启动之后,如何验证是否成功运行?可能需要告诉用户使用curl或者浏览器访问9200端口来检查状态。 可能还需要提到日志的位置,以便用户排查问题,比如在Linux下是logs目录,或者systemd的journalctl查看日志。 总结一下,回答的结构应该是先确认“es”指的是Elasticsearch,然后分Linux和Windows两种情况讲解后台启动的方法,包括使用nohup、systemd以及Windows服务的方式。然后给出验证方法和常见问题提示,比如Java环境、权限问题等。确保步骤清晰,用户能一步步操作,同时提醒需要注意的地方,比如防火墙设置或者配置文件修改。</think>关于“ES后台启动”,通常指的是Elasticsearch(分布式搜索和分析引擎)在服务器环境中以后台进程方式启动。以下是分步说明: ### 1. 确认环境 - **操作系统**:Linux/Unix系统或Windows系统 - **安装方式**:通过压缩包(tar.gz/zip)或包管理器(apt/yum)安装 --- ### 2. Linux/Unix系统后台启动方法 #### 方法一:使用 `nohup` 命令 ```bash # 进入Elasticsearch安装目录的bin文件夹 cd /path/to/elasticsearch/bin # 使用nohup后台启动(默认绑定本地地址,端口9200) nohup ./elasticsearch > /dev/null 2>&1 & ``` #### 方法二:通过Systemd服务(推荐) 1. 创建systemd服务文件: ```bash sudo nano /etc/systemd/system/elasticsearch.service ``` 2. 添加以下内容(根据实际路径修改): ```ini [Unit] Description=Elasticsearch After=network.target [Service] User=elasticsearch Group=elasticsearch ExecStart=/path/to/elasticsearch/bin/elasticsearch Restart=always LimitNOFILE=65536 [Install] WantedBy=multi-user.target ``` 3. 启动并设置开机自启: ```bash sudo systemctl daemon-reload sudo systemctl start elasticsearch sudo systemctl enable elasticsearch ``` --- ### 3. Windows系统后台启动 1. 以管理员身份打开CMD/PowerShell 2. 安装为服务: ```powershell cd C:\path\to\elasticsearch\bin .\elasticsearch-service.bat install ``` 3. 启动服务: ```powershell .\elasticsearch-service.bat start ``` --- ### 4. 验证是否启动成功 ```bash curl http://localhost:9200 # 或浏览器访问 http://服务器IP:9200 ``` 成功响应示例: ```json { "name" : "node-1", "cluster_name" : "elasticsearch", "version" : { ... } } ``` --- ### 5. 常见问题排查 - **权限问题**:Linux下需确保用户对Elasticsearch目录有读写权限。 - **Java环境**:需安装Java 8或更高版本,并设置`JAVA_HOME`环境变量。 - **端口冲突**:检查9200和9300端口是否被占用。 - **内存不足**:调整`config/jvm.options`中的堆内存参数(如`-Xms1g -Xmx1g`)。 --- 通过以上步骤,可确保Elasticsearch稳定运行于后台。建议优先使用systemd(Linux)或服务(Windows)管理,便于监控和自动重启。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值