ArchLinux: Samba Public Ordner

Life_is_short

Neuling
Thread Starter
Mitglied seit
08.09.2005
Beiträge
220
Hallo zusammen!

Ich schlage mich seit einigen Tagen mit einem Problem herum und komme einfach nicht auf einen grünen Zweig.

Folgendes:
Ich habe auf meinem ArchLinux Samba installiert (genau nach Anleitung der archwiki). Die Deamons sind auch alle in der rc.conf registriert und laufen somit.
Dann wollte ich einen im Netzwerk öffentlichen Ordner erstellen.
Dazu änderte ich in der smb.conf folgende Einträge:

security = share

# A publicly accessible directory, but read only, except for people in
# the "staff" group
[Public]
comment = Public Stuff
path = /home/stefan/Public
public = yes
writable = yes
printable = no

... Tipte dann

sudo /etc/rc.d/samba restart

ein und dachte, damit hätte es sich.
Es klappt auch alles bis auf ein entscheidendes Detail. Auf dem Windows Rechner finde ich meinen Linux Rechner, ich finde auch den Ordner Public, aber wenn ich auf ihn doppelklicke, erscheint folgende Fehlermeldung:



Auf \\MacBook-Pro\Public kann nicht zugegriffen werden. Sie haben eventuell keine Berechtigung, diese Netzwerkressource zu verwenden. Wenden Sie sich an den Administrator des Servers, um herauszufinden, ob sie über Berechtigungen verfügen.

Es sind mehr Daten verfügbar.




Und ich kann nicht auf meinen Sharddocs Ordner zugreifen. Umgekehrt funktioniert aber alles. Ich kann mit meinem Linux Rechner auf die Shareddocs der Windows Rechner zugreifen.

Hat jemand eine Idee? Vielen Dank im Voraus!

MFG
 
Wenn Du diese Anzeige nicht sehen willst, registriere Dich und/oder logge Dich ein.
Eventuell hast du ein paar Sachen in der smb.conf durcheinandergewürfelt.

Alle Parameter und Optionen müssen am Anfang unter Global definiert werden, und erst ganz zum Schluss kommen die Freigaben.

Desweiteren solltest du sicherstellen, dass der freizugebende Ordner auch für Guest mindestens lesbar ist:

chmod -R 775 /meine/Freigabe

Dann nochmal Samba neustarten und testen ;)

Ansonsten hab ich auch ein How-To für dich: http://www.hardwareluxx.de/community/showthread.php?t=683509

mfg
foxxx :wink:
 
Danke für deine Antwort. Ich glaube ich werde hier mal meine smb.conf posten:

# This is the main Samba configuration file. You should read the
# smb.conf(5) manual page in order to understand the options listed
# here. Samba has a huge number of configurable options (perhaps too
# many!) most of which are not shown in this example
#
# For a step to step guide on installing, configuring and using samba,
# read the Samba-HOWTO-Collection. This may be obtained from:
# http://www.samba.org/samba/docs/Samba-HOWTO-Collection.pdf
#
# Many working examples of smb.conf files can be found in the
# Samba-Guide which is generated daily and can be downloaded from:
# http://www.samba.org/samba/docs/Samba-Guide.pdf
#
# Any line which starts with a ; (semi-colon) or a # (hash)
# is a comment and is ignored. In this example we will use a #
# for commentry and a ; for parts of the config file that you
# may wish to enable
#
# NOTE: Whenever you modify this file you should run the command "testparm"
# to check that you have not made any basic syntactic errors.
#
#======================= Global Settings =====================================
[global]

# workgroup = NT-Domain-Name or Workgroup-Name, eg: MIDEARTH
workgroup = GAMSABETAWEG

# server string is the equivalent of the NT Description field
server string = Shareddocs

# Security mode. Defines in which mode Samba will operate. Possible
# values are share, user, server, domain and ads. Most people will want
# user level security. See the Samba-HOWTO-Collection for details.
security = share

# This option is important for security. It allows you to restrict
# connections to machines which are on your local network. The
# following example restricts access to two C class networks and
# the "loopback" interface. For more examples of the syntax see
# the smb.conf man page
; hosts allow = 192.168.1. 192.168.2. 127.

# If you want to automatically load your printer list rather
# than setting them up individually then you'll need this
load printers = yes

# you may wish to override the location of the printcap file
; printcap name = /etc/printcap

# on SystemV system setting printcap name to lpstat should allow
# you to automatically obtain a printer list from the SystemV spool
# system
; printcap name = lpstat

# It should not be necessary to specify the print system type unless
# it is non-standard. Currently supported print systems include:
# bsd, cups, sysv, plp, lprng, aix, hpux, qnx
; printing = cups

# Uncomment this if you want a guest account, you must add this to /etc/passwd
# otherwise the user "nobody" is used
; guest account = pcguest

# this tells Samba to use a separate log file for each machine
# that connects
log file = /var/log/samba/%m.log

# Put a capping on the size of the log files (in Kb).
max log size = 50

# Use password server option only with security = server
# The argument list may include:
# password server = My_PDC_Name [My_BDC_Name] [My_Next_BDC_Name]
# or to auto-locate the domain controller/s
# password server = *
; password server = <NT-Server-Name>

# Use the realm option only with security = ads
# Specifies the Active Directory realm the host is part of
; realm = MY_REALM

# Backend to store user information in. New installations should
# use either tdbsam or ldapsam. smbpasswd is available for backwards
# compatibility. tdbsam requires no further configuration.
; passdb backend = tdbsam

# Using the following line enables you to customise your configuration
# on a per machine basis. The %m gets replaced with the netbios name
# of the machine that is connecting.
# Note: Consider carefully the location in the configuration file of
# this line. The included file is read at that point.
; include = /usr/local/samba/lib/smb.conf.%m

# Configure Samba to use multiple interfaces
# If you have multiple network interfaces then you must list them
# here. See the man page for details.
; interfaces = 192.168.12.2/24 192.168.13.2/24

# Browser Control Options:
# set local master to no if you don't want Samba to become a master
# browser on your network. Otherwise the normal election rules apply
; local master = no

# OS Level determines the precedence of this server in master browser
# elections. The default value should be reasonable
; os level = 33

# Domain Master specifies Samba to be the Domain Master Browser. This
# allows Samba to collate browse lists between subnets. Don't use this
# if you already have a Windows NT domain controller doing this job
; domain master = yes

# Preferred Master causes Samba to force a local browser election on startup
# and gives it a slightly higher chance of winning the election
; preferred master = yes

# Enable this if you want Samba to be a domain logon server for
# Windows95 workstations.
; domain logons = yes

# if you enable domain logons then you may want a per-machine or
# per user logon script
# run a specific logon batch file per workstation (machine)
; logon script = %m.bat
# run a specific logon batch file per username
; logon script = %U.bat

# Where to store roving profiles (only for Win95 and WinNT)
# %L substitutes for this servers netbios name, %U is username
# You must uncomment the [Profiles] share below
; logon path = \\%L\Profiles\%U

# Windows Internet Name Serving Support Section:
# WINS Support - Tells the NMBD component of Samba to enable it's WINS Server
; wins support = yes

# WINS Server - Tells the NMBD components of Samba to be a WINS Client
# Note: Samba can be either a WINS Server, or a WINS Client, but NOT both
; wins server = w.x.y.z

# WINS Proxy - Tells Samba to answer name resolution queries on
# behalf of a non WINS capable client, for this to work there must be
# at least one WINS Server on the network. The default is NO.
; wins proxy = yes

# DNS Proxy - tells Samba whether or not to try to resolve NetBIOS names
# via DNS nslookups. The default is NO.
dns proxy = no

# These scripts are used on a domain controller or stand-alone
# machine to add or delete corresponding unix accounts
; add user script = /usr/sbin/useradd %u
; add group script = /usr/sbin/groupadd %g
; add machine script = /usr/sbin/adduser -n -g machines -c Machine -d /dev/null -s /bin/false %u
; delete user script = /usr/sbin/userdel %u
; delete user from group script = /usr/sbin/deluser %u %g
; delete group script = /usr/sbin/groupdel %g


#============================ Share Definitions ==============================
[homes]
comment = Home Directories
browseable = no
writable = yes

# Un-comment the following and create the netlogon directory for Domain Logons
; [netlogon]
; comment = Network Logon Service
; path = /usr/local/samba/lib/netlogon
; guest ok = yes
; writable = no
; share modes = no


# Un-comment the following to provide a specific roving profile share
# the default is to use the user's home directory
;[Profiles]
; path = /usr/local/samba/profiles
; browseable = no
; guest ok = yes


# NOTE: If you have a BSD-style print system there is no need to
# specifically define each individual printer
[printers]
comment = All Printers
path = /var/spool/samba
browseable = no
# Set public = yes to allow user 'guest account' to print
guest ok = no
writable = no
printable = yes

# This one is useful for people to share files
;[tmp]
; comment = Temporary file space
; path = /tmp
; read only = no
; public = yes

# A publicly accessible directory, but read only, except for people in
# the "staff" group
[Public]
comment = Public Stuff
path = /home/stefan/Public
public = yes
writable = yes
printable = no

# Other examples.
#
# A private printer, usable only by fred. Spool data will be placed in fred's
# home directory. Note that fred must have write access to the spool directory,
# wherever it is.
;[fredsprn]
; comment = Fred's Printer
; valid users = fred
; path = /homes/fred
; printer = freds_printer
; public = no
; writable = no
; printable = yes

# A private directory, usable only by fred. Note that fred requires write
# access to the directory.
;[fredsdir]
; comment = Fred's Service
; path = /usr/somewhere/private
; valid users = fred
; public = no
; writable = yes
; printable = no

# a service which has a different directory for each machine that connects
# this allows you to tailor configurations to incoming machines. You could
# also use the %U option to tailor it by user name.
# The %m gets replaced with the machine name that is connecting.
;[pchome]
; comment = PC Directories
; path = /usr/pc/%m
; public = no
; writable = yes

# A publicly accessible directory, read/write to all users. Note that all files
# created in the directory by users will be owned by the default user, so
# any user with access can delete any other user's files. Obviously this
# directory must be writable by the default user. Another user could of course
# be specified, in which case all files would be owned by that user instead.
;[public]
; path = /usr/somewhere/else/public
; public = yes
; only guest = yes
; writable = yes
; printable = no

# The following two entries demonstrate how to share a directory so that two
# users can place files there that will be owned by the specific users. In this
# setup, the directory should be writable by both users and should have the
# sticky bit set on it to prevent abuse. Obviously this could be extended to
# as many users as required.
;[myshare]
; comment = Mary's and Fred's stuff
; path = /usr/somewhere/shared
; valid users = mary fred
; public = no
; writable = yes
; printable = no
; create mask = 0765


Sieht das etwas nicht in Ordnung aus?

MFG
 
Die Freigaben sind ja gar nicht definiert. Ich würde dir empfehlen, die originale Conf unter anderen Namen zu speichern und eine neue anzulegen, dann hast du auch den Überblick.

Beispielhaft hier mal meine:
 

Anhänge

  • smb.conf.png
    smb.conf.png
    7,1 KB · Aufrufe: 118
Zuletzt bearbeitet:
füg mal noch unter security = share folgendes ein:

encrypt passwords = true

und bei deiner Freigabe noch:

browseable = yes
guest ok = yes

Dann sollte es gehen ;)

mfg
foxxx :wink:
 
hallo foxxx,
Deine Tips brachten leider nicht den gewünschten Erfolg. Es erscheint immer noch die gleiche Fehlermeldung.

@ Karbe:
Ich vermute du benützt Debian. Ich weiss einfach von Ubuntu, dass ein Shareddocs Ordner einrichten nicht so viel Aufwand benötigt. Warum funktioniert es nicht in Archlinux? Gibt es einen Assistenten, mit dem man das einrichten kann? (smb4k finde ich sch*****)

Mfg
 
Hast du mal ein Backup deiner Config gemacht und meine minimal-Config für Freigaben ohne Anmeldung für deine Freigabe abgeändert und getestet ?

Vielleicht ist bei dir noch irgendwo der Wurm drin, was in der riesigen Config total unübersichtlich ist ;)

mfg
foxxx :wink:
 
http://wiki.archlinux.org/index.php/Samba#smb.conf

Diese Anleitung habe ich benutzt. In ihr wird zuerst eine default conf Datei in eine aktuell genutzte Datei umbenannt und kopiert. Ich nehme an, die ";" haben die gleiche Wirkung wie "#".

Ein Versuch wäre es ja wert. Kann mir jemand seine smb.conf Datei schicken, in der er einen Shareddocs Ordner angelegt hat?

Mfg
 
Ich würde von einer minimalen Konfiguration ausgehen, als eine "komplette" irgendwie zurechtzubiegen, so daß sie funktioniert.

Hast du versucht mittels
Code:
	log level = 3
oder ähnlich in der smb.conf eine ausführlichere Fehlerausgabe zu erhalten?

Kannst du mit Linux auf die freigegeben Shares zugreifen ?
( testparm für "testen" der smb.conf , smbclient, smbtree zum testen des Zugriffes )

Vielleicht versucht dein Windows anders auf Samba zuzugreifen ?
Es gibt ja verschiedene Protokolle: Lanman, NTLM, NTLMv2.
In Windows selbst kann man die Zugriffsmöglichkeit ändern oder in Samba müssen dann die entsprechenden Optionen gesetzt werden. (Logfile ansehen)

Code:
client ntlmv2 auth = yes

Bei Zugriffsproblemen hilft vielleicht auch
Code:
map to guest = bad user
guest account = nobody
 
http://wiki.archlinux.org/index.php/Samba#smb.conf

Diese Anleitung habe ich benutzt. In ihr wird zuerst eine default conf Datei in eine aktuell genutzte Datei umbenannt und kopiert. Ich nehme an, die ";" haben die gleiche Wirkung wie "#".

Ein Versuch wäre es ja wert. Kann mir jemand seine smb.conf Datei schicken, in der er einen Shareddocs Ordner angelegt hat?

Mfg

Siehe mein Guide: http://www.hardwareluxx.de/community/showthread.php?t=683509

steht auch paar Posts weiter oben.

Dort die smb.conf für "ohne Anmeldung" kopieren und nur unten die Freigabe anpassen ;)
 
So. Habe den "Fehler" gefunden. Ich musste den Public Ordner unter /home/ erstellen, dann klappt es.
Jetzt ist es aber so, dass ich jedes mal, wenn ich meinen Rechner (linux) neustarte, Samba nochmals neustarten muss, damit es funktioniert, obwohl ich samba in die DAEMONS*liste eingetragen habe. Wie kommt das nun wieder zustande?

MFG
 
poste mal deine rc.conf. Bitte ohne Kommentare (#............)
 
LOCALE="en_US.UTF-8"
HARDWARECLOCK="UTC"
TIMEZONE="Europe/Zurich"
KEYMAP="de_CH-latin1"
CONSOLEFONT=
CONSOLEMAP=
USECOLOR="yes"

MOD_AUTOLOAD="yes"
MODULES=(lib80211_crypt_tkip wl !b43 !ssb)
USELVM="no"
HOSTNAME=MacBook-Pro
eth0="dhcp"
INTERFACES=(!eth0)
gateway="default gw 192.168.0.1"
ROUTES=(!gateway)
DAEMONS=(syslog-ng hal !network networkmanager netfs crond bluetooth fam pommed samba)
 
problem gelöst.

ipv6 musste deaktiviert werden:)

danke an alle, die geholfen haben!

mfg
 
Hardwareluxx setzt keine externen Werbe- und Tracking-Cookies ein. Auf unserer Webseite finden Sie nur noch Cookies nach berechtigtem Interesse (Art. 6 Abs. 1 Satz 1 lit. f DSGVO) oder eigene funktionelle Cookies. Durch die Nutzung unserer Webseite erklären Sie sich damit einverstanden, dass wir diese Cookies setzen. Mehr Informationen und Möglichkeiten zur Einstellung unserer Cookies finden Sie in unserer Datenschutzerklärung.


Zurück
Oben Unten refresh