0

嗨,我遇到了 qmail 的问题。我想从我的程序发送一封电子邮件,我从 qmail-inject 收到 111 错误代码。但是,如果我尝试从命令行发送相同的电子邮件,它就可以工作。

在我的代码中:

if ((pid = fork()) < 0) {
        logger.error("error creating on new process");
}

else if (pid == 0) {
      logger.info("qmail-inject is calling now for Dlp Notify");
      if (execl("/opt/program/bin/sendmail","sendmail", notifySender, tempMail,(char*)   0) == -1)  {
        logger.error("notify operation failed: %s", strerror(errno));
        exit(1);
    }
}

sendmail 就是这样的脚本:

/bin/cat $2 | /opt/smtp/bin/qmail-inject -f   $1

当我在命令行上运行这个脚本时效果很好。但是从我的程序不起作用。

任何帮助,将不胜感激。

4

1 回答 1

0

qmail-inject至少从您向我们展示的内容来看,您要执行的 C 代码看起来不错。

man qmail-inject 告诉我们退出代码 111 表示临时错误

qmail-inject的来源(v1.03,这里看起来与 netqmail 1.06 相同)显示以下内容:

void temp() { _exit(111); }
void die_nomem() {
 substdio_putsflush(subfderr,"qmail-inject: fatal: out of memory\n"); temp(); }
void die_invalid(sa) stralloc *sa; {
 substdio_putsflush(subfderr,"qmail-inject: fatal: invalid header field: ");
 substdio_putflush(subfderr,sa->s,sa->len); perm(); }
void die_qqt() {
 substdio_putsflush(subfderr,"qmail-inject: fatal: unable to run qmail-queue\n"); temp(); }
void die_chdir() {
 substdio_putsflush(subfderr,"qmail-inject: fatal: internal bug\n"); temp(); }
void die_read() {
 if (errno == error_nomem) die_nomem();
 substdio_putsflush(subfderr,"qmail-inject: fatal: read error\n"); temp(); }

从后者(以及对 的更多查找qmail-inject.c)可以得出以下可能导致qmail-inject111 退出的原因:

  • 记不清
  • 无效的标头字段(传递到-f配置/控制文件或从配置/控制文件读取)
  • 无法运行qmail-queue(可能是因为它不存在,或者缺少它的搜索路径)
  • 无法控制/chdir配置qmail文件夹
  • 无法读取 qmail 的配置/控制文件

检查您身边的日志也可能会有所帮助。

于 2012-11-16T14:23:01.977 回答