From 20967627378194121bc48bf387838b8bd7682478 Mon Sep 17 00:00:00 2001
From: Jelmer Vernooij The man pages distributed with SAMBA contain
- lots of useful info that will help to get you started.
- If you don't know how to read man pages then try
- something like: $ man smbd.8
- or
- $ nroff -man smbd.8 | more
- on older unixes. Other sources of information are pointed to
- by the Samba web site,Binary packages of samba are included in almost any Linux or
+ Unix distribution. There are also some packages available at
+ http://www.samba.org To do this, first run the program ./configure
- in the source directory. This should automatically
- configure Samba for your operating system. If you have unusual
- needs then you may wish to run root# ./configure --help
- first to see what special options you can enable.
- Then executing root# make will create the binaries. Once it's successfully
- compiled you can use root# make install to install the binaries and manual pages. You can
- separately install the binaries and/or man pages using root# make installbin
- and root# make installman
- Note that if you are upgrading for a previous version
- of Samba you might like to know that the old versions of
- the binaries will be renamed with a ".old" extension. You
- can go back to the previous version with root# make revert
- if you find this version a disaster!1.2. Building the Binaries
There are sample configuration files in the examples subdirectory in the distribution. I suggest you read them @@ -288,19 +172,18 @@ CLASS="FILENAME" >
For more information about security settings for the [homes] share please refer to the document UNIX_SECURITY.txt.
It's important that you test the validity of your smb.conf!
You must choose to start smbd and nmbd either - as daemons or from inetd. Don't try - to do both! Either you can put them in inetd.conf and have them started on demand - by inetd, or you can start them as - daemons either from the command line or in /etc/rc.local. See the man pages for details - on the command line options. Take particular care to read - the bit about what user you need to be in order to start - Samba. In many cases you must be root.
The main advantage of starting smbd - and nmbd using the recommended daemon method - is that they will respond slightly more quickly to an initial connection - request.
NOTE; The following will be different if - you use NIS or NIS+ to distributed services maps.
Look at your /etc/services. - What is defined at port 139/tcp. If nothing is defined - then add a line like this:
netbios-ssn 139/tcp
similarly for 137/udp you should have an entry like:
netbios-ns 137/udp
Next edit your /etc/inetd.conf - and add two lines something like this:
netbios-ssn stream tcp nowait root /usr/local/samba/bin/smbd smbd - netbios-ns dgram udp wait root /usr/local/samba/bin/nmbd nmbd -
The exact syntax of /etc/inetd.conf - varies between unixes. Look at the other entries in inetd.conf - for a guide.
NOTE: Some unixes already have entries like netbios_ns - (note the underscore) in /etc/services. - You must either edit /etc/services or - /etc/inetd.conf to make them consistent.
NOTE: On many systems you may need to use the - "interfaces" option in smb.conf to specify the IP address - and netmask of your interfaces. Run ifconfig - as root if you don't know what the broadcast is for your - net. nmbd tries to determine it at run - time, but fails on some unixes. See the section on "testing nmbd" - for a method of finding if you need to do this.
!!!WARNING!!! Many unixes only accept around 5 - parameters on the command line in inetd.conf. - This means you shouldn't use spaces between the options and - arguments, or you should use a script, and start the script - from inetd.
Restart inetd, perhaps just send - it a HUP. If you have installed an earlier version of nmbd then you may need to kill nmbd as well.
To start the server as a daemon you should create - a script something like this one, perhaps calling - it startsmb.
#!/bin/sh - /usr/local/samba/bin/smbd -D - /usr/local/samba/bin/nmbd -D -
then make it executable with chmod - +x startsmb
You can then run startsmb by - hand or execute it from /etc/rc.local -
To kill it send a kill signal to the processes - nmbd and smbd.
NOTE: If you use the SVR4 style init system then - you may like to look at the examples/svr4-startup - script to make Samba fit into that system.
1.2.2. SWATSWAT is a web-based interface that helps you configure samba. + SWAT might not be available in the samba package on your platform, + but in a seperate package. Please read the swat manpage + on compiling, installing and configuring swat from source. +
To launch SWAT just run your favorite web browser and + point it at "http://localhost:901/". Replace localhost with the name of the computer you are running samba on if you + are running samba on a different computer then your browser.
Note that you can attach to SWAT from any IP connected + machine but connecting from a remote machine leaves your + connection open to password sniffing as passwords will be sent + in the clear over the wire.
$ $ smbclient -L - yourhostnameyourhostname
You should get back a list of shares available on @@ -566,39 +273,31 @@ CLASS="SECT1" >
$ $ smbclient smbclient //yourhostname/aservice //yourhostname/aservice
Typically the Typically the yourhostnameyourhostname would be the name of the host where you installed smbd. The . The aserviceaservice is any service you have defined in the For example if your unix host is bambi and your login name is fred you would type:
$ $ smbclient //bambi/fred -
Try mounting disks. eg:
C:\WINDOWS\> C:\WINDOWS\> net use d: \\servername\service -
Try printing. eg:
C:\WINDOWS\> C:\WINDOWS\> net use lpt1: - \\servername\spoolservice
C:\WINDOWS\> C:\WINDOWS\> print filename -
Celebrate, or send me a bug report!
If nothing works and you start to think "who wrote - this pile of trash" then I suggest you do step 2 again (and - again) till you calm down.
1.6. What If Things Don't Work?Then you might read the file DIAGNOSIS.txt and the +>Then you might read the file HOWTO chapter Diagnosis and the FAQ. If you are still stuck then try the mailing list or newsgroup (look in the README for details). Samba has been successfully installed at thousands of sites worldwide, so maybe someone else has hit your problem and has overcome it. You could also use the WWW site to scan back issues of the samba-digest.
When you fix the problem PLEASE send me some updates to the - documentation (or source code) so that the next person will find it - easier.
If you have installation problems then go to the - Diagnosis chapter to try to find the - problem.
By default Samba uses a blank scope ID. This means all your windows boxes must also have a blank scope ID. If you really want to use a non-blank scope ID then you will need to use the 'netbios scope' smb.conf option. - All your PCs will need to have the same setting for + All your PCs will need to have the same setting for this to work. I do not recommend scope IDs.
The SMB protocol has many dialects. Currently - Samba supports 5, called CORE, COREPLUS, LANMAN1, - LANMAN2 and NT1.
You can choose what maximum protocol to support - in the smb.conf file. The default is - NT1 and that is the best for the vast majority of sites.
In older versions of Samba you may have found it - necessary to use COREPLUS. The limitations that led to - this have mostly been fixed. It is now less likely that you - will want to use less than LANMAN1. The only remaining advantage - of COREPLUS is that for some obscure reason WfWg preserves - the case of passwords in this protocol, whereas under LANMAN1, - LANMAN2 or NT1 it uppercases all passwords before sending them, - forcing you to use the "password level=" option in some cases.
The main advantage of LANMAN2 and NT1 is support for - long filenames with some clients (eg: smbclient, Windows NT - or Win95).
See the smb.conf(5) manual page for more details.
Note: To support print queue reporting you may find - that you have to use TCP/IP as the default protocol under - WfWg. For some reason if you leave Netbeui as the default - it may break the print queue reporting on some systems. - It is presumably a WfWg bug.
To use a printer that is available via a smb-based - server from a unix host with LPR you will need to compile the - smbclient program. You then need to install the script - "smbprint". Read the instruction in smbprint for more details. -
There is also a SYSV style script that does much - the same thing called smbprint.sysv. It contains instructions.
See the CUPS manual for information about setting up - printing from a unix host with CUPS to a smb-based server.