"use strict";(self.webpackChunkwebsite=self.webpackChunkwebsite||[]).push([[5893],{6071:(e,n,r)=>{r.r(n),r.d(n,{assets:()=>l,contentTitle:()=>c,default:()=>u,frontMatter:()=>i,metadata:()=>a,toc:()=>d});var s=r(5893),t=r(1151),o=r(5471);const i={title:"Getting Started with Docker"},c=void 0,a={id:"guides/docker-share/index",title:"Getting Started with Docker",description:"Overview",source:"@site/../docs/guides/docker-share/index.mdx",sourceDirName:"guides/docker-share",slug:"/guides/docker-share/",permalink:"/docs/guides/docker-share/",draft:!1,unlisted:!1,editUrl:"https://github.com/openziti/zrok/blob/main/docs/../docs/guides/docker-share/index.mdx",tags:[],version:"current",frontMatter:{title:"Getting Started with Docker"},sidebar:"tutorialSidebar",previous:{title:"Permission Modes",permalink:"/docs/guides/permission-modes"},next:{title:"Public Share",permalink:"/docs/guides/docker-share/docker_public_share_guide"}},l={},d=[{value:"Overview",id:"overview",level:2},{value:"Permanent Public Share",id:"permanent-public-share",level:2},{value:"Temporary Public Share",id:"temporary-public-share",level:2}];function h(e){const n={a:"a",code:"code",h2:"h2",li:"li",ol:"ol",p:"p",pre:"pre",...(0,t.a)(),...e.components};return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(n.h2,{id:"overview",children:"Overview"}),"\n",(0,s.jsxs)(n.p,{children:["To follow the guides in this section you will need ",(0,s.jsx)(n.a,{href:"https://docs.docker.com/get-docker/",children:"Docker"}),"."]}),"\n",(0,s.jsxs)(n.p,{children:["You have the option to enable a ",(0,s.jsx)(n.code,{children:"zrok"})," account on the Docker host and mount it on the container or you can use the provided Docker Compose project files (",(0,s.jsx)(n.code,{children:"compose.yml"}),") to enable a separate ",(0,s.jsx)(n.code,{children:"zrok"})," environment for each project."]}),"\n",(0,s.jsxs)(n.p,{children:["This page provides ",(0,s.jsx)(n.code,{children:"docker"})," and ",(0,s.jsx)(n.code,{children:"docker compose"})," examples of mounting the host's ",(0,s.jsx)(n.code,{children:"zrok"})," environment on the container. You'll need to first ",(0,s.jsx)(n.a,{href:"/docs/getting-started/#installing-the-zrok-command",children:"enable zrok on the Docker host"})," to use this approach."]}),"\n",(0,s.jsx)(n.h2,{id:"permanent-public-share",children:"Permanent Public Share"}),"\n",(0,s.jsxs)(n.p,{children:["Let's say you have a ",(0,s.jsx)(n.code,{children:"compose.yml"})," file that defines a web app known within the project's bridge network as ",(0,s.jsx)(n.code,{children:"https://myapp:8080"})," and you want to publish it as a reliable, public site."]}),"\n",(0,s.jsxs)(n.ol,{children:["\n",(0,s.jsxs)(n.li,{children:["\n",(0,s.jsxs)(n.p,{children:["Reserve a subdomain by running ",(0,s.jsx)(n.code,{children:'zrok reserve public --unique-name "myapp" https://myapp:8080'})," on the Docker host."]}),"\n"]}),"\n",(0,s.jsxs)(n.li,{children:["\n",(0,s.jsxs)(n.p,{children:["Merge this YAML with ",(0,s.jsx)(n.code,{children:"compose.yml"})," or save it in the same directory as ",(0,s.jsx)(n.code,{children:"compose.override.yml"})," to let ",(0,s.jsx)(n.code,{children:"docker compose up"})," merge it for you."]}),"\n",(0,s.jsx)(n.pre,{children:(0,s.jsx)(n.code,{className:"language-yaml",children:'services:\n zrok:\n image: openziti/zrok\n restart: unless-stopped\n user: "${UID}"\n volumes:\n - ${HOME}/.zrok:/.zrok\n environment:\n PFXLOG_NO_JSON: "true"\n command: share reserved "myapp" --headless\n'})}),"\n"]}),"\n"]}),"\n",(0,s.jsxs)(n.p,{children:["The reserved share will be available at ",(0,s.jsx)(n.code,{children:"https://myapp.share.zrok.io"})," each time the ",(0,s.jsx)(n.code,{children:"zrok"})," container starts up."]}),"\n",(0,s.jsx)(n.h2,{id:"temporary-public-share",children:"Temporary Public Share"}),"\n",(0,s.jsxs)(n.p,{children:["Let's say you have a web server running on the host's private network at ",(0,s.jsx)(n.code,{children:"https://10.11.12.13:8080"}),". With one additional ",(0,s.jsx)(n.code,{children:"docker"})," command, you can share the web server publicly as long as the ",(0,s.jsx)(n.code,{children:"zrok"})," container stays running."]}),"\n",(0,s.jsx)(n.pre,{children:(0,s.jsx)(n.code,{className:"language-bash",metastring:'title="BASH"',children:'docker run \\\n --rm \\\n --network=host \\\n --volume ~/.zrok:/.zrok \\\n --user "${UID}" \\\n openziti/zrok share public \\\n --headless \\\n https://10.11.12.13:8080\n'})}),"\n",(0,s.jsxs)(o.Z,{children:[(0,s.jsx)("summary",{children:"PowerShell"}),(0,s.jsx)(n.pre,{children:(0,s.jsx)(n.code,{className:"language-powershell",children:'docker.exe run `\n --rm `\n --network "host" `\n --volume "${env:USERPROFILE}\\.zrok:/.zrok" `\n --user "1000" `\n openziti/zrok share public `\n --headless `\n https://10.11.12.13:8080\n'})})]}),"\n",(0,s.jsxs)(o.Z,{children:[(0,s.jsx)("summary",{children:"Command Prompt (batch)"}),(0,s.jsx)(n.pre,{children:(0,s.jsx)(n.code,{className:"language-cmd",children:'docker.exe run ^\n --rm ^\n --network "host" ^\n --volume "%USERPROFILE%\\.zrok:/.zrok" ^\n --user "1000" ^\n openziti/zrok share public ^\n --headless ^\n https://10.11.12.13:8080\n'})})]}),"\n",(0,s.jsxs)(o.Z,{children:[(0,s.jsx)("summary",{children:"Windows Subsystem for Linux (WSL)"}),(0,s.jsx)(n.pre,{children:(0,s.jsx)(n.code,{className:"language-bash",children:'docker run \\\n --rm \\\n --network "host" \\\n --volume "/mnt/c/Users/$(powershell.exe -Command \'Write-Output $env:USERNAME\' | tr -d \'\\r\')/.zrok:/.zrok" \\\n --user "$UID" \\\n openziti/zrok share public \\\n --headless \\\n https://10.11.12.13:8080\n'})})]}),"\n",(0,s.jsx)(n.p,{children:"The public share URL appears near the beginning of the container's log."}),"\n",(0,s.jsx)(n.p,{children:"Let's break down those options and arguments."}),"\n",(0,s.jsxs)(n.ol,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.code,{children:"--rm"})," don't save this container because it's providing a temporary public share that's destroyed when the container stops"]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.code,{children:"--network=host"})," shares the host's network with the container so that the container can reach the web server directly. This is always necessary when the web server is listening only on the host's loopback interface, e.g., ",(0,s.jsx)(n.code,{children:"https://::1:8080"}),", and may not be strictly necessary if the target is routeable from the default Docker bridge."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.code,{children:"--volume ~/.zrok:/.zrok"})," mounts the ",(0,s.jsx)(n.code,{children:"zrok"})," configuration from the Docker host into the container."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.code,{children:'--user "${UID}:${GID}"'})," sets the container's user to the current user on the Docker host to avoid permission issues with reading the mounted ",(0,s.jsx)(n.code,{children:"zrok"})," configuration."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.code,{children:"openziti/zrok"})," is the ",(0,s.jsx)(n.code,{children:"zrok"})," Docker image."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.code,{children:"share public"})," is the ",(0,s.jsx)(n.code,{children:"zrok"})," command to share the target publicly until zrok exits."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.code,{children:"--headless"})," runs the ",(0,s.jsx)(n.code,{children:"zrok"})," command without the interactive terminal UI."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.code,{children:"https://10.11.12.13:8080"})," is the target web server to share."]}),"\n"]})]})}function u(e={}){const{wrapper:n}={...(0,t.a)(),...e.components};return n?(0,s.jsx)(n,{...e,children:(0,s.jsx)(h,{...e})}):h(e)}},5471:(e,n,r)=>{r.d(n,{Z:()=>j});var s=r(7294),t=r(6905),o=r(788),i=r(2389),c=r(6043);const a={details:"details_lb9f",isBrowser:"isBrowser_bmU9",collapsibleContent:"collapsibleContent_i85q"};var l=r(5893);function d(e){return!!e&&("SUMMARY"===e.tagName||d(e.parentElement))}function h(e,n){return!!e&&(e===n||h(e.parentElement,n))}function u(e){let{summary:n,children:r,...t}=e;const u=(0,i.Z)(),p=(0,s.useRef)(null),{collapsed:m,setCollapsed:x}=(0,c.u)({initialState:!t.open}),[j,k]=(0,s.useState)(t.open),b=s.isValidElement(n)?n:(0,l.jsx)("summary",{children:n??"Details"});return(0,l.jsxs)("details",{...t,ref:p,open:j,"data-collapsed":m,className:(0,o.Z)(a.details,u&&a.isBrowser,t.className),onMouseDown:e=>{d(e.target)&&e.detail>1&&e.preventDefault()},onClick:e=>{e.stopPropagation();const n=e.target;d(n)&&h(n,p.current)&&(e.preventDefault(),m?(x(!1),k(!0)):x(!0))},children:[b,(0,l.jsx)(c.z,{lazy:!1,collapsed:m,disableSSRStyle:!0,onCollapseTransitionEnd:e=>{x(e),k(!e)},children:(0,l.jsx)("div",{className:a.collapsibleContent,children:r})})]})}const p={details:"details_b_Ee"},m="alert alert--info";function x(e){let{...n}=e;return(0,l.jsx)(u,{...n,className:(0,t.Z)(m,p.details,n.className)})}function j(e){const n=s.Children.toArray(e.children),r=n.find((e=>s.isValidElement(e)&&"summary"===e.type)),t=(0,l.jsx)(l.Fragment,{children:n.filter((e=>e!==r))});return(0,l.jsx)(x,{...e,summary:r,children:t})}},1151:(e,n,r)=>{r.d(n,{Z:()=>c,a:()=>i});var s=r(7294);const t={},o=s.createContext(t);function i(e){const n=s.useContext(o);return s.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function c(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(t):e.components||t:i(e.components),s.createElement(o.Provider,{value:n},e.children)}}}]);