AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 126696
Accepted
Dane O'Connor
Dane O'Connor
Asked: 2010-03-27 10:39:03 +0800 CST2010-03-27 10:39:03 +0800 CST 2010-03-27 10:39:03 +0800 CST

Ubuntu 9.10:如何对似乎无法运行的启动脚本进行故障排除?

  • 772

我创建了一个 bash 脚本“foo”。我已经使该脚本可执行

chmod+x 

并通过运行将其添加到启动中

sudo update-rc.d foo defaults 80

尽管如此,它似乎并没有在启动时工作。有没有办法让我的脚本将消息回显到日志?或者是否有一些日志可以记录事件/错误?

自动取款机,我觉得我在瞎飞,真的不知道如何解决这个问题。

根据要求,这是我的脚本的内容:

#!/bin/bash
modprobe uinput
/home/dane/dev/mangler/run.sh /home/dane/dev/mangler/dane/keys.js

run.sh 命令执行程序 kbd-mangler.exe。在 gnome-terminal 中运行以下命令时,它可以工作:

~/$ sudo bash custom_keys.sh
ubuntu log-files troubleshooting startup-scripts ubuntu-9.10
  • 5 5 个回答
  • 8624 Views

5 个回答

  • Voted
  1. Dennis Williamson
    2010-03-27T11:00:33+08:002010-03-27T11:00:33+08:00

    看一下logger命令。

    在脚本的开头添加这样的一行:

    logger "foo started"
    

    添加一条简单的消息,以/var/log/syslog表明您的脚本正在执行某些操作。

    • 3
  2. Zoredache
    2010-03-27T11:08:34+08:002010-03-27T11:08:34+08:00

    如果您使用 sudo 运行该脚本,它是否有效?如果脚本设置正确,我见过的最常见错误与未正确设置环境有关。

    例如,在脚本开头显式设置 PATH 或对运行的任何命令使用完整路径是一种很好的做法。

    80也是你真正需要的水平吗?您是否依赖尚未开始的事情?

    您的脚本是否充分检查您运行的事物的错误级别,然后做出适当的响应。良好的脚本和编程要求您正确地观察和处理错误。

    将一些echo status语句放入您的脚本中,并在系统启动时仔细观察。使用记录器会有所帮助,因为您可以将输出发送到系统日志。

    您可以将 a 添加set -x到脚本的第一行,并将 a添加到sleep 120最后一行,然后注意错误。这基本上会在您的屏幕上执行每条语句,然后等待几分钟,以便您有机会阅读和识别问题。

    • 1
  3. 3dinfluence
    2010-03-27T11:11:38+08:002010-03-27T11:11:38+08:00

    只是为了补充建议的内容。

    我还将验证符号链接 /etc/rc2.d/S80foo 是否已创建并正确链接。如果文件 foo 不存在,update-rc.d 应该会给你一个错误,但仔细检查并没有什么坏处。

    • 1
  4. Best Answer
    Florin Andrei
    2010-03-27T12:47:38+08:002010-03-27T12:47:38+08:00

    在脚本的开头,添加以下行:

    exec > /tmp/debug-my-script.txt 2>&1
    

    重启。现在看看 /tmp 中的那个文件——它应该告诉你发生了什么。

    顺便说一句,在 init.d 脚本中,我倾向于使用带有完整路径 (/sbin/modprobe) 的命令。我已经被这些脚本使用的受限 PATH 烧毁了很多次,我现在不做任何假设。:)

    顺便说一句,好的 Bash 编程链接:

    http://mywiki.wooledge.org/BashFAQ

    http://mywiki.wooledge.org/BashPitfalls

    http://mywiki.wooledge.org/BashGuide

    • 1
  5. d34dh0r53
    2010-03-27T11:01:21+08:002010-03-27T11:01:21+08:00

    您可以使用 logger 命令将条目添加到日志文件:

    logger -i "Foo Starting"
    
    • 0

相关问题

  • 设置没有密码的用户

  • 在 Ubuntu 上设置电子邮件服务器

  • 网速慢 - 我应该检查什么?

  • 保护新的 Ubuntu 服务器 [关闭]

  • (软)Ubuntu 7.10 上的 RAID 6,我应该迁移到 8.10 吗?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve