| Background Intelligent Transfer Service (BITS) | |
|---|---|
| Developer | Microsoft |
| Initial release | October 2001; 24 years ago (2001-10) |
| Stable release | 10.3 / December 7, 2019; 6 years ago (2019-12-07) |
| Operating system | Microsoft Windows |
| Type | Download manager |
| License | Proprietarycommercial software |
| Website | learn |
Background Intelligent Transfer Service (BITS) is a component ofMicrosoft Windows XP and later iterations of the operating systems, which facilitates asynchronous, prioritized, and throttled transfer of files between machines using idle network bandwidth. It is most commonly used by recent versions ofWindows Update,Microsoft Update,Windows Server Update Services, andSystem Center Configuration Manager to deliversoftware updates to clients,Microsoft's anti-virus scannerMicrosoft Security Essentials (a later version ofWindows Defender) to fetch signature updates, and is also used by Microsoft's instant messaging products to transfer files. BITS is exposed through theComponent Object Model (COM) and the UWP APIWindows.Networking.BackgroundTransfer.
BITS uses idlebandwidth to transfer data. Normally, BITS transfers data in the background, i.e., BITS will only transfer data whenever there is bandwidth which is not being used by other applications. BITS also supports resuming transfers in case of disruptions.
BITS version 1.0 supports only downloads. BITS version 1.2 was included inWindows XP SP1 andWindows 2000 SP3. From version 1.5, BITS supports both downloads and uploads. Uploads require theIIS web server, with BITS server extension, on the receiving side.
BITS transfers files on behalf of requesting applications asynchronously, i.e., once an application requests the BITS service for a transfer, it will be free to do any other task, or even terminate. The transfer will continue in the background as long as the network connection is there and the job owner is logged in. BITS jobs do not transfer when the job owner is not signed in.
BITS suspends any ongoing transfer when the network connection is lost or the operating system is shut down. It resumes the transfer from where it left off when (the computer is turned on later and) the network connection is restored. BITS supports transfers overSMB,HTTP andHTTPS.
BITS attempts to use only spare bandwidth. For example, when applications use 80% of the available bandwidth, BITS will use only the remaining 20%. BITS constantly monitors network traffic for any increase or decrease in network traffic andthrottles its own transfers to ensure that other foreground applications (such as aweb browser) get the bandwidth they need.Note that BITS does not necessarily measure the actual bandwidth. BITS versions 3.0 and up will useInternet Gateway Device counters, if available, to more accurately calculate available bandwidth. Otherwise, BITS will use the speed as reported by theNIC to calculate bandwidth. This can lead to bandwidth calculation errors, for example when a fast network adapter (10 Mbit/s) is connected to the network via a slow link (56 kbit/s).[1]
BITS uses a queue to manage file transfers. A BITS session has to be started from an application by creating aJob. A job is a container, which has one or more files to transfer. A newly created job is empty. Files must be added, specifying both the source and destinationURIs. While a download job can have any number of files, upload jobs can have only one. Properties can be set for individual files. Jobs inherit the security context of the application that creates them.BITS providesAPI access to control jobs. A job can be programmatically started, stopped, paused, resumed, and queried for status. Before starting a job, a priority has to be set for it to specify when the job is processed relative to other jobs in the transfer queue. By default, all jobs are ofNormal priority. Jobs can optionally be set toHigh,Low, orForeground priority. Background transfers are optimized by BITS, which increases and decreases (or throttles) the rate of transfer based on the amount of idle network bandwidth that is available. If a network application begins to consume more bandwidth, BITS decreases its transfer rate to preserve the user's interactive experience, except forForeground priority downloads.
BITSschedules each job to receive only a finitetime slice, for which only that job is allowed to transfer, before it is temporarily paused to give another job a chance to transfer. Higher priority jobs get a higher chunk of time slice. BITS usesround-robin scheduling to process jobs in the same priority and to prevent a large transfer job from blocking smaller jobs.
When a job is newly created, it is automaticallysuspended (or paused). It has to be explicitlyresumed to be activated.Resuming moves the job to thequeued state. On its turn to transfer data, it first connects to the remote server and then starts transferring. After the job's time slice expires, the transfer is temporarily paused, and the job is moved back to thequeued state. When the job gets another time slice, it has to connect again before it can transfer. When the job is complete, BITS transfers ownership of the job to the application that created it.
BITS includes a built-in mechanism for error handling and recovery attempts. Errors can be eitherfatal ortransient; either moves a job to the respective state. Atransient error is a temporary error that resolves itself after some time. For a transient error, BITS waits for some time and then retries. Forfatal errors, BITS transfers control of the job to the creating application, with as much information regarding the error as it can provide.
Microsoft provides a BITS Administration Utility (BITSAdmin)command-lineutility to manage BITS jobs. The utility is part ofWindows Vista and later.[2][3] It is also available as a part of theWindows XP Service Pack 2 Support Tools[4] orWindows Server 2003 Service Pack 1 Support Tools.[5]
Usage example:
C:\>bitsadmin /transfer myDownloadJob /download /priority normal https://example.com/file.zip C:\file.zipInWindows 7, theBITSAdmin utility is deprecated in favor ofWindows PowerShell cmdlets.[6] TheBitsTransfer PowerShell module provides eight cmdlets with which to manage BITS jobs.[7]
The following example is the equivalent of the BITSAdmin example above:
PS C:\>Start-BitsTransfer-Source"https://example.com/file.zip"-Destination"C:\file.zip"-DisplayName"myDownloadJob"