summaryrefslogtreecommitdiff
path: root/docs/Samba-HOWTO-Collection
diff options
context:
space:
mode:
authorJohn Terpstra <jht@samba.org>2005-05-16 07:11:57 +0000
committerGerald W. Carter <jerry@samba.org>2008-04-23 08:46:35 -0500
commit06131ac5751494f8d022e0e6b5a013e89e666022 (patch)
tree9f3049d394ef62e91c68d858075a0c11ca057cc6 /docs/Samba-HOWTO-Collection
parent5c6237adc83ace7bf0d159324a26caeecc986403 (diff)
downloadsamba-06131ac5751494f8d022e0e6b5a013e89e666022.tar.gz
samba-06131ac5751494f8d022e0e6b5a013e89e666022.tar.bz2
samba-06131ac5751494f8d022e0e6b5a013e89e666022.zip
Another work in progress commit.
(This used to be commit f3f31c5fa49118d79649827d0c5271a527fb5dba)
Diffstat (limited to 'docs/Samba-HOWTO-Collection')
-rw-r--r--docs/Samba-HOWTO-Collection/TOSHARG-TheNetCommand.xml438
1 files changed, 336 insertions, 102 deletions
diff --git a/docs/Samba-HOWTO-Collection/TOSHARG-TheNetCommand.xml b/docs/Samba-HOWTO-Collection/TOSHARG-TheNetCommand.xml
index 51bf795aee..e2d8590075 100644
--- a/docs/Samba-HOWTO-Collection/TOSHARG-TheNetCommand.xml
+++ b/docs/Samba-HOWTO-Collection/TOSHARG-TheNetCommand.xml
@@ -4,6 +4,7 @@
<chapter id="NetCommand">
<chapterinfo>
&author.jht;
+ &author.vl;
&author.gd;
<pubdate>May 9, 2005</pubdate>
</chapterinfo>
@@ -34,7 +35,7 @@ the infliction of self induced pain, agony and desperation. Be warned, this is a
</para>
<sect1>
- <title>Self-Defense Overview</title>
+ <title>Overview</title>
<para>
The tasks that follow the installation of a Samba-3 server, whether Stand-Alone, Domain Member, of a
@@ -73,26 +74,53 @@ the infliction of self induced pain, agony and desperation. Be warned, this is a
</para>
</sect1>
-
<sect1>
<title>Administrative Tasks And Methods</title>
<para>
- Stuff goes here - this is a work in progress.!!!!!
+ The basic operations of the <command>net</command> command are documented here. This documentation is not
+ exhaustive, and thus it is incomplete. Since the primary focus is on migration from Windows servers to
+ a Samba server the emphasis is on the use of the DCE RPC mode of operation. When used against a server
+ that is a member of an Active Directory domain it is preferable (and often necessary) to use ADS mode
+ operations. The <command>net</command> command supports both, but not for every operation. Please refer
+ to the man page for a more comprehensive overview of the capabilities of this utility.
</para>
- <sect2>
+ </sect1>
+
+ <sect1>
<title>UNIX and Windows Group Management</title>
<para>
- More stuff.!!!!!!!!!!
+ In repetition of what has been said, the focus in most of this chapter is on use of the <command>net
+ rpc</command> family of operations that are supported by Samba. Most of them are supported by the
+ <command>net ads</command> mode when used in connection with MS Active Directory. The <command>net
+ rap</command> operating mode is also supported for some of these operations. RAP protocols are used
+ by IBM OS/2 and by several earlier SMB servers.
</para>
- <sect3>
+ <para>
+ Sambas' <command>net</command> tool implements sufficient capability to permit all common adminstrative
+ tasks to be completed from the command line. In this section each of the essential user and group management
+ facilities are explored.
+ </para>
+
+ <para>
+ Samba-3 recognizes two types of groups: <emphasis>domain groups</emphasis> and <emphasis>local
+ groups</emphasis>. Domain groups can contain (have as members) only domain user accounts. Local groups
+ can contain local users, domain users, and domain groups as members.
+ </para>
+
+ <para>
+ The purpose of a local group is to permit file permission to be set for a group account that, like the
+ usual UNIX/Linux group, is persistent across redeployment of a Windows file server.
+ </para>
+
+ <sect2>
<title>Adding, Renaming, or Deletion of Group Accounts</title>
- <sect4>
+ <sect3>
<title>Adding or Creating a New Group</title>
<para>
@@ -166,9 +194,9 @@ SupportEngrs (S-1-5-21-72630-4128915-11681869-3007) -> SupportEngrs
</screen>
</para>
- </sect4>
+ </sect3>
- <sect4>
+ <sect3>
<title>Mapping Windows Groups to UNIX Groups</title>
<para>
@@ -178,6 +206,14 @@ SupportEngrs (S-1-5-21-72630-4128915-11681869-3007) -> SupportEngrs
</para>
<para>
+ All file system (file and directory) access controls, within the file system of a UNIX/Linux server that is
+ hosting a Samba server, is implemented using a UID/GID identity tuple. Samba does not in any way over-ride
+ or replace UNIX file system semantics. Thus it is necessary that all Windows networking operations that
+ access the file system must provide a mechanism that maps a Windows user to a particular UNIX/Linux group
+ account. The user account must also map to a locally known UID.
+ </para>
+
+ <para>
Samba depends on default mappings for the <constant>Domain Admins, Domain Users</constant> and
<constant>Domain Guests</constant> global groups. Additional groups may be added as shown in the
examples just given. There are times when it is necessary to map an existing UNIX group account
@@ -208,15 +244,18 @@ SupportEngrs (S-1-5-21-72630-4128915-11681869-3007) -> SupportEngrs
</para>
<para>
- Both the Windows group as well as the UNIX group can be deleted by executing:
+ Two types of Windows groups can be created: <constant>domain (global),</constant> and <constant>local</constant>.
+ In the above examples the Windows groups created were of type <constant>domain</constant>, or global. The
+ following command will create a Windows group of type <constant>local</constant>.
<screen>
-&rootprompt; net groupmap delete ntgroup=
+&rootprompt; net groupmap add ntgroup=Pixies unixgroup=pixies type=l
</screen>
+ Local groups can be used with Samba to enable multiple nested group support.
</para>
- </sect4>
+ </sect3>
- <sect4>
+ <sect3>
<title>Deleting a Group Account</title>
<para>
@@ -230,9 +269,10 @@ SupportEngrs (S-1-5-21-72630-4128915-11681869-3007) -> SupportEngrs
Validation of the deletion is advisable. The same commands may be executed as shown above.
</para>
- </sect4>
- <sect4>
- <title>How to Rename a Group Account</title>
+ </sect3>
+
+ <sect3>
+ <title>Rename Group Accounts</title>
<note><para>
This command is not documented in the man pages, it is implemented in the source code, but it does not
@@ -250,20 +290,124 @@ SupportEngrs (S-1-5-21-72630-4128915-11681869-3007) -> SupportEngrs
</screen>
</para>
- </sect4>
-
</sect3>
- <sect3>
+ </sect2>
+
+ <sect2>
<title>Manipulating Group Memberships</title>
<para>
- Fix me by adding stuff here!!!!!!
+ Three operations can be performed in respect of group membership. It is possible to (1) add Windows users
+ to Windows group, to (2) delete Windows users from Windows groups, and to (3) list the Windows users that are
+ members of a Windows group.
</para>
- </sect3>
+ <para>
+ So as to avoid confusion, it makes sense to check group membership before attempting to make and changes.
+ The <command>getent group</command> will list UNIX/Linux group membership. UNIX/Linux group members are
+ seen also as members of a Windows group that has been mapped using the <command>net groupmap</command>
+ command (see <link linkend="groupmapping"/>). The following list of UNIX/Linux group membership shows
+ that the user <constant>ajt</constant> is a member of the UNIX/Linux group <constant>Engineers</constant>.
+<screen>
+&rootprompt; getent group
+...
+Domain Admins:x:512:root
+Domain Users:x:513:jht,lct,ajt,met,vlendecke
+Domain Guests:x:514:
+Print Operators:x:550:
+Backup Operators:x:551:
+Replicator:x:552:
+Domain Computers:x:553:
+Engineers:x:1000:jht,ajt
+</screen>
+ The UNIX/Linux groups have been mapped to Windows groups, as is shown here:
+<screen>
+&rootprompt; net groupmap list
+Domain Admins (S-1-5-21-72630-412605-116429-512) -> Domain Admins
+Domain Users (S-1-5-21-72630-412605-116429-513) -> Domain Users
+Domain Guests (S-1-5-21-72630-412605-116429-514) -> Domain Guests
+Print Operators (S-1-5-21-72630-412605-116429-550) -> Print Operators
+Backup Operators (S-1-5-21-72630-412605-116429-551) -> Backup Operators
+Replicator (S-1-5-21-72630-412605-116429-552) -> Replicator
+Domain Computers (S-1-5-21-72630-412605-116429-553) -> Domain Computers
+Engineers (S-1-5-21-72630-412605-116429-3001) -> Engineers
+</screen>
+ </para>
- <sect3>
+ <para>
+ Given that the user <constant>ajt</constant> is already a member of the UNIX/Linux group, and via the
+ group mapping, a member of the Windows group, an attempt to add this account again should fail. This is
+ demonstrated here:
+<screen>
+merlin:~ # net rpc group addmem "MIDEARTH\Engineers" ajt -Uroot%not24get
+Could not add ajt to MIDEARTH\Engineers: NT_STATUS_MEMBER_IN_GROUP
+</screen>
+ This showns that the group mapping between UNIX/Linux groups and Windows groups is effective and
+ transparent.
+ </para>
+
+ <para>
+ To permit the user <constant>ajt</constant> to be added using the <command>net rpc group</command> utility
+ this account must first be removed. The removal, and confirmation of its effect is shown here:
+<screen>
+&rootprompt; net rpc group delmem "MIDEARTH\Engineers" ajt -Uroot%not24get
+&rootprompt; getent group Engineers
+Engineers:x:1000:jht
+&rootprompt; net rpc group members Engineers -Uroot%not24get
+MIDEARTH\jht
+</screen>
+ In this example both at the UNIX/Linux system level, the group no longer has the <constant>ajt</constant>
+ as a member. The above also shows this to be the case for Windows group membership.
+ </para>
+
+ <para>
+ The account is now added again, using the <command>net rpc group</command> utility:
+<screen>
+&rootprompt; net rpc group addmem "MIDEARTH\Engineers" ajt -Uroot%not24get
+&rootprompt; getent group Engineers
+Engineers:x:1000:jht,ajt
+&rootprompt; net rpc group members Engineers -Uroot%not24get
+MIDEARTH\jht
+MIDEARTH\ajt
+</screen>
+ </para>
+
+ <para>
+ In this example the members of the Windows <constant>Domain Users</constant> account is validated using
+ the <command>net rpc group</command> utility. Note that this contents of the UNIX/Linux group was shown
+ 4 paragraphs earlier. The Windows (domain) group membership is shown here:
+<screen>
+&rootprompt; net rpc group members "Domain Users" -Uroot%not24get
+MIDEARTH\jht
+MIDEARTH\lct
+MIDEARTH\ajt
+MIDEARTH\met
+MIDEARTH\vlendecke
+</screen>
+ The example shown here is an express example that Windows group names are treated by Samba (as with
+ MS Windows) in a case insensitive manner:
+<screen>
+&rootprompt; net rpc group members "DomAiN USerS" -Uroot%not24get
+MIDEARTH\jht
+MIDEARTH\lct
+MIDEARTH\ajt
+MIDEARTH\met
+MIDEARTH\vlendecke
+</screen>
+ </para>
+
+ <note><para>
+ An attempt to specify the group name as <constant>MIDEARTH\Domain Users</constant> in place of
+ just simply <constant>Domain Users</constant> will fail. The default behavior of the net rpc group
+ is to direct the command at the local machine. The Windows group is treated as being local to the machine.
+ If it is necessary to query another machine, its name can be specified using the <constant>-S
+ servername</constant> parameter to the <command>net</command> command.
+ </para></note>
+
+ </sect2>
+
+ <sect2>
<title>Nested Group Support</title>
<para>
@@ -300,26 +444,69 @@ DOM\jht
</para>
<para>
- Nest group members can be removed (deleted) as shown here:
+ Nested group members can be removed (deleted) as shown here:
<screen>
&rootprompt; net rpc group delmem demo "DOM\jht" -Uroot%not24get
</screen>
</para>
- </sect3>
+ </sect2>
+
+ </sect1>
+
+ <sect1>
+ <title>UNIX and Windows User Management</title>
+
+ <para>
+ Every Windows network user account must be translated to a UNIX/Linux user account. In actual fact,
+ the only account information the UNIX/Linux Samba server needs is a UID. The UID is available either
+ from a system (POSIX) account, or from a pool (range) of UID numbers that is set aside for the purpose
+ of being allocated for use by Windows user accounts. In the case of the UID pool, the UID for a
+ particular user will be allocated by <command>windbindd</command>.
+ </para>
+
+ <para>
+ Although this is not the appropriate place to discuss the <smbconfoption name="username map"/> facility,
+ this interface is an important method of mapping a Windows user account to a UNIX account that has a
+ different name. Refer to the man page for the &smb.conf; file for more information regarding this
+ facility. User name mappings can not be managed usinf the <command>net<command> utility.
+ </para>
+
+ <sect2>
+ <title>Adding User Accounts</title>
+
+ <para>
+ </para>
</sect2>
<sect2>
- <title>UNIX and Windows User Management</title>
+ <title>Deletion of User Accounts</title>
<para>
- Put somethings useful here man!!!!!!
</para>
</sect2>
<sect2>
+ <title>Modification of User Accounts</title>
+
+ <para>
+ </para>
+
+ </sect2>
+
+ <sect2>
+ <title>User Mapping</title>
+
+ <para>
+ </para>
+
+ </sect2>
+
+ </sect1>
+
+ <sect1>
<title>Administering User Rights and Privileges</title>
<para>
@@ -396,16 +583,16 @@ SeDiskOperatorPrivilege
</screen>
</para>
- </sect2>
+ </sect1>
- <sect2>
+ <sect1>
<title>Managing Trust Relationships</title>
<para>
Document how to set up trusts here!!!!!!!!!!!
</para>
- <sect3>
+ <sect2>
<title>Machine Trust Accounts</title>
<para>
@@ -415,36 +602,36 @@ Join to 'MIDEARTH' is OK
</screen>
</para>
- </sect3>
+ </sect2>
- <sect3>
+ <sect2>
<title>Inter-Domain Trusts</title>
<para>
Document how to set up trusts here!!!!!!!!!!!
</para>
- </sect3>
-
</sect2>
- <sect2>
+ </sect1>
+
+ <sect1>
<title>Managing Security Identifiers (SIDS)</title>
<para>
Document how to set up trusts here!!!!!!!!!!!
</para>
- </sect2>
+ </sect1>
- <sect2>
+ <sect1>
<title>Share Management</title>
<para>
Document how to set up trusts here!!!!!!!!!!!
</para>
- <sect3>
+ <sect2>
<title>Creating, Editing, and Removing Shares</title>
<para>
@@ -501,17 +688,17 @@ kyocera
</screen>
</para>
- </sect3>
+ </sect2>
- <sect3>
+ <sect2>
<title>Creating and Changing Share ACLs</title>
<para>
</para>
- </sect3>
+ </sect2>
- <sect3>
+ <sect2>
<title>Share, Directory and File Migration</title>
<para>
@@ -553,7 +740,23 @@ kyocera
server (or domain) as well as the processes on which the migration is critically dependant.
</para>
- <sect4>
+ <para>
+ There are two known limitations to the migration process:
+ </para>
+
+ <orderedlist>
+ <listitem><para>
+ The <command>net</command> command requires that the user credentials provided exist both
+ on the migration source and the migration target.
+ </para></listitem>
+
+ <listitem><para>
+ Printer settings may not be fully or incorrectly migrated. This might in particular happen
+ when migrating a Windows 2003 print server to Samba.
+ </para></listitem>
+ </orderedlist>
+
+ <sect3>
<title>Share Migration</title>
<para>
@@ -608,9 +811,9 @@ net rpc share MIGRATE SHARES &lt;sharename&gt; -S &lt;source&gt;
are not migrated by the steps covered up to this point.
</para>
- </sect4>
+ </sect3>
- <sect4>
+ <sect3>
<title>File and Directory Migration</title>
<para>
@@ -691,9 +894,9 @@ net rpc share MIGRATE FILES &lt;sharename&gt; -S &lt;source&gt;
will be owned by the user account <constant>administrator</constant>.
</para>
- </sect4>
+ </sect3>
- <sect4>
+ <sect3>
<title>Simultaneous Share and File Migration</title>
<para>
@@ -713,111 +916,144 @@ net rpc share MIGRATE ALL &lt;sharename&gt; -S &lt;source&gt;
This will generate a complete server clone of the <parameter>w2k3server</parameter> server.
</para>
- </sect4>
-
</sect3>
- <sect3>
+ </sect2>
+
+ <sect2>
<title>Printer Migration</title>
-<para>
-<screen>
-Migrating printers
------------------------------------------------------------
+ <para>
+ The installation of a new server, as with the migration to a new network environment, often has similarity
+ to the building of a house; progress is very rapid from the laying of foundations up to the stage at which
+ the the house can be locked-up, but the finishing off appears to take longer and longer as building
+ approaches completion.
+ </para>
-net rpc printer MIGRATE PRINTERS [printer] [misc. options] [targets]
- migrates printers from remote to local server
+ <para>
+ Printing needs vary greatly depending on the network environment, and may be very simple or complex. If
+ the need is very simple the best solution to the implementation of printing support may well be to
+ re-install everything from a clean slate instead of migrating older configurations. On the other hand,
+ a complex network that is integrated with many international offices and a multiplexity of local branch
+ offices, each of which form an inter-twined maze of printing possibilities, the ability to migrate all
+ printer configurations is decidedly beneficial. To manually re-establish a complex printing network
+ will take much time and frustration. Often-times it will not be possible to find driver files that are
+ currently in use thus necessitating the installation of newer drivers. Newer drivers often implement
+ printing features that will necessitate a change in the printer usage. Additionally, with very complex
+ printer configurations it becomes almost impossible to re-create the same environment - not matter
+ how extensivly it has been documented.
+ </para>
+ <para>
+ The migration of an existing printing architecture involves the following:
+ </para>
-Migrating printer-drivers
------------------------------------------------------------
+ <itemizedlist>
+ <listitem><para>Establishment of print queues.</para></listitem>
-net rpc printer MIGRATE DRIVERS [printer] [misc. options] [targets]
- migrates printer-drivers from remote to local server
+ <listitem><para>Installation of printer drivers (both for the print server and for Windows clients.</para></listitem>
+ <listitem><para>Configuration of printing forms.</para></listitem>
-Migrating printer-forms
------------------------------------------------------------
+ <listitem><para>Implementation of security settings.</para></listitem>
-net rpc printer MIGRATE FORMS [printer] [misc. options] [targets]
- migrates printer-forms from remote to local server
+ <listitem><para>Configuration of printer settings.</para></listitem>
+ </itemizedlist>
+ <para>
+ The Samba <command>net</command> utility permits printer migration from one Windows print server
+ to another. When this tool is used to migrate printers to a Samba server <command>smbd</command>,
+ the application the receives the network requests to create the necessary services, must call-out
+ to the operating system in order to create the underlying printers. The call-out is implemented
+ by way of an interface script that can be specified by the &smb.conf; file parameter
+ <smbconfoption id="add printer script"/>. This script is essential to the migration process.
+ A suitable example script may be obtained from the <filename>$SAMBA_SOURCES/examples/scripts</filename>
+ directory. Take note that this script must be customized to suit the operating system environment
+ and may use its tools to create a print queue.
+ </para>
-Migrating printer security-settings
------------------------------------------------------------
+ <para>
+ Each of the components listed above can be completed separately, or they can be completed as part of an
+ automated operation. Many network administrators prefer to deal with migration issues in a manner that
+ gives them the most control, particularly when things go wrong. The syntax for each operation will now
+ be briefly described.
+ </para>
+ <para>
+ Printer migration from a Windows print server (NT4 or 200X) is shown. This instruction causes the
+ printer share to be created together with the underlying print queue:
+<screen>
+net rpc printer MIGRATE PRINTERS [printer] [misc. options] [targets]
+</screen>
+ Printer drivers can be migrated from the Windows print server to the Samba server using this
+ command line instruction:
+<screen>
+net rpc printer MIGRATE DRIVERS [printer] [misc. options] [targets]
+</screen>
+ Printer forms can be migrated with the following operation:
+<screen>
+net rpc printer MIGRATE FORMS [printer] [misc. options] [targets]
+</screen>
+ Printer security settings (ACLs) can be migrated from the Windows server to the Samba server using this command:
+<screen>
net rpc printer MIGRATE SECURITY [printer] [misc. options] [targets]
- migrates printer-ACLs from remote to local server
-
-
-Migrating printer-settings
------------------------------------------------------------
-
+</screen>
+ Printer configuration settings include factors such as paper size, default paper orientation, etc.
+ These can be migrated from the Windows print server to the Samba server with this command:
+<screen>
net rpc printer MIGRATE SETTINGS [printer] [misc. options] [targets]
- migrates printer-settings from remote to local server
-
-
-Migrating printers including all the above mentioned sets of information
------------------------------------------------------------
+</screen>
+ </para>
+ <para>
+ Migration of printers including all the above mentioned sets of information may be completed
+ with a single command using this syntax:
+<screen>
net rpc printer MIGRATE ALL [printer] [misc. options] [targets]
- migrates drivers, forms, queues, settings and acls from
- remote to local print-server
-
-
-
-Known Limitations
------------------------------------------------------------
-
-* net requires that the given credentials exist both on the migration source
- and the migration target.
-
-* printer-settings may not be fully or incorrectly migrated. This might in
- particular happen when migrating a Windows 2003 print-server to Samba.
</screen>
</para>
- </sect3>
-
</sect2>
- <sect2>
+ </sect1>
+
+ <sect1>
<title>Controlling Open Files</title>
<para>
Document how to set up trusts here!!!!!!!!!!!
</para>
- </sect2>
+ </sect1>
- <sect2>
+ <sect1>
<title>Session and Connection Management</title>
<para>
Document how to set up trusts here!!!!!!!!!!!
</para>
- </sect2>
+ </sect1>
- <sect2>
+ <sect1>
<title>Printers and ADS</title>
<para>
Document how to set up trusts here!!!!!!!!!!!
</para>
- </sect2>
+ </sect1>
- <sect2>
+ <sect1>
<title>Manipulating the Samba Cache</title>
<para>
Document how to set up trusts here!!!!!!!!!!!
</para>
- </sect2>
+ </sect1>
- <sect2>
+ <sect1>
<title>Other Miscellaneous Operations</title>
<para>
@@ -832,8 +1068,6 @@ Num local groups: 0
</screen>
</para>
- </sect2>
-
</sect1>
</chapter>