<!DOCTYPE html>
<html lang="en">
<!-- Global site tag (gtag.js) - Google Analytics -->
<script async src="https://www.googletagmanager.com/gtag/js?id=UA-112407000-2"></script>
<script>
    window.dataLayer = window.dataLayer || [];

    function gtag() {
        dataLayer.push(arguments);
    }
    gtag('js', new Date());

    gtag('config', 'UA-112407000-2');
</script>

<!-- Google Tag Manager -->
<script>
    (function (w, d, s, l, i) {
        w[l] = w[l] || [];
        w[l].push({
            'gtm.start': new Date().getTime(),
            event: 'gtm.js'
        });
        var f = d.getElementsByTagName(s)[0],
            j = d.createElement(s),
            dl = l != 'dataLayer' ? '&l=' + l : '';
        j.async = true;
        j.src =
            'https://www.googletagmanager.com/gtm.js?id=' + i + dl;
        f.parentNode.insertBefore(j, f);
    })(window, document, 'script', 'dataLayer', 'GTM-KS8HHSF');
</script>
<!-- End Google Tag Manager -->

<head>
    	<base href="/codewind/" />
	<title>Docker registry guidance for Eclipse Codewind | Codewind</title>
	<meta charset="utf-8">
	<meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
	<meta name="viewport" content="width=device-width, initial-scale=1">
	<meta name="description" content="Docker registry guidance for Eclipse Codewind">
	<meta name="keywords" content="users, projects, Kubernetes, docker, containers, registry, deployment, push"/>
	<link rel="icon" type="image/png" sizes="16x16" href="images/favicon-16x16.png">
	<link rel="icon" type="image/png" sizes="32x32" href="images/favicon-32x32.png">
	<link href="https://fonts.googleapis.com/css?family=IBM+Plex+Sans:300,400,600&display=swap" rel="stylesheet">
	<!-- Bootstrap CSS CDN -->
	<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css"
	integrity="sha384-ggOyR0iXCbMQv3Xipma34MD+dH/1fQ784/j6cY/iJTQUOhcWr7x9JvoRxT2MZw1T" crossorigin="anonymous">
	<link href="https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet" />
	<link rel="stylesheet" href="css/styles.css">
	<link rel="stylesheet" href="css/docs.css">
	

</head>

<body data-spy="scroll" data-target="#toc">
    <!-- Google Tag Manager (noscript) -->
    <noscript><iframe src="https://www.googletagmanager.com/ns.html?id=GTM-KS8HHSF"
        height="0" width="0" style="display:none;visibility:hidden"></iframe></noscript>
        <!-- End Google Tag Manager (noscript) -->
    <div class="main">
        <!-- Bootstrap NavBar -->
<nav class="navbar navbar-expand-lg navbar-light cw-banner fixed-top">
        <button class="navbar-toggler navbar-toggler-right" type="button" data-toggle="collapse"
            data-target="#navbarNavDropdown" aria-controls="navbarNavDropdown" aria-expanded="false"
            aria-label="Toggle navigation">
            <span class="navbar-toggler-icon"></span>
        </button>
        <a class="navbar-brand" href="">
            <img src="images/header-logo.svg" class="cw-header-logo" alt="">
        </a>
        <div class="collapse navbar-collapse justify-content-end cw-navbar-padding" id="navbarNavDropdown">
            <ul class="navbar-nav cw-navbar-nav">
                <li class="nav-item cw-navbar-item cw-header-link">
                    <a class="nav-link cw-nav-link" href="docindex.html">Docs</a>
                </li>
                <!-- li class="nav-item cw-navbar-item" id="download-li">
                    <button onClick="window.location.href='https://microclimate.dev/download/codewind';" type="button" class="btn cw-download-button">Download</button>
                    <a href="https://microclimate.dev/download/codewind" class="nav-link cw-nav-link cw-download-link" href="#">Download</a>
                </li>  -->


                <li class="nav-item cw-navbar-item" id="github-stars-button">
                    <!-- Place this tag where you want the button to render. -->
                    <a class="github-button" href="https://github.com/eclipse/codewind" data-size="large"
                        data-show-count="true" aria-label="Star eclipse/codewind on GitHub">Star</a>
                </li>
                <!-- Smaller devices menu END -->

            </ul>
        </div>
    </nav>
    <!-- NavBar END -->

<!-- Bootstrap row -->
<div class="row" id="body-row">
    <!-- Sidebar -->
    <div id="sidebar-container" class="bg-light">
        <!-- Bootstrap List Group -->
        <ul class="list-group sticky-top bg-light cw-sticky-offset">
            <!-- Separator with title -->
            <li class="list-group-item cw-sidebar-separator-title cw-text-gray d-flex bg-light align-items-center menu-collapsed">
                <small class="badge badge-success cw-margin-auto">DOCUMENTS</small>
            </li>
            <!-- /END Separator -->
            <!-- Hard coded TOC -->

            <a href="#install_on_cloud" data-toggle="collapse" aria-expanded="false" class="bg-light list-group-item list-group-item-action flex-column align-items-start collapsed">
                <div class="d-flex w-100 justify-content-start align-items-center">
                    <span class="menu-collapsed">Installing and Using Codewind on Cloud</span>
                    <span class="submenu-icon ml-auto"></span>
                </div>
            </a>
            <div id="install_on_cloud" class="cw-sidebar-div cw-sidebar-submenu collapse" style="">
                <a href="installoncloud.html" 
			        
				    
				    class="bg-light list-group-item list-group-item-action">
				    <div class="d-flex w-100 justify-content-start align-items-center">
                        <span class="menu-collapsed">Installing and Using Codewind on Kubernetes</span>
                    </div>
                </a>
                <a href="supportingmultipleusers.html" 
			        
				    
				    class="bg-light list-group-item list-group-item-action">
				    <div class="d-flex w-100 justify-content-start align-items-center">
                        <span class="menu-collapsed">Support for multiple users</span>
                    </div>
                </a>
                <a href="viewkibanalogs.html" 
			        
				    
				    class="bg-light list-group-item list-group-item-action">
				    <div class="d-flex w-100 justify-content-start align-items-center">
                        <span class="menu-collapsed">Viewing logs using Kibana in IBM Cloud Private</span>
                    </div>
                </a>
            </div>            

			<a href="installlocally.html" 
			    
				
				class="bg-light list-group-item list-group-item-action">
				<div class="d-flex w-100 justify-content-start align-items-center">
                    <span class="menu-collapsed">Installing Codewind locally</span>
                </div>
            </a>

            <a href="#codewind_for_eclipse" data-toggle="collapse" aria-expanded="false" class="bg-light list-group-item list-group-item-action flex-column align-items-start collapsed">
                <div class="d-flex w-100 justify-content-start align-items-center">
                    <span class="menu-collapsed">Codewind for Eclipse</span>
                    <span class="submenu-icon ml-auto"></span>
                </div>
            </a>
            <div id="codewind_for_eclipse" class="cw-sidebar-div cw-sidebar-submenu collapse" style="">
                <a href="mdteclipseoverview.html" 
                    
                    
                    class="bg-light list-group-item list-group-item-action">
                    <div class="d-flex w-100 justify-content-start align-items-center">
                        <span class="menu-collapsed">Overview</span>
                    </div>
                </a>
                <a href="mdteclipsegettingstarted.html" 
                    
                    
                    class="bg-light list-group-item list-group-item-action">
                    <div class="d-flex w-100 justify-content-start align-items-center">
                        <span class="menu-collapsed">Installation and Getting Started</span>
                    </div>
                </a>
                <a href="mdteclipsemanagingprojects.html" 
                    
                    
                    class="bg-light list-group-item list-group-item-action">
                    <div class="d-flex w-100 justify-content-start align-items-center">
                        <span class="menu-collapsed">Managing Codewind projects</span>
                    </div>
                </a>
                <a href="mdteclipsebuildproject.html" 
                    
                    
                    class="bg-light list-group-item list-group-item-action">
                    <div class="d-flex w-100 justify-content-start align-items-center">
                        <span class="menu-collapsed">Building Codewind projects</span>
                    </div>
                </a>
                <a href="mdteclipsedebugproject.html" 
                    
                    
                    class="bg-light list-group-item list-group-item-action">
                    <div class="d-flex w-100 justify-content-start align-items-center">
                        <span class="menu-collapsed">Debugging Codewind projects</span>
                    </div>
                </a>
                <a href="mdteclipsetroubleshooting.html" 
                    
                    
                    class="bg-light list-group-item list-group-item-action">
                    <div class="d-flex w-100 justify-content-start align-items-center">
                        <span class="menu-collapsed">Troubleshooting</span>
                    </div>
                </a>
                <a href="mdteclipseuninstall.html" 
                    
                    
                    class="bg-light list-group-item list-group-item-action">
                    <div class="d-flex w-100 justify-content-start align-items-center">
                        <span class="menu-collapsed">Uninstalling</span>
                    </div>
                </a>
            </div>
            
            <a href="#codewind_for_vscode" data-toggle="collapse" aria-expanded="false" class="bg-light list-group-item list-group-item-action flex-column align-items-start collapsed">
                <div class="d-flex w-100 justify-content-start align-items-center">
                    <span class="menu-collapsed">Codewind for VS Code</span>
                    <span class="submenu-icon ml-auto"></span>
                </div>
            </a>
            <div id="codewind_for_vscode" class="cw-sidebar-div cw-sidebar-submenu collapse" style="">
                <a href="mdt-vsc-overview.html" 
                    
                    
                    class="bg-light list-group-item list-group-item-action">
                    <div class="d-flex w-100 justify-content-start align-items-center">
                        <span class="menu-collapsed">Overview</span>
                    </div>
                </a>
                <a href="mdt-vsc-getting-started.html"
                    
                    
                    class="bg-light list-group-item list-group-item-action">
                    <div class="d-flex w-100 justify-content-start align-items-center">
                        <span class="menu-collapsed">Getting started</span>
                    </div>
                </a>
                <a href="mdt-vsc-tutorial.html"
                    
                    
                    class="bg-light list-group-item list-group-item-action">
                    <div class="d-flex w-100 justify-content-start align-items-center">
                        <span class="menu-collapsed">Tutorial</span>
                    </div>
                </a>
                <a href="mdt-vsc-commands-overview.html"
                    
                    
                    class="bg-light list-group-item list-group-item-action">
                    <div class="d-flex w-100 justify-content-start align-items-center">
                        <span class="menu-collapsed">Commands overview</span>
                    </div>
                </a>
                <a href="mdt-vsc-commands-project.html"
                    
                    
                    class="bg-light list-group-item list-group-item-action">
                    <div class="d-flex w-100 justify-content-start align-items-center">
                        <span class="menu-collapsed">Project commands</span>
                    </div>
                </a>
                <a href="mdt-vsc-commands-restart-and-debug.html"
                    
                    
                    class="bg-light list-group-item list-group-item-action">
                    <div class="d-flex w-100 justify-content-start align-items-center">
                        <span class="menu-collapsed">Restart and debug commands</span>
                    </div>
                </a>
                <a href="mdt-vsc-troubleshooting.html"
                    
                    
                    class="bg-light list-group-item list-group-item-action">
                    <div class="d-flex w-100 justify-content-start align-items-center">
                        <span class="menu-collapsed">Troubleshooting</span>
                    </div>
                </a>
                <a href="mdt-vsc-uninstall.html"
                    
                    
                    class="bg-light list-group-item list-group-item-action">
                    <div class="d-flex w-100 justify-content-start align-items-center">
                        <span class="menu-collapsed">Uninstalling</span>
                    </div>
                </a>
            </div>

            <a href="#configuring_codewind" data-toggle="collapse" aria-expanded="false" class="bg-light list-group-item list-group-item-action flex-column align-items-start collapsed">
                <div class="d-flex w-100 justify-content-start align-items-center">
                    <span class="menu-collapsed">Configuring Codewind</span>
                    <span class="submenu-icon ml-auto"></span>
                </div>
            </a>
            <div id="configuring_codewind" class="cw-sidebar-div cw-sidebar-submenu collapse" style="">
                <a href="usingadifferenttemplate.html" 
			        
				    
				    class="bg-light list-group-item list-group-item-action">
				    <div class="d-flex w-100 justify-content-start align-items-center">
                        <span class="menu-collapsed">Using a template repository of your own</span>
                    </div>
                </a>

            </div>

            <a href="guide_performance.html" 
			    
				
				class="bg-light list-group-item list-group-item-action">
				<div class="d-flex w-100 justify-content-start align-items-center">
                    <span class="menu-collapsed">Guide: Monitoring applications with the performance dashboard</span>
                </div>
            </a>

            <a href="uninstall.html"
                
                
                class="bg-light list-group-item list-group-item-action">
                <div class="d-flex w-100 justify-content-start align-items-center">
                    <span class="menu-collapsed">Uninstalling Codewind</span>
                </div>
            </a>

            <a href="troubleshooting.html"
                
                
                class="bg-light list-group-item list-group-item-action">
                <div class="d-flex w-100 justify-content-start align-items-center">
                    <span class="menu-collapsed">Troubleshooting</span>
                </div>
            </a>

            <a href="limitations.html"
                
                
                class="bg-light list-group-item list-group-item-action">
                <div class="d-flex w-100 justify-content-start align-items-center">
                    <span class="menu-collapsed">Limitations</span>
                </div>
            </a>

            <!-- END hard coded TOC -->

            <!-- Separator without title -->
            <li class="list-group-item cw-sidebar-separator-title bg-light  cw-text-gray d-flex align-items-center menu-collapsed">
                <small class="badge badge-success cw-margin-auto">HELPFUL
        LINKS</small>
            </li>
            <!-- /END Separator -->
            <a href="https://projects.eclipse.org/proposals/eclipse-codewind" class="bg-light list-group-item list-group-item-action">
                <div class="d-flex w-100 justify-content-start align-items-center">
                    <span class="menu-collapsed">Eclipse Codewind project page</span>
                </div>
            </a>
            <a href="https://www.youtube.com/channel/UCnKCVK6RFDyHFqUmXlAhCHQ" class="bg-light list-group-item list-group-item-action">
                <div class="d-flex w-100 justify-content-start align-items-center">
                    <span class="menu-collapsed">Eclipse Codewind YouTube channel</span>
                </div>
            </a>
            
            
            <!-- Logo -->
            <li class="list-group-item cw-logo-separator  bg-light d-flex justify-content-center">
                <img src="images/header-logo.svg">
            </li>
        </ul>
        <!-- List Group END-->
    </div>
    <!-- sidebar-container END -->
    <!-- MAIN -->
    <div id="content-container" class="py-5 px-5">
        <div role="main"><h1 id="codewind-docker-registry-guidance">Codewind Docker registry guidance</h1>

<p>When you run Codewind on Kubernetes, Codewind uses <a href="https://github.com/containers/buildah"><code class="highlighter-rouge">buildah</code></a> to build container images from Dockerfiles and then push the images to a container registry that you specify.</p>

<p>Codewind is flexible with the registry that can be used as long as <code class="highlighter-rouge">buildah</code> and the node that Codewind is running on can resolve the registry hostname. If <code class="highlighter-rouge">buildah</code> is unable to resolve the registry hostname, <code class="highlighter-rouge">buildah</code> will be unable to push your projects to the registry and will prevent deployment on Kubernetes.</p>

<p>Before you proceed, see the <a href="#examples">examples</a> section on recommended values for common registries:</p>

<h2 id="examples">Examples:</h2>
<p>The following deployment registries have been tested and verified with Codewind:</p>
<ul>
  <li>Dockerhub:
    <ul>
      <li>Host: <code class="highlighter-rouge">docker.io</code></li>
      <li>Codewind deployment registry: <code class="highlighter-rouge">docker.io/&lt;username&gt;</code></li>
      <li>Credentials: Dockerhub user name and password</li>
    </ul>
  </li>
  <li>Quay.io:
    <ul>
      <li>Host: <code class="highlighter-rouge">https://quay.io</code></li>
      <li>Codewind deployment registry: <code class="highlighter-rouge">https://quay.io/&lt;username&gt;</code></li>
      <li>Credentials: Quay.io user name and encrpyted password</li>
    </ul>
  </li>
  <li>Artifactory
    <ul>
      <li>Host: <code class="highlighter-rouge">&lt;artifactory-hostname&gt;</code></li>
      <li>Codewind deployment registry: <code class="highlighter-rouge">&lt;artifactory-hostname&gt;/&lt;username&gt;</code></li>
      <li>Credentials: Artifactory user name and token</li>
    </ul>
  </li>
  <li>OpenShift Registry
    <ul>
      <li>Host: <code class="highlighter-rouge">docker-registry.default.svc:5000</code></li>
      <li>Codewind deployment registry: <code class="highlighter-rouge">docker-registry.default.svc:5000/&lt;project&gt;</code></li>
      <li>Credentials: OpenShift user name and token</li>
    </ul>
  </li>
</ul>

<h2 id="step-1-authenticating-registry-credentials">Step 1: Authenticating registry credentials</h2>
<p>To push to the container registry, first add the registry credentials with Che.</p>
<ol>
  <li>On the Che dashboard, click the <strong>Administration</strong> tab in the sidebar.</li>
  <li>Click <strong>Add Registry</strong>.</li>
  <li>Enter the container registry host, such as <code class="highlighter-rouge">quay.io</code> or <code class="highlighter-rouge">http://index.docker.io/v1/</code>.</li>
  <li>Enter your user credentials for the registry.
These credentials are passed into each Codewind workspace that is deployed in your user account in Che.</li>
  <li>If a Codewind workspace is already running, restart the workspace to make the changes take effect.</li>
</ol>

<h2 id="step-2-specifying-the-deployment-registry-for-the-codewind-workspace">Step 2: Specifying the deployment registry for the Codewind workspace</h2>
<p>Before you deploy your project with Codewind, first specify a deployment registry to push the images to.</p>
<ol>
  <li>When you first deploy a project in Codewind, Codewind prompts you to set a deployment registry.
    <ul>
      <li>If Codewind detects the registry is unset, Codewind prompts before deploying a project.</li>
    </ul>
  </li>
  <li>Enter a path with which to push your container.
    <ul>
      <li><strong>Important:</strong> Before attempting this step, ensure that you have entered the registry credentials with the Che dashboard.</li>
    </ul>
  </li>
  <li>Codewind asks if you want to verify push permissions. If you select <strong>yes</strong>, Codewind pushes a small <code class="highlighter-rouge">hello-world</code> image to the registry to verify permissions.</li>
</ol>

<h3 id="instructions-specific-to-ibm-cloud-private">Instructions specific to IBM Cloud Private</h3>
<ul>
  <li>The internal Docker registry on IBM Cloud Private is <strong>not</strong> supported. Instead, you need to use either an external registry or a container registry that you installed yourself.
    <ul>
      <li>If a registry that you installed is using self-signed certificates, the registry must be whitelisted in both Kubernetes and Docker on <strong>all</strong> nodes.</li>
    </ul>
  </li>
  <li>The <code class="highlighter-rouge">docker.io</code>, <code class="highlighter-rouge">quay.io</code>, and <code class="highlighter-rouge">artifactory</code> container registry hosts have been tested with IBM Cloud Private.</li>
</ul>

<h3 id="instructions-specific-to-okd-and-openshift">Instructions specific to OKD and OpenShift</h3>
<ul>
  <li>The internal container registry on OKD and OpenShift is supported.</li>
  <li>To use the internal container registry with Codewind, specify the internal hostname for the registry instead of the publicly exposed container registry.
    <ul>
      <li>If you enter credentials with Che, use <code class="highlighter-rouge">docker-registry.default.svc:5000</code> as the host and your cluser user name and account key as the credentials.</li>
      <li>If you enter the tag to push with Codewind, use <code class="highlighter-rouge">docker-registry.default.svc:5000/&lt;project&gt;</code>, where <code class="highlighter-rouge">&lt;project&gt;</code> is a project on your cluster, such as <code class="highlighter-rouge">eclipse-che</code>.</li>
    </ul>
  </li>
  <li>For more information, see <a href="https://blog.openshift.com/remotely-push-pull-container-images-openshift/">Remotely Push and Pull Container Images to OpenShift</a>.</li>
</ul>

</div>
    </div>
</div>
<!-- Main Col END -->
<!-- footer row -->
<footer>
    <div class="row" id="footer-div">
        <div class="col-lg-3 col-md-3 footer-col text-center">
            <div>
                <div>
                    <a href="https://twitter.com/EclipseCodewind"><img src="images/twitter-logo.svg" class="cw-logo" /></a>
                </div>
                <div>@EclipseCodewind</div>
            </div>
        </div>
        
        <div class="col-lg-3 col-md-3 footer-col text-center">
            <div>
                <div>
                    <a href="https://github.com/eclipse/codewind"><img src="images/github-logo.svg"
                            class="cw-logo" /></a>
                </div>
                <div>@Codewind</div>
            </div>
        </div>
        <div class="col-lg-3 col-md-3 footer-col text-center">
            <div>
                <div>
                    <a href="mailto:codewind-dev@eclipse.org"><img src="images/email-icon.svg" class="cw-logo" /></a>
                </div>
                <div>@Codewind</div>
            </div>
        </div>

        <div class="col-lg-3 col-md-3 footer-col text-center">
            <div class="cw-logo-mm" >
                <div class="cw-logo-mm" >
                    <a href="https://mattermost.eclipse.org/eclipse/channels/eclipse-codewind"><img src="images/mattermost-logo.png" class="cw-logo-mm" /></a>
                </div>
            </div>
        </div>

    </div>
</footer>
<!-- footer row END --> <!-- Jquery -->
<script
  src="https://code.jquery.com/jquery-3.4.1.min.js"
  integrity="sha256-CSXorXvZcTkaix6Yvo6HppcZGetbYMGWSFlBw8HfCJo="
  crossorigin="anonymous"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.7/umd/popper.min.js"
    integrity="sha384-UO2eT0CpHqdSJQ6hJty5KVphtPhzWj9WO1clHTMGa3JDZwrnQq4sF86dIHNDz0W1" crossorigin="anonymous">
</script>



<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js"
    integrity="sha384-JjSmVgyd0p3pXB1rRibZUAYoIIy6OrQ6VrjIEaFf/nJGzIxFDsf4x0xIM+B07jRM" crossorigin="anonymous">
</script>


<!-- Font Awesome JS -->
<script defer src="https://use.fontawesome.com/releases/v5.0.13/js/solid.js"
    integrity="sha384-tzzSw1/Vo+0N5UhStP3bvwWPq+uvzCMfrN1fEFe+xBmv1C/AtVX5K0uZtmcHitFZ" crossorigin="anonymous">
</script>
<script defer src="https://use.fontawesome.com/releases/v5.0.13/js/fontawesome.js"
    integrity="sha384-6OIrr52G08NpOFSZdxxz1xdNSndlD4vdcf/q2myIUVO0VsqaGHJsB0RaBE01VTOY" crossorigin="anonymous">
</script>
<!-- Place this tag in your head or just before your close body tag. -->
<script async defer src="https://buttons.github.io/buttons.js"></script>

<script src="js/jquery.matchHeight-min.js"></script>
<script src="js/index.js"></script>
<script src="js/docs.js"></script>

</div>
</body>

</html>
