It can take hours to mirror the full repository.
- To create a complete mirror, see Mirroring the Anaconda repository or Mirroring a PYPI repository.
- To create partial mirror, see Mirroring specific packages.
- To mirror a repository in a system without internet access, see Mirroring in an air-gapped environment.
- To share mirrors, see Configuring Anaconda Enterprise and Sharing channels.
- Configuring SSL verification
- Mirroring in a proxied environment
- Mirroring specific platforms and versions
- Using blacklisting to exclude packages
- Using whitelisting to include packages
- Combining multiple configuration arguments
If Anaconda Enterprise 5 is installed in a proxied environment, see Mirroring in a proxied environment for information on setting the 
NO_PROXY variable.Mirroring the Anaconda repository
We recommend the following process as a best practice for mirroring the Anaconda repository.- Instead of using the default anaconda.yamlfile included in the mirror tool installation, create twoyamlfiles, one for mirroring themainchannel, and another for mirroring thefreechannel.
main.yaml file:
free.yaml file:
- 
If you saved both of these files to the home directory, you can use the following commands to mirror these channels. Otherwise, amend the path so that it corresponds to where you saved the files:
If you plan to mirror these channels on a regular basis, consider adding the 
-c flag to get a clean mirror each time. This will automatically remove any packages that have been removed from the Anaconda repository between mirrors from your internal repository—excluding any packages your organization has blacklisted.- Verify that the mirror was successful by logging into your account and navigating to the Packages tab. You should see a list of the mirrored packages.
Mirroring a PyPI repository
The full PyPI mirror size is currently close to 4TB, so ensure that your file storage location has sufficient disk space before proceeding. Rather than mirror the entire PyPI repository, you can use a configuration file such as$PREFIX/etc/anaconda-platform/mirrors/pypi.yaml to customize the mirror behavior and specify the subset of packages you want to mirror.
To create a PyPI mirror:
https://pypi.org into the pypi user account. Mirrored
packages can be viewed at <https://anaconda.example.com>/repository/pypi/pypi/simple/,
replacing <https://anaconda.example.com> with the actual URL to your installation of Anaconda
Enterprise. (The second pypi in the url should match the user configuration value described
below.)
The following configuration options are available for you to customize your configuration file:
| Name | Description | 
|---|---|
| user | The local user under which the PyPI packages are imported. Default: pypi. | 
| pkg_list | A list of packages to mirror. Only packages listed are mirrored. If this is set, blacklistandwhitelistsettings are ignored. Default:[]. | 
| whitelist | A list of packages to mirror. Only packages listed are mirrored. If the list is empty, all packages are checked. Default: []. | 
| blacklist | A list of packages to skip. The packages listed are ignored. Default: []. | 
| latest_only | Only download the latest versions of the packages. Default: false. | 
| remote_url | The URL of the PyPI mirror. /pypiis appended to build the XML RPC API URL,/simplefor the simple index and/pypi/{package}/{version}/jsonfor the JSON API. Default:https://pypi.python.org/. | 
| xml_rpc_api_url | A custom value for XML RPC URL. If this value is present, it takes precedence over the URL built using remote_url. Default:null. | 
| simple_index_url | A custom value for the simple index URL. If this value is present, it takes precedence over the URL built using remote_url. Default:null. | 
| use_xml_rpc | Whether to use the XML RPC API as specified by PEP381. If this is set to true, the XML RPC API is used to determine which packages to check. Otherwise the scripts falls back to the simple index. If the XML RPC fails, the simple index is used. Default:true. | 
| use_serial | Whether to use the serial number provided by the XML RPC API. Only packages updated since the last serial saved are checked. If this is set to false, all PyPI packages are checked for updates. Default: true. | 
| create_org | Create the mirror user as an organization instead of a regular user account. All superusers are added to the “Owners” group of the organization. Default: false. | 
Configuring pip
To configure pip to use this new mirror, createpip.conf as follows:
<https://anaconda.example.com> with the actual URL to your Anaconda Enterprise.
To configure Anaconda Enterprise sessions and deployments to automatically use
the pip.conf run the following command.
--index-url flag directly when invoking pip.
For example,
<https://anaconda.example.com> with the actual URL to your Anaconda Enterprise
installation, and <package_name> with the name of a package that is in your local mirror. In
the example URL, the second pypi should match the user configuration value described
above.
For more specific information on configuring pip, refer to the official documentation at https://pip.pypa.io/en/stable/user_guide/#config-file.
Mirroring specific packages
Alternately, you may not wish to mirror all packages. In this case, you can specify which platforms or specific packages you want to mirror —or— use the whitelist, blacklist or license_blacklist functionality to control which packages are mirrored, by editing the provided mirror files. You cannot combine these methods. For more information, see Mirror configuration options.Mirroring R packages
An example configuration file for mirroring R packages is also provided:Mirroring in an air-gapped environment
To mirror the repository in a system with no internet access, create a local copy of the repository by extracting the airgapped tarball and pointcas-sync-api-v5 to the extracted tarball.
In this example we will
extract to /tmp:
/tmp/mirror/pkgs. You can
mirror this repository by editing <path to cas-mirror>/etc/anaconda-platform/mirrors/anaconda.yaml to contain:
This mirrors the contents of the local file-system repository to your
Anaconda Enterprise installation under the username anaconda.
Configuring Anaconda Enterprise
After creating the mirror, edit your Anaconda Enterprise configuration to add this new mirrored channel to the default Anaconda Enterprise channels and make the packages available to users.<anaconda.example.com> with the actual URL to your installation of Anaconda Enterprise.
The 
ap-workspace pod must be restarted for the configuration change to take effect on new project editor sessions.- Run the following command in an interactive shell to identify the pod associated with the workspace services:
- Restart the workspace services by running the following command:
Sharing channels
To make your new channels visible to your users in their Channels list, you need to share the channels with them. EXAMPLE: To share new channelsmain, free, and r with group everyone for read access:
share command, verify by logging onto the user interface and viewing the Channels list.
For more information, see Sharing channels and packages
Mirror configuration options
You can use the following options to configure your mirror:- Configuring SSL verification.
- Mirroring in a proxied environment.
- Mirroring specific platforms and versions.
- Using blacklisting to exclude packages.
- Using whitelisting to include package.
- Combining multiple configuration arguments.
https://repo.continuum.io/.
channels
Specifies the remote channels from which conda packages are downloaded. The
default is a list of the channels <remote_url>/pkgs/free/ and <remote_url>/pkgs/pro/
All specification information should be included in the same file, and can be
passed to the cas-sync-api-v5 command via the --file argument:
dest_channel specifies where files will be uploaded.
The default value is: anaconda.
SSL verification
The mirroring tool uses two different settings for configuring SSL verification. When the mirroring tool connects to its destination, it uses thessl_verify setting
from anaconda-enterprise-cli to determine how to validate certificates. For example,
to use a custom certificate authority:
Mirroring in a proxied environment
If Anaconda Enterprise 5 is installed in a proxied environment, set theNO_PROXY variable. This ensures the mirroring tool does not use the proxy when
communicating with the repository service, and prevents errors such as Max retries exceeded, Cannot connect to proxy, and Tunnel connection failed: 503 Service Unavailable.
Platform-specific mirroring
By default, thecas-sync-api-v5 tool mirrors all platforms. If you do
not need all platforms, edit the YAML file to specify the platform(s)
you want mirrored:
The platform argument is evaluated before any other argument.
Package-specific mirroring
In some cases you may want to mirror only a small subset of the repository. Rather than blacklisting a long list of packages you do not want mirrored, you can instead simply enumerate the list of packages you DO want mirrored.This argument cannot be used with the 
blacklist, whitelist or license_blacklist arguments—it can only be combined with platform-specific and version-specific mirroring.Python version-specific mirroring
Mirror the repository with a Python version or versions specified. EXAMPLE:License blacklist mirroring
The mirroring script supports license blacklisting for the following license families:Blacklist mirroring
The blacklist allows access to all packages EXCEPT those explicitly listed. If thelicense_blacklist and blacklist arguments are combined, license_blacklist is evaluated first, and blacklist is a supplemental modifier.
EXAMPLE:
bzip2, Tk,
and OpenSSL packages.
Whitelist mirroring
Thewhitelist argument adds or includes packages that would be otherwise excluded by the blacklist and/or license_blacklist functions.
EXAMPLE:
This example mirrors the entire repository EXCEPT any GPL2- or GPL3-licenses
packages, but includes readline, despite the fact that it is GPL3-licensed.
Combining multiple mirror configurations
You may find that combining two or more of the arguments above is the easiest way to get the exact combination of packages that you want.The platform argument is evaluated before any other argument.
license_blacklist and blacklist arguments are combined, license_blacklist is evaluated first, and blacklist is a supplemental modifier.
EXAMPLE: In this example, the mirror configuration does not mirror GPL2-licensed
packages. It does not mirror the GPL3 licensed package pyqt because it has
been blacklisted. It does mirror all other packages in the repository:
blacklist and whitelist arguments are both employed, the blacklist is
evaluated first, with the whitelist functioning as a modifier.
EXAMPLE: This example mirrors all packages in the repository except astropy and pygments.
Despite being listed on the blacklist, accelerate is mirrored because it is
listed on the whitelist.

