Set-SmbShare
Modifies the properties of the SMB share.
Syntax
Set-SmbShare
[-Name] <String[]>
[[-ScopeName] <String[]>]
[-SmbInstance <SmbInstance>]
[-Description <String>]
[-ConcurrentUserLimit <UInt32>]
[-CATimeout <UInt32>]
[-ContinuouslyAvailable <Boolean>]
[-FolderEnumerationMode <FolderEnumerationMode>]
[-CachingMode <CachingMode>]
[-SecurityDescriptor <String>]
[-EncryptData <Boolean>]
[-CompressData <Boolean>]
[-IsolatedTransport <Boolean>]
[-LeasingMode <LeasingMode>]
[-DirectoryHandleLeasing <Boolean>]
[-QoSFlowScope <QoSFlowScope>]
[-QoSPolicyId <String>]
[-Force]
[-CimSession <CimSession[]>]
[-ThrottleLimit <Int32>]
[-AsJob]
[-PassThru]
[-WhatIf]
[-Confirm]
[<CommonParameters>]
Set-SmbShare
-InputObject <CimInstance[]>
[-Description <String>]
[-ConcurrentUserLimit <UInt32>]
[-CATimeout <UInt32>]
[-ContinuouslyAvailable <Boolean>]
[-FolderEnumerationMode <FolderEnumerationMode>]
[-CachingMode <CachingMode>]
[-SecurityDescriptor <String>]
[-EncryptData <Boolean>]
[-CompressData <Boolean>]
[-IsolatedTransport <Boolean>]
[-LeasingMode <LeasingMode>]
[-DirectoryHandleLeasing <Boolean>]
[-QoSFlowScope <QoSFlowScope>]
[-QoSPolicyId <String>]
[-Force]
[-CimSession <CimSession[]>]
[-ThrottleLimit <Int32>]
[-AsJob]
[-PassThru]
[-WhatIf]
[-Confirm]
[<CommonParameters>]
Description
The Set-SmbShare
cmdlet modifies the properties of the Server Message Block (SMB) share.
Examples
Example 1: Modify properties of an SMB share
Set-SmbShare -Name "VMFiles" -EncryptData $True
Confirm
Are you sure you want to perform this action?
Performing operation 'Modify' on Target 'Contoso-SO,VMFiles'.
[Y] Yes [A] Yes to All [N] No [L] No to All [S] Suspend [?] Help (default is "Y"):
This command modifies the properties of an SMB share.
Example 2: Modify properties of an SMB share without confirmation
Set-SmbShare -Name "VMFiles" -EncryptData $True -Force
This command modifies the properties of an SMB share without user confirmation.
Parameters
-AsJob
Runs the cmdlet as a background job. Use this parameter to run commands that take a long time to complete.
Type: | SwitchParameter |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-CachingMode
Specifies the caching mode of the offline files for the SMB share. There are five caching modes:
- BranchCache - Enables BranchCache and manual caching of documents on the shared folder.
- Documents - Automatically stores documents offline.
- Manual - Allows users to identify the documents and programs that they want to store offline.
- Programs - Automatically stores documents and programs offline.
- None - Prevents users from storing documents and programs offline.
Type: | CachingMode |
Accepted values: | None, Manual, Documents, Programs, BranchCache, Unknown |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-CATimeout
Specifies the continuous availability time-out of the SMB share.
Type: | UInt32 |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-CimSession
Runs the cmdlet in a remote session or on a remote computer. Enter a computer name or a session object, such as the output of a New-CimSession or Get-CimSession cmdlet. The default is the current session on the local computer.
Type: | CimSession[] |
Aliases: | Session |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-CompressData
Indicates that the shares being enumerated should request compression from clients.
Type: | Boolean |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-ConcurrentUserLimit
Specifies the maximum number of concurrently connected users that the SMB share may accommodate. If this parameter is set to zero (0), then the number of users is unlimited. By default, new SMB shares have no limit on the number of concurrent connections.
Type: | UInt32 |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-Confirm
Prompts you for confirmation before running the cmdlet.
Type: | SwitchParameter |
Aliases: | cf |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-ContinuouslyAvailable
Indicates whether the share is continuously available.
Type: | Boolean |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-Description
Specifies an optional description of the SMB share. A description of the share can be displayed by running the Get-SmbShare cmdlet. Specify an empty string to clear the current description. The description may not contain more than 256 characters.
Type: | String |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-DirectoryHandleLeasing
When directory handle leasing is set to $true
, the SMB client can cache directory handles and
reuse them for future requests. This can improve performance and reduce network traffic.
When directory handle leasing is set to $false
, the SMB client must request a new directory
handle for each request. This can increase network traffic and reduce performance.
Type: | Boolean |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-EncryptData
Indicates whether the SMB share is encrypted.
Type: | Boolean |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-FolderEnumerationMode
Specifies which files and folders in the new SMB share will be visible to the users. The acceptable values for this parameter are:
AccessBased
: SMB doesn't the display the files and folders for a share to a user unless that user has rights to access the files and folders. By default, access-based enumeration is disabled for new SMB shares.Unrestricted
: SMB displays files and folders to a user even when the user doesn't have permission to access those items.
The default value is Unrestricted.
Type: | FolderEnumerationMode |
Accepted values: | AccessBased, Unrestricted |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-Force
Forces the command to run without asking for user confirmation.
Type: | SwitchParameter |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-InputObject
Specifies the input object that's used in a pipeline command.
Type: | CimInstance[] |
Position: | Named |
Default value: | None |
Required: | True |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-IsolatedTransport
Specifies whether to use an isolated transport for the SMB share. An isolated transport provides additional security by encrypting and signing SMB traffic. The default value is False.
Type: | Boolean |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-LeasingMode
Specifies SMB leasing and oplock behaviors for application compatibility. The acceptable values for this parameter are:
Full
: Use default lease and oplock behaviors from SMB3.Shared
: Grant read-caching lease but not write or handle-caching.None
: No oplocks or leases, behave like SMB1 (not recommended).
Important
We don't recommend disabling oplocks, but may be required in some scenarios. For more information, see SMB1 Product Clearinghouse.
Type: | LeasingMode |
Accepted values: | Full, Shared, None |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Name
Specifies the name of one or more SMB shares.
Type: | String[] |
Position: | 1 |
Default value: | None |
Required: | True |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-PassThru
Returns an object representing the item with which you're working. By default, this cmdlet doesn't generate any output.
Type: | SwitchParameter |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-QoSFlowScope
Specifies the Quality of Service (QoS) flow scope for the SMB share. The QoS flow scope determines how QoS policies are applied to SMB traffic. The accepted values are:
- File: Applies the QoS policy to file operations, each file handle is considered a flows.
- Share: Applies the QoS policy to SMB share connections, each connection is considered a flow.
- User: Applies the QoS policy to each user connection, each user connection is considered a flow.
- Session: Applies the QoS policy to each SMB session, each session connection is considered a flow.
The default value is None.
Type: | QoSFlowScope |
Accepted values: | File, Share, User, Session |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-QoSPolicyId
Specifies the QoS policy ID for the SMB share. The QoS policy ID is used to apply QoS policies to SMB traffic. The default value is None.
Type: | String |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-ScopeName
Specifies the scope name of the SMB share. For use with Windows Server failover cluster file server resources.
Type: | String[] |
Position: | 2 |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-SecurityDescriptor
Specifies the security descriptor for the SMB share in string format.
Type: | String |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-SmbInstance
Specifies the input to this cmdlet. You can use this parameter, or you can pipe the input to this cmdlet.
Type: | SmbInstance |
Accepted values: | Default, CSV, SBL, SR |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-ThrottleLimit
Specifies the maximum number of concurrent operations that can be established to run the cmdlet. If
this parameter is omitted or a value of 0
is entered, then Windows PowerShell calculates an
optimum throttle limit for the cmdlet based on the number of CIM cmdlets that are running on the
computer. The throttle limit applies only to the current cmdlet, not to the session or to the
computer.
Type: | Int32 |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-WhatIf
Shows what would happen if the cmdlet runs. The cmdlet isn't run.
Type: | SwitchParameter |
Aliases: | wi |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
Inputs
Microsoft.PowerShell.Cmdletization.GeneratedTypes.SmbShare.SmbInstance
Microsoft.PowerShell.Cmdletization.GeneratedTypes.SmbShare.FolderEnumerationMode
Microsoft.PowerShell.Cmdletization.GeneratedTypes.SmbShare.CachingMode
Microsoft.PowerShell.Cmdletization.GeneratedTypes.SmbShare.QoSFlowScope
Outputs
This cmdlet returns a MSFT_SmbShare object that represents the modified share.