嗨,我遇到了 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
当我在命令行上运行这个脚本时效果很好。但从我的程序来看,这是行不通的。
如有任何帮助,我们将不胜感激。
最佳答案
您执行qmail-inject
的C代码看起来不错,至少从您向我们展示的内容来看是这样。
man qmail-inject
tells us exit code 111 indicates a temporary error .
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-inject
以 111 退出的以下可能原因:
- 内存不足
- 无效的 header 字段(传递给
-f
或从配置/控制文件读取) - 无法运行
qmail-queue
(可能是因为它不存在,或者缺少它的搜索路径) - 无法
chdir
到qmail
的控制/配置文件夹 - 无法读取 qmail 的配置/控制文件
检查您这边的日志也可能有所帮助。
关于c++ - qmail-inject 返回 111,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13417419/