Samba Service Printer Does Not Execute

Я установил службу samba на свой raspberry pi 3 linux: Джесси (Debian 8) .

smb.conf

[global]
  netbios name = medicalexporter
  workgroup = WORKGROUP

  public = yes

  # Run a WINS server
  wins support = yes

  local master = yes
  preferred master = yes
  os level = 65

  log level = 10
  log file = /home/pi/logs/samba.log.%m

[SambaTest]
  comment = Samba-Test-Freigabe
  path = /home/pi/shares/test
  read only = no

[pdfCreatorLinux]
  path = /tmp
  printable = yes
  guest ok = yes
  print command = /usr/bin/printpdf %s
  lpq command =
  lprm command =

/ usr / bin / printpdf

#!/bin/sh
LOG_FILE=/home/pi/logs/pdf.log
exec 3>&1 1>>${LOG_FILE} 2>&1
DATE="date +%b%d-%H%M%S"
OUTDIR=/home/pi/shr/pdfdropbox

"hello" >> /home/pi/logs/2.log
ps2pdf $1 \$OUTDIR/\$DATE.temp
mv \$OUTDIR/\$DATE.temp \$OUTDIR/\$DATE.pdf
rm \$1

В целях тестирования я дал этому скрипту разрешение 777 с sudo chmod 777 / usr / bin / printpdf

папка samba

mkdir -p ~/shr/pdfdropbox
chown root:root ~/shr/pdfdropbox
chmod u+rwx ~/shr/pdfdropbox

У службы samba есть пользователь и работают smbd и nmbd . Я вижу службу samba на моем Mac в разделе общий доступ и получаю доступ к папке общего доступа.Я вижу принтер под сетевыми принтерами. Когда я распечатываю документ через принтер samba, он показывает мне, что он подключается, отправляет данные и что данные получены без сбоев.

Но похоже, что / usr / bin / printpdf не выполняется. В журналах / home / pi / нет ничего, кроме журналов самой samba (два журнала, один с именем моего компьютера и один с ip).

Когда я запускаю pdf-скрипт вручную, создаются журналы.

PS: Я в основном придерживался этого руководства: http://www.tldp.org/LDP/LG/issue72/bright.html

Вопрос

Почему скрипт не выполняется?

0
23.06.2016, 10:57
2 ответа

Я считаю, что в этой строке есть ошибка:

"привет" >> /home/pi/logs/2.log

Вы можете попробовать

echo "привет" >> / home / pi / logs / 2.log

И вы цитируете $ в остальной части скрипта. Я бы попытался удалить \ s. И укажите полные имена файлов.

В конце:

echo "hello" >> /home/pi/logs/2.log
ps2pdf "$1" "$OUTDIR/$DATE.temp"
mv "$OUTDIR/$DATE.temp" "$OUTDIR/$DATE.pdf"
rm "$1"

во второй половине вашего скрипта

0
28.01.2020, 04:50

Итак, я нашел несколько вещей. Сначала мне нужно было добавить Printing = BSD , возможно, в противном случае используется CUPS, который переопределяет настройки . Затем мне нужно было установить printcap name = / dev / null , иначе файлы ghostscript исчезли раньше, чем я смог получить к ним доступ. Команды lpq и lpr не требуются.

[pdfCreatorLinux2]
#  load printers = no
  printcap name = /dev/null
  path = /tmp/
  printable = yes
  printing = BSD
  print command = /usr/bin/printpdf %s
#  lpq command =
#  lprm command =

Во-вторых, все скрипты и папки должны быть доступны пользователю сервиса samba.

PS: Я также скорректировал pdf-скрипт, но не по этой причине он не был выполнен.

#!/bin/sh
LOG_FILE=/home/pi/logs/pdf.log
exec 3>&1 1>${LOG_FILE} 2>>&1
DATE=$(date +"%m_%d_%Y")
OUTDIR="/home/pi/shr/pdfdropbox"

ps2pdf $1 "$OUTDIR/$DATE.temp"
mv $OUTDIR/$DATE.temp $OUTDIR/$DATE.pdf
rm $1
0
28.01.2020, 04:50

Теги

Похожие вопросы