Modified: karaf/site/production/manual/latest/deployers.html URL: http://svn.apache.org/viewvc/karaf/site/production/manual/latest/deployers.html?rev=1839907&r1=1839906&r2=1839907&view=diff ============================================================================== --- karaf/site/production/manual/latest/deployers.html (original) +++ karaf/site/production/manual/latest/deployers.html Mon Sep 3 06:10:48 2018 @@ -817,7 +817,7 @@ For instance:</p> </div> <div id="footer"> <div id="footer-text"> -Last updated 2017-11-15 16:55:26 +01:00 +Last updated 2018-07-31 07:02:52 +02:00 </div> </div> </body>
Modified: karaf/site/production/manual/latest/developer-commands.html URL: http://svn.apache.org/viewvc/karaf/site/production/manual/latest/developer-commands.html?rev=1839907&r1=1839906&r2=1839907&view=diff ============================================================================== --- karaf/site/production/manual/latest/developer-commands.html (original) +++ karaf/site/production/manual/latest/developer-commands.html Mon Sep 3 06:10:48 2018 @@ -809,7 +809,7 @@ system folder.</p> </div> <div id="footer"> <div id="footer-text"> -Last updated 2017-07-26 16:36:29 +02:00 +Last updated 2018-06-17 17:18:28 +02:00 </div> </div> </body> Modified: karaf/site/production/manual/latest/directory-structure.html URL: http://svn.apache.org/viewvc/karaf/site/production/manual/latest/directory-structure.html?rev=1839907&r1=1839906&r2=1839907&view=diff ============================================================================== --- karaf/site/production/manual/latest/directory-structure.html (original) +++ karaf/site/production/manual/latest/directory-structure.html Mon Sep 3 06:10:48 2018 @@ -521,7 +521,7 @@ table.CodeRay td.code>pre{padding:0} <p><code>/bin</code>: control scripts to start, stop, login, …​</p> </li> <li> -<p><code>/demos</code>: contains some simple Karaf samples</p> +<p><code>/examples</code>: contains several examples to start with Apache Karaf</p> </li> <li> <p><code>/etc</code>: configuration files</p> @@ -553,7 +553,7 @@ table.CodeRay td.code>pre{padding:0} <div class="ulist"> <ul> <li> -<p><code>/lib/boot</code>: contains the systeù libraries used at Karaf bootstrap</p> +<p><code>/lib/boot</code>: contains the system libraries used at Karaf bootstrap</p> </li> <li> <p><code>/lib/endorsed</code>: directory for endorsed libraries</p> @@ -589,7 +589,7 @@ using the clean option to the Karaf star </div> <div id="footer"> <div id="footer-text"> -Last updated 2017-07-26 16:36:29 +02:00 +Last updated 2018-08-17 21:42:57 +02:00 </div> </div> </body> Added: karaf/site/production/manual/latest/docker.html URL: http://svn.apache.org/viewvc/karaf/site/production/manual/latest/docker.html?rev=1839907&view=auto ============================================================================== --- karaf/site/production/manual/latest/docker.html (added) +++ karaf/site/production/manual/latest/docker.html Mon Sep 3 06:10:48 2018 @@ -0,0 +1,1029 @@ +<!DOCTYPE html> +<html lang="en"> +<head> +<meta charset="UTF-8"> +<!--[if IE]><meta http-equiv="X-UA-Compatible" content="IE=edge"><![endif]--> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> +<meta name="generator" content="Asciidoctor 1.5.2"> +<title>Docker</title> +<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Open+Sans:300,300italic,400,400italic,600,600italic%7CNoto+Serif:400,400italic,700,700italic%7CDroid+Sans+Mono:400"> +<style> +/* Asciidoctor default stylesheet | MIT License | http://asciidoctor.org */ +/* Remove the comments around the @import statement below when using this as a custom stylesheet */ +/*@import "https://fonts.googleapis.com/css?family=Open+Sans:300,300italic,400,400italic,600,600italic%7CNoto+Serif:400,400italic,700,700italic%7CDroid+Sans+Mono:400";*/ +article,aside,details,figcaption,figure,footer,header,hgroup,main,nav,section,summary{display:block} +audio,canvas,video{display:inline-block} +audio:not([controls]){display:none;height:0} +[hidden],template{display:none} +script{display:none!important} +html{font-family:sans-serif;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%} +body{margin:0} +a{background:transparent} +a:focus{outline:thin dotted} +a:active,a:hover{outline:0} +h1{font-size:2em;margin:.67em 0} +abbr[title]{border-bottom:1px dotted} +b,strong{font-weight:bold} +dfn{font-style:italic} +hr{-moz-box-sizing:content-box;box-sizing:content-box;height:0} +mark{background:#ff0;color:#000} +code,kbd,pre,samp{font-family:monospace;font-size:1em} +pre{white-space:pre-wrap} +q{quotes:"\201C" "\201D" "\2018" "\2019"} +small{font-size:80%} +sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline} +sup{top:-.5em} +sub{bottom:-.25em} +img{border:0} +svg:not(:root){overflow:hidden} +figure{margin:0} +fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em} +legend{border:0;padding:0} +button,input,select,textarea{font-family:inherit;font-size:100%;margin:0} +button,input{line-height:normal} +button,select{text-transform:none} +button,html input[type="button"],input[type="reset"],input[type="submit"]{-webkit-appearance:button;cursor:pointer} +button[disabled],html input[disabled]{cursor:default} +input[type="checkbox"],input[type="radio"]{box-sizing:border-box;padding:0} +input[type="search"]{-webkit-appearance:textfield;-moz-box-sizing:content-box;-webkit-box-sizing:content-box;box-sizing:content-box} +input[type="search"]::-webkit-search-cancel-button,input[type="search"]::-webkit-search-decoration{-webkit-appearance:none} +button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0} +textarea{overflow:auto;vertical-align:top} +table{border-collapse:collapse;border-spacing:0} +*,*:before,*:after{-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box} +html,body{font-size:100%} +body{background:#fff;color:rgba(0,0,0,.8);padding:0;margin:0;font-family:"Noto Serif","DejaVu Serif",serif;font-weight:400;font-style:normal;line-height:1;position:relative;cursor:auto} +a:hover{cursor:pointer} +img,object,embed{max-width:100%;height:auto} +object,embed{height:100%} +img{-ms-interpolation-mode:bicubic} +#map_canvas img,#map_canvas embed,#map_canvas object,.map_canvas img,.map_canvas embed,.map_canvas object{max-width:none!important} +.left{float:left!important} +.right{float:right!important} +.text-left{text-align:left!important} +.text-right{text-align:right!important} +.text-center{text-align:center!important} +.text-justify{text-align:justify!important} +.hide{display:none} +.antialiased,body{-webkit-font-smoothing:antialiased} +img{display:inline-block;vertical-align:middle} +textarea{height:auto;min-height:50px} +select{width:100%} +p.lead,.paragraph.lead>p,#preamble>.sectionbody>.paragraph:first-of-type p{font-size:1.21875em;line-height:1.6} +.subheader,.admonitionblock td.content>.title,.audioblock>.title,.exampleblock>.title,.imageblock>.title,.listingblock>.title,.literalblock>.title,.stemblock>.title,.openblock>.title,.paragraph>.title,.quoteblock>.title,table.tableblock>.title,.verseblock>.title,.videoblock>.title,.dlist>.title,.olist>.title,.ulist>.title,.qlist>.title,.hdlist>.title{line-height:1.45;color:#7a2518;font-weight:400;margin-top:0;margin-bottom:.25em} +div,dl,dt,dd,ul,ol,li,h1,h2,h3,#toctitle,.sidebarblock>.content>.title,h4,h5,h6,pre,form,p,blockquote,th,td{margin:0;padding:0;direction:ltr} +a{color:#2156a5;text-decoration:underline;line-height:inherit} +a:hover,a:focus{color:#1d4b8f} +a img{border:none} +p{font-family:inherit;font-weight:400;font-size:1em;line-height:1.6;margin-bottom:1.25em;text-rendering:optimizeLegibility} +p aside{font-size:.875em;line-height:1.35;font-style:italic} +h1,h2,h3,#toctitle,.sidebarblock>.content>.title,h4,h5,h6{font-family:"Open Sans","DejaVu Sans",sans-serif;font-weight:300;font-style:normal;color:#ba3925;text-rendering:optimizeLegibility;margin-top:1em;margin-bottom:.5em;line-height:1.0125em} +h1 small,h2 small,h3 small,#toctitle small,.sidebarblock>.content>.title small,h4 small,h5 small,h6 small{font-size:60%;color:#e99b8f;line-height:0} +h1{font-size:2.125em} +h2{font-size:1.6875em} +h3,#toctitle,.sidebarblock>.content>.title{font-size:1.375em} +h4,h5{font-size:1.125em} +h6{font-size:1em} +hr{border:solid #ddddd8;border-width:1px 0 0;clear:both;margin:1.25em 0 1.1875em;height:0} +em,i{font-style:italic;line-height:inherit} +strong,b{font-weight:bold;line-height:inherit} +small{font-size:60%;line-height:inherit} +code{font-family:"Droid Sans Mono","DejaVu Sans Mono",monospace;font-weight:400;color:rgba(0,0,0,.9)} +ul,ol,dl{font-size:1em;line-height:1.6;margin-bottom:1.25em;list-style-position:outside;font-family:inherit} +ul,ol,ul.no-bullet,ol.no-bullet{margin-left:1.5em} +ul li ul,ul li ol{margin-left:1.25em;margin-bottom:0;font-size:1em} +ul.square li ul,ul.circle li ul,ul.disc li ul{list-style:inherit} +ul.square{list-style-type:square} +ul.circle{list-style-type:circle} +ul.disc{list-style-type:disc} +ul.no-bullet{list-style:none} +ol li ul,ol li ol{margin-left:1.25em;margin-bottom:0} +dl dt{margin-bottom:.3125em;font-weight:bold} +dl dd{margin-bottom:1.25em} +abbr,acronym{text-transform:uppercase;font-size:90%;color:rgba(0,0,0,.8);border-bottom:1px dotted #ddd;cursor:help} +abbr{text-transform:none} +blockquote{margin:0 0 1.25em;padding:.5625em 1.25em 0 1.1875em;border-left:1px solid #ddd} +blockquote cite{display:block;font-size:.9375em;color:rgba(0,0,0,.6)} +blockquote cite:before{content:"\2014 \0020"} +blockquote cite a,blockquote cite a:visited{color:rgba(0,0,0,.6)} +blockquote,blockquote p{line-height:1.6;color:rgba(0,0,0,.85)} +@media only screen and (min-width:768px){h1,h2,h3,#toctitle,.sidebarblock>.content>.title,h4,h5,h6{line-height:1.2} +h1{font-size:2.75em} +h2{font-size:2.3125em} +h3,#toctitle,.sidebarblock>.content>.title{font-size:1.6875em} +h4{font-size:1.4375em}}table{background:#fff;margin-bottom:1.25em;border:solid 1px #dedede} +table thead,table tfoot{background:#f7f8f7;font-weight:bold} +table thead tr th,table thead tr td,table tfoot tr th,table tfoot tr td{padding:.5em .625em .625em;font-size:inherit;color:rgba(0,0,0,.8);text-align:left} +table tr th,table tr td{padding:.5625em .625em;font-size:inherit;color:rgba(0,0,0,.8)} +table tr.even,table tr.alt,table tr:nth-of-type(even){background:#f8f8f7} +table thead tr th,table tfoot tr th,table tbody tr td,table tr td,table tfoot tr td{display:table-cell;line-height:1.6} +h1,h2,h3,#toctitle,.sidebarblock>.content>.title,h4,h5,h6{line-height:1.2;word-spacing:-.05em} +h1 strong,h2 strong,h3 strong,#toctitle strong,.sidebarblock>.content>.title strong,h4 strong,h5 strong,h6 strong{font-weight:400} +.clearfix:before,.clearfix:after,.float-group:before,.float-group:after{content:" ";display:table} +.clearfix:after,.float-group:after{clear:both} +*:not(pre)>code{font-size:.9375em;font-style:normal!important;letter-spacing:0;padding:.1em .5ex;word-spacing:-.15em;background-color:#f7f7f8;-webkit-border-radius:4px;border-radius:4px;line-height:1.45;text-rendering:optimizeSpeed} +pre,pre>code{line-height:1.45;color:rgba(0,0,0,.9);font-family:"Droid Sans Mono","DejaVu Sans Mono",monospace;font-weight:400;text-rendering:optimizeSpeed} +.keyseq{color:rgba(51,51,51,.8)} +kbd{display:inline-block;color:rgba(0,0,0,.8);font-size:.75em;line-height:1.4;background-color:#f7f7f7;border:1px solid #ccc;-webkit-border-radius:3px;border-radius:3px;-webkit-box-shadow:0 1px 0 rgba(0,0,0,.2),0 0 0 .1em white inset;box-shadow:0 1px 0 rgba(0,0,0,.2),0 0 0 .1em #fff inset;margin:-.15em .15em 0 .15em;padding:.2em .6em .2em .5em;vertical-align:middle;white-space:nowrap} +.keyseq kbd:first-child{margin-left:0} +.keyseq kbd:last-child{margin-right:0} +.menuseq,.menu{color:rgba(0,0,0,.8)} +b.button:before,b.button:after{position:relative;top:-1px;font-weight:400} +b.button:before{content:"[";padding:0 3px 0 2px} +b.button:after{content:"]";padding:0 2px 0 3px} +p a>code:hover{color:rgba(0,0,0,.9)} +#header,#content,#footnotes,#footer{width:100%;margin-left:auto;margin-right:auto;margin-top:0;margin-bottom:0;max-width:62.5em;*zoom:1;position:relative;padding-left:.9375em;padding-right:.9375em} +#header:before,#header:after,#content:before,#content:after,#footnotes:before,#footnotes:after,#footer:before,#footer:after{content:" ";display:table} +#header:after,#content:after,#footnotes:after,#footer:after{clear:both} +#content{margin-top:1.25em} +#content:before{content:none} +#header>h1:first-child{color:rgba(0,0,0,.85);margin-top:2.25rem;margin-bottom:0} +#header>h1:first-child+#toc{margin-top:8px;border-top:1px solid #ddddd8} +#header>h1:only-child,body.toc2 #header>h1:nth-last-child(2){border-bottom:1px solid #ddddd8;padding-bottom:8px} +#header .details{border-bottom:1px solid #ddddd8;line-height:1.45;padding-top:.25em;padding-bottom:.25em;padding-left:.25em;color:rgba(0,0,0,.6);display:-ms-flexbox;display:-webkit-flex;display:flex;-ms-flex-flow:row wrap;-webkit-flex-flow:row wrap;flex-flow:row wrap} +#header .details span:first-child{margin-left:-.125em} +#header .details span.email a{color:rgba(0,0,0,.85)} +#header .details br{display:none} +#header .details br+span:before{content:"\00a0\2013\00a0"} +#header .details br+span.author:before{content:"\00a0\22c5\00a0";color:rgba(0,0,0,.85)} +#header .details br+span#revremark:before{content:"\00a0|\00a0"} +#header #revnumber{text-transform:capitalize} +#header #revnumber:after{content:"\00a0"} +#content>h1:first-child:not([class]){color:rgba(0,0,0,.85);border-bottom:1px solid #ddddd8;padding-bottom:8px;margin-top:0;padding-top:1rem;margin-bottom:1.25rem} +#toc{border-bottom:1px solid #efefed;padding-bottom:.5em} +#toc>ul{margin-left:.125em} +#toc ul.sectlevel0>li>a{font-style:italic} +#toc ul.sectlevel0 ul.sectlevel1{margin:.5em 0} +#toc ul{font-family:"Open Sans","DejaVu Sans",sans-serif;list-style-type:none} +#toc a{text-decoration:none} +#toc a:active{text-decoration:underline} +#toctitle{color:#7a2518;font-size:1.2em} +@media only screen and (min-width:768px){#toctitle{font-size:1.375em} +body.toc2{padding-left:15em;padding-right:0} +#toc.toc2{margin-top:0!important;background-color:#f8f8f7;position:fixed;width:15em;left:0;top:0;border-right:1px solid #efefed;border-top-width:0!important;border-bottom-width:0!important;z-index:1000;padding:1.25em 1em;height:100%;overflow:auto} +#toc.toc2 #toctitle{margin-top:0;font-size:1.2em} +#toc.toc2>ul{font-size:.9em;margin-bottom:0} +#toc.toc2 ul ul{margin-left:0;padding-left:1em} +#toc.toc2 ul.sectlevel0 ul.sectlevel1{padding-left:0;margin-top:.5em;margin-bottom:.5em} +body.toc2.toc-right{padding-left:0;padding-right:15em} +body.toc2.toc-right #toc.toc2{border-right-width:0;border-left:1px solid #efefed;left:auto;right:0}}@media only screen and (min-width:1280px){body.toc2{padding-left:20em;padding-right:0} +#toc.toc2{width:20em} +#toc.toc2 #toctitle{font-size:1.375em} +#toc.toc2>ul{font-size:.95em} +#toc.toc2 ul ul{padding-left:1.25em} +body.toc2.toc-right{padding-left:0;padding-right:20em}}#content #toc{border-style:solid;border-width:1px;border-color:#e0e0dc;margin-bottom:1.25em;padding:1.25em;background:#f8f8f7;-webkit-border-radius:4px;border-radius:4px} +#content #toc>:first-child{margin-top:0} +#content #toc>:last-child{margin-bottom:0} +#footer{max-width:100%;background-color:rgba(0,0,0,.8);padding:1.25em} +#footer-text{color:rgba(255,255,255,.8);line-height:1.44} +.sect1{padding-bottom:.625em} +@media only screen and (min-width:768px){.sect1{padding-bottom:1.25em}}.sect1+.sect1{border-top:1px solid #efefed} +#content h1>a.anchor,h2>a.anchor,h3>a.anchor,#toctitle>a.anchor,.sidebarblock>.content>.title>a.anchor,h4>a.anchor,h5>a.anchor,h6>a.anchor{position:absolute;z-index:1001;width:1.5ex;margin-left:-1.5ex;display:block;text-decoration:none!important;visibility:hidden;text-align:center;font-weight:400} +#content h1>a.anchor:before,h2>a.anchor:before,h3>a.anchor:before,#toctitle>a.anchor:before,.sidebarblock>.content>.title>a.anchor:before,h4>a.anchor:before,h5>a.anchor:before,h6>a.anchor:before{content:"\00A7";font-size:.85em;display:block;padding-top:.1em} +#content h1:hover>a.anchor,#content h1>a.anchor:hover,h2:hover>a.anchor,h2>a.anchor:hover,h3:hover>a.anchor,#toctitle:hover>a.anchor,.sidebarblock>.content>.title:hover>a.anchor,h3>a.anchor:hover,#toctitle>a.anchor:hover,.sidebarblock>.content>.title>a.anchor:hover,h4:hover>a.anchor,h4>a.anchor:hover,h5:hover>a.anchor,h5>a.anchor:hover,h6:hover>a.anchor,h6>a.anchor:hover{visibility:visible} +#content h1>a.link,h2>a.link,h3>a.link,#toctitle>a.link,.sidebarblock>.content>.title>a.link,h4>a.link,h5>a.link,h6>a.link{color:#ba3925;text-decoration:none} +#content h1>a.link:hover,h2>a.link:hover,h3>a.link:hover,#toctitle>a.link:hover,.sidebarblock>.content>.title>a.link:hover,h4>a.link:hover,h5>a.link:hover,h6>a.link:hover{color:#a53221} +.audioblock,.imageblock,.literalblock,.listingblock,.stemblock,.videoblock{margin-bottom:1.25em} +.admonitionblock td.content>.title,.audioblock>.title,.exampleblock>.title,.imageblock>.title,.listingblock>.title,.literalblock>.title,.stemblock>.title,.openblock>.title,.paragraph>.title,.quoteblock>.title,table.tableblock>.title,.verseblock>.title,.videoblock>.title,.dlist>.title,.olist>.title,.ulist>.title,.qlist>.title,.hdlist>.title{text-rendering:optimizeLegibility;text-align:left;font-family:"Noto Serif","DejaVu Serif",serif;font-size:1rem;font-style:italic} +table.tableblock>caption.title{white-space:nowrap;overflow:visible;max-width:0} +.paragraph.lead>p,#preamble>.sectionbody>.paragraph:first-of-type p{color:rgba(0,0,0,.85)} +table.tableblock #preamble>.sectionbody>.paragraph:first-of-type p{font-size:inherit} +.admonitionblock>table{border-collapse:separate;border:0;background:none;width:100%} +.admonitionblock>table td.icon{text-align:center;width:80px} +.admonitionblock>table td.icon img{max-width:none} +.admonitionblock>table td.icon .title{font-weight:bold;font-family:"Open Sans","DejaVu Sans",sans-serif;text-transform:uppercase} +.admonitionblock>table td.content{padding-left:1.125em;padding-right:1.25em;border-left:1px solid #ddddd8;color:rgba(0,0,0,.6)} +.admonitionblock>table td.content>:last-child>:last-child{margin-bottom:0} +.exampleblock>.content{border-style:solid;border-width:1px;border-color:#e6e6e6;margin-bottom:1.25em;padding:1.25em;background:#fff;-webkit-border-radius:4px;border-radius:4px} +.exampleblock>.content>:first-child{margin-top:0} +.exampleblock>.content>:last-child{margin-bottom:0} +.sidebarblock{border-style:solid;border-width:1px;border-color:#e0e0dc;margin-bottom:1.25em;padding:1.25em;background:#f8f8f7;-webkit-border-radius:4px;border-radius:4px} +.sidebarblock>:first-child{margin-top:0} +.sidebarblock>:last-child{margin-bottom:0} +.sidebarblock>.content>.title{color:#7a2518;margin-top:0;text-align:center} +.exampleblock>.content>:last-child>:last-child,.exampleblock>.content .olist>ol>li:last-child>:last-child,.exampleblock>.content .ulist>ul>li:last-child>:last-child,.exampleblock>.content .qlist>ol>li:last-child>:last-child,.sidebarblock>.content>:last-child>:last-child,.sidebarblock>.content .olist>ol>li:last-child>:last-child,.sidebarblock>.content .ulist>ul>li:last-child>:last-child,.sidebarblock>.content .qlist>ol>li:last-child>:last-child{margin-bottom:0} +.literalblock pre,.listingblock pre:not(.highlight),.listingblock pre[class="highlight"],.listingblock pre[class^="highlight "],.listingblock pre.CodeRay,.listingblock pre.prettyprint{background:#f7f7f8} +.sidebarblock .literalblock pre,.sidebarblock .listingblock pre:not(.highlight),.sidebarblock .listingblock pre[class="highlight"],.sidebarblock .listingblock pre[class^="highlight "],.sidebarblock .listingblock pre.CodeRay,.sidebarblock .listingblock pre.prettyprint{background:#f2f1f1} +.literalblock pre,.literalblock pre[class],.listingblock pre,.listingblock pre[class]{-webkit-border-radius:4px;border-radius:4px;word-wrap:break-word;padding:1em;font-size:.8125em} +.literalblock pre.nowrap,.literalblock pre[class].nowrap,.listingblock pre.nowrap,.listingblock pre[class].nowrap{overflow-x:auto;white-space:pre;word-wrap:normal} +@media only screen and (min-width:768px){.literalblock pre,.literalblock pre[class],.listingblock pre,.listingblock pre[class]{font-size:.90625em}}@media only screen and (min-width:1280px){.literalblock pre,.literalblock pre[class],.listingblock pre,.listingblock pre[class]{font-size:1em}}.literalblock.output pre{color:#f7f7f8;background-color:rgba(0,0,0,.9)} +.listingblock pre.highlightjs{padding:0} +.listingblock pre.highlightjs>code{padding:1em;-webkit-border-radius:4px;border-radius:4px} +.listingblock pre.prettyprint{border-width:0} +.listingblock>.content{position:relative} +.listingblock code[data-lang]:before{display:none;content:attr(data-lang);position:absolute;font-size:.75em;top:.425rem;right:.5rem;line-height:1;text-transform:uppercase;color:#999} +.listingblock:hover code[data-lang]:before{display:block} +.listingblock.terminal pre .command:before{content:attr(data-prompt);padding-right:.5em;color:#999} +.listingblock.terminal pre .command:not([data-prompt]):before{content:"$"} +table.pyhltable{border-collapse:separate;border:0;margin-bottom:0;background:none} +table.pyhltable td{vertical-align:top;padding-top:0;padding-bottom:0} +table.pyhltable td.code{padding-left:.75em;padding-right:0} +pre.pygments .lineno,table.pyhltable td:not(.code){color:#999;padding-left:0;padding-right:.5em;border-right:1px solid #ddddd8} +pre.pygments .lineno{display:inline-block;margin-right:.25em} +table.pyhltable .linenodiv{background:none!important;padding-right:0!important} +.quoteblock{margin:0 1em 1.25em 1.5em;display:table} +.quoteblock>.title{margin-left:-1.5em;margin-bottom:.75em} +.quoteblock blockquote,.quoteblock blockquote p{color:rgba(0,0,0,.85);font-size:1.15rem;line-height:1.75;word-spacing:.1em;letter-spacing:0;font-style:italic;text-align:justify} +.quoteblock blockquote{margin:0;padding:0;border:0} +.quoteblock blockquote:before{content:"\201c";float:left;font-size:2.75em;font-weight:bold;line-height:.6em;margin-left:-.6em;color:#7a2518;text-shadow:0 1px 2px rgba(0,0,0,.1)} +.quoteblock blockquote>.paragraph:last-child p{margin-bottom:0} +.quoteblock .attribution{margin-top:.5em;margin-right:.5ex;text-align:right} +.quoteblock .quoteblock{margin-left:0;margin-right:0;padding:.5em 0;border-left:3px solid rgba(0,0,0,.6)} +.quoteblock .quoteblock blockquote{padding:0 0 0 .75em} +.quoteblock .quoteblock blockquote:before{display:none} +.verseblock{margin:0 1em 1.25em 1em} +.verseblock pre{font-family:"Open Sans","DejaVu Sans",sans;font-size:1.15rem;color:rgba(0,0,0,.85);font-weight:300;text-rendering:optimizeLegibility} +.verseblock pre strong{font-weight:400} +.verseblock .attribution{margin-top:1.25rem;margin-left:.5ex} +.quoteblock .attribution,.verseblock .attribution{font-size:.9375em;line-height:1.45;font-style:italic} +.quoteblock .attribution br,.verseblock .attribution br{display:none} +.quoteblock .attribution cite,.verseblock .attribution cite{display:block;letter-spacing:-.05em;color:rgba(0,0,0,.6)} +.quoteblock.abstract{margin:0 0 1.25em 0;display:block} +.quoteblock.abstract blockquote,.quoteblock.abstract blockquote p{text-align:left;word-spacing:0} +.quoteblock.abstract blockquote:before,.quoteblock.abstract blockquote p:first-of-type:before{display:none} +table.tableblock{max-width:100%;border-collapse:separate} +table.tableblock td>.paragraph:last-child p>p:last-child,table.tableblock th>p:last-child,table.tableblock td>p:last-child{margin-bottom:0} +table.spread{width:100%} +table.tableblock,th.tableblock,td.tableblock{border:0 solid #dedede} +table.grid-all th.tableblock,table.grid-all td.tableblock{border-width:0 1px 1px 0} +table.grid-all tfoot>tr>th.tableblock,table.grid-all tfoot>tr>td.tableblock{border-width:1px 1px 0 0} +table.grid-cols th.tableblock,table.grid-cols td.tableblock{border-width:0 1px 0 0} +table.grid-all *>tr>.tableblock:last-child,table.grid-cols *>tr>.tableblock:last-child{border-right-width:0} +table.grid-rows th.tableblock,table.grid-rows td.tableblock{border-width:0 0 1px 0} +table.grid-all tbody>tr:last-child>th.tableblock,table.grid-all tbody>tr:last-child>td.tableblock,table.grid-all thead:last-child>tr>th.tableblock,table.grid-rows tbody>tr:last-child>th.tableblock,table.grid-rows tbody>tr:last-child>td.tableblock,table.grid-rows thead:last-child>tr>th.tableblock{border-bottom-width:0} +table.grid-rows tfoot>tr>th.tableblock,table.grid-rows tfoot>tr>td.tableblock{border-width:1px 0 0 0} +table.frame-all{border-width:1px} +table.frame-sides{border-width:0 1px} +table.frame-topbot{border-width:1px 0} +th.halign-left,td.halign-left{text-align:left} +th.halign-right,td.halign-right{text-align:right} +th.halign-center,td.halign-center{text-align:center} +th.valign-top,td.valign-top{vertical-align:top} +th.valign-bottom,td.valign-bottom{vertical-align:bottom} +th.valign-middle,td.valign-middle{vertical-align:middle} +table thead th,table tfoot th{font-weight:bold} +tbody tr th{display:table-cell;line-height:1.6;background:#f7f8f7} +tbody tr th,tbody tr th p,tfoot tr th,tfoot tr th p{color:rgba(0,0,0,.8);font-weight:bold} +p.tableblock>code:only-child{background:none;padding:0} +p.tableblock{font-size:1em} +td>div.verse{white-space:pre} +ol{margin-left:1.75em} +ul li ol{margin-left:1.5em} +dl dd{margin-left:1.125em} +dl dd:last-child,dl dd:last-child>:last-child{margin-bottom:0} +ol>li p,ul>li p,ul dd,ol dd,.olist .olist,.ulist .ulist,.ulist .olist,.olist .ulist{margin-bottom:.625em} +ul.unstyled,ol.unnumbered,ul.checklist,ul.none{list-style-type:none} +ul.unstyled,ol.unnumbered,ul.checklist{margin-left:.625em} +ul.checklist li>p:first-child>.fa-square-o:first-child,ul.checklist li>p:first-child>.fa-check-square-o:first-child{width:1em;font-size:.85em} +ul.checklist li>p:first-child>input[type="checkbox"]:first-child{width:1em;position:relative;top:1px} +ul.inline{margin:0 auto .625em auto;margin-left:-1.375em;margin-right:0;padding:0;list-style:none;overflow:hidden} +ul.inline>li{list-style:none;float:left;margin-left:1.375em;display:block} +ul.inline>li>*{display:block} +.unstyled dl dt{font-weight:400;font-style:normal} +ol.arabic{list-style-type:decimal} +ol.decimal{list-style-type:decimal-leading-zero} +ol.loweralpha{list-style-type:lower-alpha} +ol.upperalpha{list-style-type:upper-alpha} +ol.lowerroman{list-style-type:lower-roman} +ol.upperroman{list-style-type:upper-roman} +ol.lowergreek{list-style-type:lower-greek} +.hdlist>table,.colist>table{border:0;background:none} +.hdlist>table>tbody>tr,.colist>table>tbody>tr{background:none} +td.hdlist1{padding-right:.75em;font-weight:bold} +td.hdlist1,td.hdlist2{vertical-align:top} +.literalblock+.colist,.listingblock+.colist{margin-top:-.5em} +.colist>table tr>td:first-of-type{padding:0 .75em;line-height:1} +.colist>table tr>td:last-of-type{padding:.25em 0} +.thumb,.th{line-height:0;display:inline-block;border:solid 4px #fff;-webkit-box-shadow:0 0 0 1px #ddd;box-shadow:0 0 0 1px #ddd} +.imageblock.left,.imageblock[style*="float: left"]{margin:.25em .625em 1.25em 0} +.imageblock.right,.imageblock[style*="float: right"]{margin:.25em 0 1.25em .625em} +.imageblock>.title{margin-bottom:0} +.imageblock.thumb,.imageblock.th{border-width:6px} +.imageblock.thumb>.title,.imageblock.th>.title{padding:0 .125em} +.image.left,.image.right{margin-top:.25em;margin-bottom:.25em;display:inline-block;line-height:0} +.image.left{margin-right:.625em} +.image.right{margin-left:.625em} +a.image{text-decoration:none} +span.footnote,span.footnoteref{vertical-align:super;font-size:.875em} +span.footnote a,span.footnoteref a{text-decoration:none} +span.footnote a:active,span.footnoteref a:active{text-decoration:underline} +#footnotes{padding-top:.75em;padding-bottom:.75em;margin-bottom:.625em} +#footnotes hr{width:20%;min-width:6.25em;margin:-.25em 0 .75em 0;border-width:1px 0 0 0} +#footnotes .footnote{padding:0 .375em;line-height:1.3;font-size:.875em;margin-left:1.2em;text-indent:-1.2em;margin-bottom:.2em} +#footnotes .footnote a:first-of-type{font-weight:bold;text-decoration:none} +#footnotes .footnote:last-of-type{margin-bottom:0} +#content #footnotes{margin-top:-.625em;margin-bottom:0;padding:.75em 0} +.gist .file-data>table{border:0;background:#fff;width:100%;margin-bottom:0} +.gist .file-data>table td.line-data{width:99%} +div.unbreakable{page-break-inside:avoid} +.big{font-size:larger} +.small{font-size:smaller} +.underline{text-decoration:underline} +.overline{text-decoration:overline} +.line-through{text-decoration:line-through} +.aqua{color:#00bfbf} +.aqua-background{background-color:#00fafa} +.black{color:#000} +.black-background{background-color:#000} +.blue{color:#0000bf} +.blue-background{background-color:#0000fa} +.fuchsia{color:#bf00bf} +.fuchsia-background{background-color:#fa00fa} +.gray{color:#606060} +.gray-background{background-color:#7d7d7d} +.green{color:#006000} +.green-background{background-color:#007d00} +.lime{color:#00bf00} +.lime-background{background-color:#00fa00} +.maroon{color:#600000} +.maroon-background{background-color:#7d0000} +.navy{color:#000060} +.navy-background{background-color:#00007d} +.olive{color:#606000} +.olive-background{background-color:#7d7d00} +.purple{color:#600060} +.purple-background{background-color:#7d007d} +.red{color:#bf0000} +.red-background{background-color:#fa0000} +.silver{color:#909090} +.silver-background{background-color:#bcbcbc} +.teal{color:#006060} +.teal-background{background-color:#007d7d} +.white{color:#bfbfbf} +.white-background{background-color:#fafafa} +.yellow{color:#bfbf00} +.yellow-background{background-color:#fafa00} +span.icon>.fa{cursor:default} +.admonitionblock td.icon [class^="fa icon-"]{font-size:2.5em;text-shadow:1px 1px 2px rgba(0,0,0,.5);cursor:default} +.admonitionblock td.icon .icon-note:before{content:"\f05a";color:#19407c} +.admonitionblock td.icon .icon-tip:before{content:"\f0eb";text-shadow:1px 1px 2px rgba(155,155,0,.8);color:#111} +.admonitionblock td.icon .icon-warning:before{content:"\f071";color:#bf6900} +.admonitionblock td.icon .icon-caution:before{content:"\f06d";color:#bf3400} +.admonitionblock td.icon .icon-important:before{content:"\f06a";color:#bf0000} +.conum[data-value]{display:inline-block;color:#fff!important;background-color:rgba(0,0,0,.8);-webkit-border-radius:100px;border-radius:100px;text-align:center;font-size:.75em;width:1.67em;height:1.67em;line-height:1.67em;font-family:"Open Sans","DejaVu Sans",sans-serif;font-style:normal;font-weight:bold} +.conum[data-value] *{color:#fff!important} +.conum[data-value]+b{display:none} +.conum[data-value]:after{content:attr(data-value)} +pre .conum[data-value]{position:relative;top:-.125em} +b.conum *{color:inherit!important} +.conum:not([data-value]):empty{display:none} +h1,h2{letter-spacing:-.01em} +dt,th.tableblock,td.content{text-rendering:optimizeLegibility} +p,td.content{letter-spacing:-.01em} +p strong,td.content strong{letter-spacing:-.005em} +p,blockquote,dt,td.content{font-size:1.0625rem} +p{margin-bottom:1.25rem} +.sidebarblock p,.sidebarblock dt,.sidebarblock td.content,p.tableblock{font-size:1em} +.exampleblock>.content{background-color:#fffef7;border-color:#e0e0dc;-webkit-box-shadow:0 1px 4px #e0e0dc;box-shadow:0 1px 4px #e0e0dc} +.print-only{display:none!important} +@media print{@page{margin:1.25cm .75cm} +*{-webkit-box-shadow:none!important;box-shadow:none!important;text-shadow:none!important} +a{color:inherit!important;text-decoration:underline!important} +a.bare,a[href^="#"],a[href^="mailto:"]{text-decoration:none!important} +a[href^="http:"]:not(.bare):after,a[href^="https:"]:not(.bare):after{content:"(" attr(href) ")";display:inline-block;font-size:.875em;padding-left:.25em} +abbr[title]:after{content:" (" attr(title) ")"} +pre,blockquote,tr,img{page-break-inside:avoid} +thead{display:table-header-group} +img{max-width:100%!important} +p,blockquote,dt,td.content{font-size:1em;orphans:3;widows:3} +h2,h3,#toctitle,.sidebarblock>.content>.title{page-break-after:avoid} +#toc,.sidebarblock,.exampleblock>.content{background:none!important} +#toc{border-bottom:1px solid #ddddd8!important;padding-bottom:0!important} +.sect1{padding-bottom:0!important} +.sect1+.sect1{border:0!important} +#header>h1:first-child{margin-top:1.25rem} +body.book #header{text-align:center} +body.book #header>h1:first-child{border:0!important;margin:2.5em 0 1em 0} +body.book #header .details{border:0!important;display:block;padding:0!important} +body.book #header .details span:first-child{margin-left:0!important} +body.book #header .details br{display:block} +body.book #header .details br+span:before{content:none!important} +body.book #toc{border:0!important;text-align:left!important;padding:0!important;margin:0!important} +body.book #toc,body.book #preamble,body.book h1.sect0,body.book .sect1>h2{page-break-before:always} +.listingblock code[data-lang]:before{display:block} +#footer{background:none!important;padding:0 .9375em} +#footer-text{color:rgba(0,0,0,.6)!important;font-size:.9em} +.hide-on-print{display:none!important} +.print-only{display:block!important} +.hide-for-print{display:none!important} +.show-for-print{display:inherit!important}} +</style> +<style> +/* Stylesheet for CodeRay to match GitHub theme | MIT License | http://foundation.zurb.com */ +/*pre.CodeRay {background-color:#f7f7f8;}*/ +.CodeRay .line-numbers{border-right:1px solid #d8d8d8;padding:0 0.5em 0 .25em} +.CodeRay span.line-numbers{display:inline-block;margin-right:.5em;color:rgba(0,0,0,.3)} +.CodeRay .line-numbers strong{font-weight: normal} +table.CodeRay{border-collapse:separate;border-spacing:0;margin-bottom:0;border:0;background:none} +table.CodeRay td{vertical-align: top} +table.CodeRay td.line-numbers{text-align:right} +table.CodeRay td.line-numbers>pre{padding:0;color:rgba(0,0,0,.3)} +table.CodeRay td.code{padding:0 0 0 .5em} +table.CodeRay td.code>pre{padding:0} +.CodeRay .debug{color:#fff !important;background:#000080 !important} +.CodeRay .annotation{color:#007} +.CodeRay .attribute-name{color:#000080} +.CodeRay .attribute-value{color:#700} +.CodeRay .binary{color:#509} +.CodeRay .comment{color:#998;font-style:italic} +.CodeRay .char{color:#04d} +.CodeRay .char .content{color:#04d} +.CodeRay .char .delimiter{color:#039} +.CodeRay .class{color:#458;font-weight:bold} +.CodeRay .complex{color:#a08} +.CodeRay .constant,.CodeRay .predefined-constant{color:#008080} +.CodeRay .color{color:#099} +.CodeRay .class-variable{color:#369} +.CodeRay .decorator{color:#b0b} +.CodeRay .definition{color:#099} +.CodeRay .delimiter{color:#000} +.CodeRay .doc{color:#970} +.CodeRay .doctype{color:#34b} +.CodeRay .doc-string{color:#d42} +.CodeRay .escape{color:#666} +.CodeRay .entity{color:#800} +.CodeRay .error{color:#808} +.CodeRay .exception{color:inherit} +.CodeRay .filename{color:#099} +.CodeRay .function{color:#900;font-weight:bold} +.CodeRay .global-variable{color:#008080} +.CodeRay .hex{color:#058} +.CodeRay .integer,.CodeRay .float{color:#099} +.CodeRay .include{color:#555} +.CodeRay .inline{color:#00} +.CodeRay .inline .inline{background:#ccc} +.CodeRay .inline .inline .inline{background:#bbb} +.CodeRay .inline .inline-delimiter{color:#d14} +.CodeRay .inline-delimiter{color:#d14} +.CodeRay .important{color:#555;font-weight:bold} +.CodeRay .interpreted{color:#b2b} +.CodeRay .instance-variable{color:#008080} +.CodeRay .label{color:#970} +.CodeRay .local-variable{color:#963} +.CodeRay .octal{color:#40e} +.CodeRay .predefined{color:#369} +.CodeRay .preprocessor{color:#579} +.CodeRay .pseudo-class{color:#555} +.CodeRay .directive{font-weight:bold} +.CodeRay .type{font-weight:bold} +.CodeRay .predefined-type{color:inherit} +.CodeRay .reserved,.CodeRay .keyword {color:#000;font-weight:bold} +.CodeRay .key{color:#808} +.CodeRay .key .delimiter{color:#606} +.CodeRay .key .char{color:#80f} +.CodeRay .value{color:#088} +.CodeRay .regexp .delimiter{color:#808} +.CodeRay .regexp .content{color:#808} +.CodeRay .regexp .modifier{color:#808} +.CodeRay .regexp .char{color:#d14} +.CodeRay .regexp .function{color:#404;font-weight:bold} +.CodeRay .string{color:#d20} +.CodeRay .string .string .string{background:#ffd0d0} +.CodeRay .string .content{color:#d14} +.CodeRay .string .char{color:#d14} +.CodeRay .string .delimiter{color:#d14} +.CodeRay .shell{color:#d14} +.CodeRay .shell .delimiter{color:#d14} +.CodeRay .symbol{color:#990073} +.CodeRay .symbol .content{color:#a60} +.CodeRay .symbol .delimiter{color:#630} +.CodeRay .tag{color:#008080} +.CodeRay .tag-special{color:#d70} +.CodeRay .variable{color:#036} +.CodeRay .insert{background:#afa} +.CodeRay .delete{background:#faa} +.CodeRay .change{color:#aaf;background:#007} +.CodeRay .head{color:#f8f;background:#505} +.CodeRay .insert .insert{color:#080} +.CodeRay .delete .delete{color:#800} +.CodeRay .change .change{color:#66f} +.CodeRay .head .head{color:#f4f} +</style> +</head> +<body class="article"> +<div id="header"> +<div id="toc" class="toc"> +<div id="toctitle">Table of Contents</div> +<ul class="sectlevel2"> +<li><a href="#_docker">Docker</a></li> +</ul> +</div> +</div> +<div id="content"> +<div class="sect2"> +<h3 id="_docker">Docker</h3> +<div class="paragraph"> +<p>Apache Karaf provides Docker resources allowing you to easily create your own image and container.</p> +</div> +<div class="paragraph"> +<p>Official Karaf docker image are also available on Docker Hub.</p> +</div> +<div class="paragraph"> +<p>But, Apache Karaf also provides a docker feature allows you to:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>manipulate Docker containers directly from Apache Karaf</p> +</li> +<li> +<p>create a Docker container based on the current running Apache Karaf instance (named provisioning)</p> +</li> +</ul> +</div> +<div class="sect3"> +<h4 id="_docker_images">Docker images</h4> +<div class="paragraph"> +<p>You can find the docker resource at <a href="http://github.com/apache/karaf/assemblies/docker" class="bare">http://github.com/apache/karaf/assemblies/docker</a>.</p> +</div> +<div class="paragraph"> +<p>As prerequisites, you have:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>to install the most recent stable version of docker (<a href="https://docs.docker.com/installation/" class="bare">https://docs.docker.com/installation/</a>)</p> +</li> +<li> +<p>to install the most recent stable version of docker-compose (<a href="https://docs.docker.com/compose/install/" class="bare">https://docs.docker.com/compose/install/</a>)</p> +</li> +</ul> +</div> +<div class="sect4"> +<h5 id="_official_images">Official images</h5> +<div class="paragraph"> +<p>Apache Karaf official docker images are available on Docker HUB: <a href="https://hub.docker.com/_/karaf/" class="bare">https://hub.docker.com/_/karaf/</a></p> +</div> +<div class="paragraph"> +<p>You can directly pull the official image:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre>docker pull karaf</pre> +</div> +</div> +</div> +<div class="sect4"> +<h5 id="_build_your_own">Build your own</h5> +<div class="paragraph"> +<p>You can create your own docker image. The images are based on the official Java Alpine (OpenJDK 8) image. If you +want to build the Karaf image run:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre>sh build.sh</pre> +</div> +</div> +<div class="paragraph"> +<p>or</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre>docker build -t karaf .</pre> +</div> +</div> +<div class="paragraph"> +<p>If you want to build the container for a specific version of Karaf you can configure it with the KARAF_VERSION arg:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre>docker build --build-arg KARAF_VERSION=4.2.0 -t "karaf:4.2.0" karaf</pre> +</div> +</div> +</div> +<div class="sect4"> +<h5 id="_run">Run</h5> +<div class="ulist"> +<ul> +<li> +<p>Run Karaf in interactive mode</p> +</li> +</ul> +</div> +<div class="listingblock"> +<div class="content"> +<pre>docker-compose run karaf</pre> +</div> +</div> +<div class="ulist"> +<ul> +<li> +<p>Run Karaf as a daemon (without interaction)</p> +</li> +</ul> +</div> +<div class="listingblock"> +<div class="content"> +<pre>docker-compose up</pre> +</div> +</div> +<div class="ulist"> +<ul> +<li> +<p>Kill Karaf</p> +</li> +</ul> +</div> +<div class="listingblock"> +<div class="content"> +<pre>docker-compose kill</pre> +</div> +</div> +<div class="sect5"> +<h6 id="_ports">Ports</h6> +<div class="ulist"> +<ul> +<li> +<p>The Karaf SSH server is on 8101</p> +</li> +<li> +<p>The Karaf WebContainer is on 8888</p> +</li> +<li> +<p>The Karaf JMX MBean server is on 1099 (default, not exposed to host) and 44444 (default, not exposed to host)</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p>Edit the <code>docker-compose.yml</code> file to edit port settings.</p> +</div> +</div> +</div> +</div> +<div class="sect3"> +<h4 id="_docker_feature">Docker feature</h4> +<div class="paragraph"> +<p>Docker is an optional feature from the Karaf Enterprise features repository.</p> +</div> +<div class="paragraph"> +<p>It means that you have to install the <code>docker</code> feature first:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre>karaf@root()> feature:install docker</pre> +</div> +</div> +<div class="paragraph"> +<p>The Karaf Docker feature uses the Docker HTTP layer to communicate with the Docker backend. It could be on the same local +machine where Apache Karaf instance is running or a remote Docker machine.</p> +</div> +<div class="paragraph"> +<p>The location of the Docker backend (URL) can be specified as an option to the <code>docker:*</code> commands. By default, Karaf Docker +feature uses <code><a href="http://localhost:2375" class="bare">http://localhost:2375</a></code>. Please, take a look on the Docker documentation how to enable remote API using HTTP +for Docker daemon. As short notice, you just have to enable <code>tcp</code> transport connector enabled for the docker daemon. +You have to do it using the <code>-H</code> option on <code>dockerd</code>:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre>/usr/bin/dockerd -H fd:// -H tcp://localhost:2375</pre> +</div> +</div> +<div class="paragraph"> +<p>Apache Karaf Docker feature exposes <code>DockerService</code> OSGi service that you can use programmatically (the <code>dockerClient:*</code> commands +and the <code>DockerMBean</code> use the <code>DockerService</code> service).</p> +</div> +</div> +<div class="sect3"> +<h4 id="_system_wide_information">System-wide information</h4> +<div class="paragraph"> +<p>The <code>docker:info</code> command provides some details about the docker backend:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre>karaf@root()> docker:info +Containers: 0 +Debug: false +Driver: overlay2 +ExecutionDriver: null +IPv4Forwarding: true +Images: 1 +IndexServerAddress: https://index.docker.io/v1/ +InitPath: null +InitSha1: null +KernelVersion: 4.15.0-29-generic +MemoryLimit: true +NEventsListener: false +NFd: 20 +NGoroutines: 34 +SwapLimit: false</pre> +</div> +</div> +</div> +<div class="sect3"> +<h4 id="_show_the_docker_version_information">Show the Docker version information</h4> +<div class="paragraph"> +<p>The <code>docker:version</code> command provides details about the docker version:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre>karaf@root()> docker:version +Version: 17.12.1-ce +Os: linux +Kernel version: 4.15.0-29-generic +Go version: go1.10.1 +Git commit: 7390fc6 +Arch: amd64 +API version: 1.35 +Build time: 2018-02-28T17:46:05.000000000+00:00 +Experimental: null</pre> +</div> +</div> +</div> +<div class="sect3"> +<h4 id="_search_image">Search image</h4> +<div class="paragraph"> +<p>The <code>docker:search</code> command (or <code>search()</code> operation on the <code>DockerMBean</code>) searches for a image on Docker HUB:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre>karaf@root()> docker:search java +Name â Description â Automated â Official â Star Count +ââââââââââââââââââââââââââââââââââââââââââââ¼âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ¼ââââââââââââ¼âââââââ� �âââ¼âââââââââââ +java â Java is a concurrent, class-based, and object-oriented programming language. â false â true â 1774 +anapsix/alpine-java â Oracle Java 8 (and 7) with GLIBC 2.23 over AlpineLinux â true â false â 332 +node â Node.js is a JavaScript-based platform for server-side and networking applications. â false â true â 5893 +tomcat â Apache Tomcat is an open source implementation of the Java Servlet and JavaServer Pages technologies â false â true â 1950 +openjdk â OpenJDK is an open-source implementation of the Java Platform, Standard Edition â false â true â 1097 +frekele/java â docker run --rm --name java frekele/java â true â false â 10 +ghost â Ghost is a free and open source blogging platform written in JavaScript â false â true â 799 +appuio/s2i-maven-java â S2I Builder with Maven and Java â true â false â 1 +zabbix/zabbix-java-gateway â Zabbix Java Gateway â true â false â 13 +jetty â Jetty provides a Web server and javax.servlet container. â false â true â 260 +fabric8/s2i-java â S2I Builder Image for plain Java applications â false â false â 5 +appuio/s2i-gradle-java â S2I Builder with Gradle and Java â true â false â 1 +cloudbees/jnlp-slave-with-java-build-tools â Extends cloudbees/java-build-tools docker image to make it a JNLP slave â true â false â 18 +blacklabelops/java â Java Base Images. â true â false â 8 +groovy â Apache Groovy is a multi-faceted language for the Java platform. â false â true â 47 +lwieske/java-8 â Oracle Java 8 Container - Full + Slim - Based off Alpine + CentOS (8u00 - 8u172) â true â false â 39 +davidcaste/alpine-java-unlimited-jce â Oracle Java 8 (and 7) with GLIBC 2.21 over AlpineLinux with unlimited JCE patch applied â true â false â 11 +cfje/java-test-applications â Java Test Applications CI Image â false â false â 0 +thingswise/java-docker â Java + dcd â true â false â 0 +rightctrl/java â Oracle Java â true â false â 2 +cfje/java-resource â Java Concourse Resource â false â false â 0 +cfje/java-buildpack â Java Buildpack CI Image â false â false â 0 +tomee â Apache TomEE is an all-Apache Java EE certified stack where Apache Tomcat is top dog. â false â true â 53 +couchdb â CouchDB is a database that uses JSON for documents, an HTTP API, & JavaScript/declarative indexing. â false â true â 218 +dwolla/java â Dwollaâs custom Java image â true â false â 1</pre> +</div> +</div> +</div> +<div class="sect3"> +<h4 id="_pull_image">Pull image</h4> +<div class="paragraph"> +<p>The <code>docker:pull</code> command (or <code>pull()</code> operation on the <code>DockerMBean</code>) pull a image from Docker HUB:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre>karaf@root()> docker:pull -v java:8-jre-alpine +{"status":"Pulling from library/java","id":"latest"} +{"status":"Pulling fs layer","progressDetail":{},"id":"5040bd298390"} +{"status":"Pulling fs layer","progressDetail":{},"id":"fce5728aad85"} +{"status":"Pulling fs layer","progressDetail":{},"id":"76610ec20bf5"} +{"status":"Pulling fs layer","progressDetail":{},"id":"60170fec2151"} +{"status":"Pulling fs layer","progressDetail":{},"id":"e98f73de8f0d"} +{"status":"Pulling fs layer","progressDetail":{},"id":"11f7af24ed9c"} +{"status":"Pulling fs layer","progressDetail":{},"id":"49e2d6393f32"} +{"status":"Pulling fs layer","progressDetail":{},"id":"bb9cdec9c7f3"} +{"status":"Waiting","progressDetail":{},"id":"11f7af24ed9c"} +{"status":"Waiting","progressDetail":{},"id":"49e2d6393f32"} +{"status":"Waiting","progressDetail":{},"id":"bb9cdec9c7f3"} +{"status":"Waiting","progressDetail":{},"id":"60170fec2151"} +{"status":"Waiting","progressDetail":{},"id":"e98f73de8f0d"}</pre> +</div> +</div> +</div> +<div class="sect3"> +<h4 id="_listing_images">Listing images</h4> +<div class="paragraph"> +<p>The <code>docker:images</code> command (or <code>images()</code> operation on the <code>DockerMBean</code>) lists the available images on docker:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre>karaf@root()> docker:images +Id â RepoTags â Created â Labels â Size â Virtual Size +âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ¼ââââââââââââââââââââââ¼âââââââââââââ¼âââââââââ¼ââââââââââââ¼âââââââââââââ +sha256:fdc893b19a147681ee764b2edab6c494d60fe99d83b14b8794bbcbc040ec7aa7 â [java:8-jre-alpine] â 1488578492 â {} â 107854045 â 107854045 +sha256:d23bdf5b1b1b1afce5f1d0fd33e7ed8afbc084b594b9ccf742a5b27080d8a4a8 â [java:latest] â 1484614374 â {} â 643195347 â 643195347</pre> +</div> +</div> +</div> +<div class="sect3"> +<h4 id="_remove_image">Remove image</h4> +<div class="paragraph"> +<p>The <code>docker:rmi</code> command (or <code>rmi()</code> operation on the <code>DockerMBean</code>) removes an image from docker:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre>karaf@root()> docker:rmi --force sha256:d23bdf5b1b1b1afce5f1d0fd33e7ed8afbc084b594b9ccf742a5b27080d8a4a8</pre> +</div> +</div> +</div> +<div class="sect3"> +<h4 id="_image_history">Image history</h4> +<div class="paragraph"> +<p>The <code>docker:history</code> command displays the complete history for a given image:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre>karaf@root()> docker:history sha256:fdc893b19a147681ee764b2edab6c494d60fe99d83b14b8794bbcbc040ec7aa7 +ID â Created â Created By â Tags â Size +âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ¼âââââââââââââ¼ââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ� �ââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ¼âââââââ¼âââââââââââââââââââ â +sha256:fdc893b19a147681ee764b2edab6c494d60fe99d83b14b8794bbcbc040ec7aa7 â 1488578492 â /bin/sh -c set -x && apk add --no-cache openjdk8-jre="$JAVA_ALPINE_VERSION" && [ "$JAVA_HOME" = "$(docker-java-home)" ] â â [java:8-jre-alpine] +<missing> â 1488578488 â /bin/sh -c #(nop) ENV JAVA_ALPINE_VERSION=8.111.14-r0 â â +<missing> â 1488578488 â /bin/sh -c #(nop) ENV JAVA_VERSION=8u111 â â +<missing> â 1488578487 â /bin/sh -c #(nop) ENV PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/lib/jvm/java-1.8-openjdk/jre/bin:/usr/lib/jvm/java-1.8-openjdk/bin â â +<missing> â 1488578487 â /bin/sh -c #(nop) ENV JAVA_HOME=/usr/lib/jvm/java-1.8-openjdk/jre â â +<missing> â 1488578458 â /bin/sh -c { echo '#!/bin/sh'; echo 'set -e'; echo; echo 'dirname "$(dirname "$(readlink -f "$(which javac || which java)")")"'; } > /usr/local/bin/docker-java-home && chmod +x /usr/local/bin/docker-java-home â â +<missing> â 1488578457 â /bin/sh -c #(nop) ENV LANG=C.UTF-8 â â +<missing> â 1488573141 â /bin/sh -c #(nop) ADD file:3df55c321c1c8d73f22bc69240c0764290d6cb293da46ba8f94ed25473fb5853 in / â â</pre> +</div> +</div> +</div> +<div class="sect3"> +<h4 id="_pushing_and_tagging_image">Pushing and tagging image</h4> +<div class="paragraph"> +<p>The <code>docker:push</code> command allows you to push an image on a given repository.</p> +</div> +<div class="paragraph"> +<p>The <code>docker:tag</code> command create a new tag for a given image.</p> +</div> +</div> +<div class="sect3"> +<h4 id="_create_container">Create container</h4> +<div class="paragraph"> +<p>The Karaf Docker feature can create a Docker container based on a given image.</p> +</div> +<div class="paragraph"> +<p>You can use either the <code>docker:create</code> shell command or the <code>create()</code> operation on the JMX <code>DockerMBean</code>.</p> +</div> +<div class="paragraph"> +<p>For instance, here’s an example of the <code>docker:bootstrap</code> to create a Docker container based on <code>elasticsearch</code> instance:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre>karaf@root()> docker:create --image fdc893b19a147681ee764b2edab6c494d60fe99d83b14b8794bbcbc040ec7aa7 --cmd /bin/bash test</pre> +</div> +</div> +</div> +<div class="sect3"> +<h4 id="_listing_containers">Listing containers</h4> +<div class="paragraph"> +<p>You can list the containers:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre>karaf@root()> docker:ps -a +Id â Names â Command â Created â Image â Image ID â Status â State â Ports â Size â Size Root +ââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ¼ââââââââââ¼ââââââââââââ¼âââââââââââââ¼âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ� �â¼ââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ¼ââââââââââ¼ââââââââââ¼ââââââââ¼âââââââ¼ââââââââââ +92f8b280a7fa69c9ff673ed9678b7040a56c16c9c4aa403498a538cf0f501e9e â [/test] â /bin/bash â 1532809485 â fdc893b19a147681ee764b2edab6c494d60fe99d83b14b8794bbcbc040ec7aa7 â sha256:fdc893b19a147681ee764b2edab6c494d60fe99d83b14b8794bbcbc040ec7aa7 â Created â created â â 0 â 0</pre> +</div> +</div> +<div class="paragraph"> +<p>You can also use the containers attribute on the <code>DockerMBean</code> JMX MBean or the <code>containers()</code> method on the <code>DockerService</code> service.</p> +</div> +</div> +<div class="sect3"> +<h4 id="_provision_docker_container">Provision Docker container</h4> +<div class="paragraph"> +<p>Provisioning is a specific way of creating container based on the current running Karaf instance: it creates a Docker container using the current running Apache Karaf instance <code>karaf.base</code>.</p> +</div> +<div class="paragraph"> +<p>You can then reuse this container to create a Docker image and to duplicate the container on another Docker backend via dockerhub.</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre>karaf@root()> docker:provision my-karaf</pre> +</div> +</div> +<div class="paragraph"> +<p>You can also use the <code>provision()</code> method on the <code>DockerMBean</code> JMX MBean or the <code>DockerService</code> service.</p> +</div> +</div> +<div class="sect3"> +<h4 id="_start_container">Start container</h4> +<div class="paragraph"> +<p>You can start a container using the <code>docker:start</code> command:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre>karaf@root()> docker:start my-container</pre> +</div> +</div> +<div class="paragraph"> +<p>You can also use the <code>start()</code> method on the <code>DockerMBean</code> JMX MBean or the <code>DockerService</code> service.</p> +</div> +</div> +<div class="sect3"> +<h4 id="_stop_container">Stop container</h4> +<div class="paragraph"> +<p>You can stop a container using the <code>docker:stop</code> command:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre>karaf@root()> docker:stop my-container</pre> +</div> +</div> +<div class="paragraph"> +<p>You can also use the <code>stop()</code> method on the <code>DockerMBean</code> JMX MBean or the <code>DockerService</code> service.</p> +</div> +</div> +<div class="sect3"> +<h4 id="_restart_container">Restart container</h4> +<div class="paragraph"> +<p>You can restart a container using the <code>docker:restart</code> command:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre>karaf@root()> docker:restart my-container</pre> +</div> +</div> +</div> +<div class="sect3"> +<h4 id="_delete_container">Delete container</h4> +<div class="paragraph"> +<p>You can delete an existing Docker container using the <code>docker:rm</code> commmand:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre>karaf@root()> docker:rm my-container</pre> +</div> +</div> +<div class="paragraph"> +<p>You can also use the <code>rm()</code> method on the <code>DockerMBean</code> JMX MBean or the <code>DockerService</code> service.</p> +</div> +</div> +<div class="sect3"> +<h4 id="_pause_container">Pause container</h4> +<div class="paragraph"> +<p>The <code>docker:pause</code> command pauses all processes within one or more containers:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre>karaf@root()> docker:pause my-container</pre> +</div> +</div> +</div> +<div class="sect3"> +<h4 id="_unpause_container">Unpause container</h4> +<div class="paragraph"> +<p>The <code>docker:unpause</code> command unpauses all processes within one or more containers:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre>karaf@root()> docker:unpause my-container</pre> +</div> +</div> +</div> +<div class="sect3"> +<h4 id="_kill_container">Kill container</h4> +<div class="paragraph"> +<p>The <code>docker:kill</code> command kills a running container:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre>karaf@root()> docker:kill my-container</pre> +</div> +</div> +</div> +<div class="sect3"> +<h4 id="_rename_container">Rename container</h4> +<div class="paragraph"> +<p>The <code>docker:rename</code> command renames an existing container:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre>karaf@root()> docker:rename my-container new-container</pre> +</div> +</div> +</div> +<div class="sect3"> +<h4 id="_logs">Logs</h4> +<div class="paragraph"> +<p>The <code>docker:logs</code> command displays the log on an existing container:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre>karaf@root()> docker:logs --timestamps --details --stdout --stderr my-container</pre> +</div> +</div> +</div> +<div class="sect3"> +<h4 id="_top">Top</h4> +<div class="paragraph"> +<p>The <code>docker:top</code> command displays the current running processes in an existing container:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre>karaf@root()> docker:top my-container</pre> +</div> +</div> +</div> +</div> +</div> +<div id="footer"> +<div id="footer-text"> +Last updated 2018-08-17 21:42:57 +02:00 +</div> +</div> +</body> +</html> \ No newline at end of file Modified: karaf/site/production/manual/latest/ejb.html URL: http://svn.apache.org/viewvc/karaf/site/production/manual/latest/ejb.html?rev=1839907&r1=1839906&r2=1839907&view=diff ============================================================================== --- karaf/site/production/manual/latest/ejb.html (original) +++ karaf/site/production/manual/latest/ejb.html Mon Sep 3 06:10:48 2018 @@ -615,7 +615,7 @@ openejb-soap | 4.5.2 | </div> <div id="footer"> <div id="footer-text"> -Last updated 2017-07-26 16:36:29 +02:00 +Last updated 2018-05-18 16:02:21 +02:00 </div> </div> </body> Modified: karaf/site/production/manual/latest/extending.html URL: http://svn.apache.org/viewvc/karaf/site/production/manual/latest/extending.html?rev=1839907&r1=1839906&r2=1839907&view=diff ============================================================================== --- karaf/site/production/manual/latest/extending.html (original) +++ karaf/site/production/manual/latest/extending.html Mon Sep 3 06:10:48 2018 @@ -516,408 +516,9 @@ table.CodeRay td.code>pre{padding:0} <p>Apache Karaf is a very flexible container that you can extend very easily.</p> </div> <div class="sect3"> -<h4 id="_console">Console</h4> +<h4 id="_shell_commands">Shell commands</h4> <div class="paragraph"> -<p>In this section, you will see how to extend the console by adding your own command.</p> -</div> -<div class="paragraph"> -<p>We will leverage Apache Maven to create and build the OSGi bundle. -This OSGi bundle will use Blueprint. We don’t cover the details of OSGi bundle and Blueprint, see the specific -sections for details.</p> -</div> -<div class="sect4"> -<h5 id="_create_the_maven_project">Create the Maven project</h5> -<div class="paragraph"> -<p>To create the Maven project, we can:</p> -</div> -<div class="ulist"> -<ul> -<li> -<p>use a Maven archetype</p> -</li> -<li> -<p>create by hand</p> -</li> -</ul> -</div> -<div class="sect5"> -<h6 id="_using_archetype">Using archetype</h6> -<div class="paragraph"> -<p>The Maven Quickstart archetype can create an empty Maven project where you can put your project definition.</p> -</div> -<div class="paragraph"> -<p>You can directly use:</p> -</div> -<div class="listingblock"> -<div class="content"> -<pre>mvn archetype:generate \ - -DarchetypeArtifactId=maven-archetype-quickstart \ - -DgroupId=org.apache.karaf.shell.samples \ - -DartifactId=shell-sample-commands \ - -Dversion=1.0-SNAPSHOT</pre> -</div> -</div> -<div class="paragraph"> -<p>It results to a ready to use project, including a <code>pom.xml</code>.</p> -</div> -<div class="paragraph"> -<p>You can also use Maven archetype in interactive mode. You will have to answer to some questions used to generate -the project with the <code>pom.xml</code>:</p> -</div> -<div class="listingblock"> -<div class="content"> -<pre>mvn archetype:generate -Choose a number: (1/2/3/4/5/6/7/.../32/33/34/35/36) 15: : 15 -Define value for groupId: : org.apache.karaf.shell.samples -Define value for artifactId: : shell-sample-commands -Define value for version: 1.0-SNAPSHOT: : -Define value for package: : org.apache.karaf.shell.samples</pre> -</div> -</div> -</div> -</div> -<div class="sect4"> -<h5 id="_by_hand">By hand</h5> -<div class="paragraph"> -<p>Alternatively, you can simply create the directory <code>shell-sample-commands</code> and create the <code>pom.xml</code> file inside it:</p> -</div> -<div class="listingblock"> -<div class="content"> -<pre><project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> - - <modelVersion>4.0.0</modelVersion> - - <groupId>org.apache.karaf.shell.samples</groupId> - <artifactId>shell-sample-commands<artifactId> - <packaging>bundle</packaging> - <version>1.0-SNAPSHOT</version> - <name>shell-sample-commmands</name> - - - <dependencies> - <dependency> - <groupId>org.apache.karaf.shell</groupId> - <artifactId>org.apache.karaf.shell.core</artifactId> - <version>${project.version}</version> - </dependency> - <dependency> - <groupId>junit</groupId> - <artifactId>junit</artifactId> - <version>3.8.1</version> - <scope>test</scope> - </dependency> - </dependencies> - - <build> - <plugins> - <plugin> - <groupId>org.apache.felix</groupId> - <artifactId>maven-bundle-plugin</artifactId> - <version>${felix.plugin.version}</version> - <configuration> - <instructions> - <Import-Package> - org.apache.felix.service.command, - org.apache.karaf.shell.commands, - org.apache.karaf.shell.console, - * - </Import-Package> - </instructions> - </configuration> - </plugin> - </plugins> - </build> - -</project></pre> -</div> -</div> -</div> -<div class="sect4"> -<h5 id="_configuring_for_java_8">Configuring for Java 8</h5> -<div class="paragraph"> -<p>We are using annotations to define commands, so we need to ensure Maven will actually use JDK 1.6 or 1.7 to compile the jar. -Just add the following snippet after the <code>dependencies</code> section.</p> -</div> -<div class="listingblock"> -<div class="content"> -<pre><build> - <plugins> - <plugin> - <groupId>org.apache.maven.plugins</groupId> - <artifactId>maven-compiler-plugin</artifactId> - <configuration> - <target>1.8</target> - <source>1.8</source> - </configuration> - </plugin> - </plugins> -</build></pre> -</div> -</div> -</div> -<div class="sect4"> -<h5 id="_loading_the_project_in_your_ide">Loading the project in your IDE</h5> -<div class="paragraph"> -<p>We can use Maven to generate the needed files for your IDE:</p> -</div> -<div class="paragraph"> -<p>Inside the project, run the following command</p> -</div> -<div class="listingblock"> -<div class="content"> -<pre>mvn eclipse:eclipse</pre> -</div> -</div> -<div class="paragraph"> -<p>or</p> -</div> -<div class="listingblock"> -<div class="content"> -<pre>mvn idea:idea</pre> -</div> -</div> -<div class="paragraph"> -<p>The project files for your IDE should now be created. Just open the IDE and load the project.</p> -</div> -</div> -<div class="sect4"> -<h5 id="_creating_a_basic_command_class">Creating a basic command class</h5> -<div class="paragraph"> -<p>We can now create the command class <code>HelloShellCommand.java</code></p> -</div> -<div class="listingblock"> -<div class="content"> -<pre>package org.apache.karaf.shell.samples; - -import org.apache.karaf.shell.api.action.Action; -import org.apache.karaf.shell.api.action.Command; -import org.apache.karaf.shell.api.action.lifecycle.Service; - -@Command(scope = "test", name = "hello", description="Says hello") -@Service -public class HelloShellCommand implements Action { - - @Override - public Object execute() throws Exception { - System.out.println("Executing Hello command"); - return null; - } -}</pre> -</div> -</div> -</div> -<div class="sect4"> -<h5 id="_manifest">Manifest</h5> -<div class="paragraph"> -<p>In order for Karaf to find your command, you need to add the <code>Karaf-Commands=*</code> manifest header.</p> -</div> -<div class="paragraph"> -<p>This is usually done by modifying the maven bundle plugin configuration</p> -</div> -<div class="listingblock"> -<div class="content"> -<pre><plugin> - <groupId>org.apache.felix</groupId> - <artifactId>maven-bundle-plugin</artifactId> - <configuration> - <instructions> - <Karaf-Commands>*</Karaf-Commands> - </instructions> - </configuration> -</plugin></pre> -</div> -</div> -</div> -<div class="sect4"> -<h5 id="_compile">Compile</h5> -<div class="paragraph"> -<p>Let’s try to build the jar. Remove the test classes and sample classes if you used the artifact, then from the command line, run:</p> -</div> -<div class="listingblock"> -<div class="content"> -<pre>mvn install</pre> -</div> -</div> -<div class="paragraph"> -<p>The end of the maven output should look like:</p> -</div> -<div class="listingblock"> -<div class="content"> -<pre>[INFO] ------------------------------------------------------------------------ -[INFO] BUILD SUCCESSFUL -[INFO] ------------------------------------------------------------------------</pre> -</div> -</div> -</div> -<div class="sect4"> -<h5 id="_test">Test</h5> -<div class="paragraph"> -<p>Launch Apache Karaf and install your bundle:</p> -</div> -<div class="listingblock"> -<div class="content"> -<pre>karaf@root()> bundle:install -s mvn:org.apache.karaf.shell.samples/shell-sample-commands/1.0-SNAPSHOT</pre> -</div> -</div> -<div class="paragraph"> -<p>Let’s try running the command:</p> -</div> -<div class="listingblock"> -<div class="content"> -<pre>karaf@root()> test:hello -Executing Hello command</pre> -</div> -</div> -</div> -<div class="sect4"> -<h5 id="_command_completer">Command completer</h5> -<div class="paragraph"> -<p>A completer allows you to automatically complete a command argument using <tab>. A completer is simply a bean which is -injected to a command.</p> -</div> -<div class="paragraph"> -<p>Of course to be able to complete it, the command should require an argument.</p> -</div> -</div> -<div class="sect4"> -<h5 id="_command_argument">Command argument</h5> -<div class="paragraph"> -<p>We add an argument to the HelloCommand:</p> -</div> -<div class="listingblock"> -<div class="content"> -<pre>package org.apache.karaf.shell.samples; - -import org.apache.karaf.shell.api.action.Action; -import org.apache.karaf.shell.api.action.Argument; -import org.apache.karaf.shell.api.action.Command; -import org.apache.karaf.shell.api.action.Completion; -import org.apache.karaf.shell.api.action.lifecycle.Service; - -@Command(scope = "test", name = "hello", description="Says hello") -@Service -public class HelloShellCommand implements Action { - - @Argument(index = 0, name = "name", description = "The name that sends the greet.", required = true, multiValued = false) - @Completion(SimpleNameCompleter.class) - String name = null; - - @Override - public Object execute() throws Exception { - System.out.println("Hello " + name); - return null; - } -}</pre> -</div> -</div> -</div> -<div class="sect4"> -<h5 id="_completer_bean">Completer bean</h5> -<div class="paragraph"> -<p>A completer is a bean which implements the Completer interface:</p> -</div> -<div class="listingblock"> -<div class="content"> -<pre>package org.apache.karaf.shell.samples; - -import org.apache.karaf.shell.api.action.lifecycle.Service; -import org.apache.karaf.shell.api.console.CommandLine; -import org.apache.karaf.shell.api.console.Completer; -import org.apache.karaf.shell.api.console.Session; -import org.apache.karaf.shell.support.completers.StringsCompleter; - -/** - * <p> - * A very simple completer. - * </p> - */ -@Service -public class SimpleNameCompleter implements Completer { - - public int complete(Session session, CommandLine commandLine, List<String> candidates) { - StringsCompleter delegate = new StringsCompleter(); - delegate.getStrings().add("Mike"); - delegate.getStrings().add("Eric"); - delegate.getStrings().add("Jenny"); - return delegate.complete(session, commandLine, candidates); - } - -}</pre> -</div> -</div> -</div> -<div class="sect4"> -<h5 id="_completers_for_option_values">Completers for option values</h5> -<div class="paragraph"> -<p>Quite often your commands will not have just arguments, but also options. You can provide completers for option values. -The snippet below shows the HelloShellCommand with an option to specify what the greet message will be.</p> -</div> -<div class="listingblock"> -<div class="content"> -<pre>package org.apache.karaf.shell.samples; - -import org.apache.karaf.shell.api.action.Action; -import org.apache.karaf.shell.api.action.Argument; -import org.apache.karaf.shell.api.action.Command; -import org.apache.karaf.shell.api.action.Completion; -import org.apache.karaf.shell.api.action.Option; -import org.apache.karaf.shell.api.action.lifecycle.Service; - -@Command(scope = "test", name = "hello", description="Says hello") -@Service -public class HelloShellCommand implements Action { - - @Argument(index = 0, name = "name", description = "The name that sends the greet.", required = true, multiValued = false) - @Completion(SimpleNameCompleter.class) - String name = null; - - @Option(name = "-g", aliases = "--greet", description = "The configuration pid", required = false, multiValued = false) - @Completion(GreetCompleter.class) - String greet = "Hello; - - @Override - public Object execute() throws Exception { - System.out.println(greet + " " + name); - return null; - } -}</pre> -</div> -</div> -</div> -<div class="sect4"> -<h5 id="_completers_with_state">Completers with state</h5> -<div class="paragraph"> -<p>Some times we want to tune the behavior of the completer depending on the commands already executed, in the current shell -or even the rest of the arguments that have been already passed to the command. Such example is the config:set-property -command which will provide auto completion for only for the properties of the pid specified by a previously issued config:edit -command or by the option --pid.</p> -</div> -<div class="paragraph"> -<p>The Session object provides map like methods for storing key/value pairs and can be used to put/get the state. -The pre-parsed CommandLine objects allows you to check the previous arguments and options on the command line and to fine tune -the behavior of the Completer. -Those two objects are given to the Completer when calling the <code>complete</code> method.</p> -</div> -</div> -<div class="sect4"> -<h5 id="_test_2">Test</h5> -<div class="paragraph"> -<p>Launch a Karaf instance and run the following command to install the newly created bundle:</p> -</div> -<div class="listingblock"> -<div class="content"> -<pre>karaf@root()> bundle:install -s mvn:org.apache.karaf.shell.samples/shell-sample-commands/1.0-SNAPSHOT</pre> -</div> -</div> -<div class="paragraph"> -<p>Let’s try running the command:</p> -</div> -<div class="listingblock"> -<div class="content"> -<pre>karaf@root> test:hello <tab> - one two three</pre> -</div> -</div> +<p>See [examples/karaf-command-example] to add your own shell commands.</p> </div> </div> <div class="sect3"> @@ -926,14 +527,14 @@ Those two objects are given to the Compl <p>You can also extend the Apache Karaf WebConsole by providing and installing a webconsole plugin.</p> </div> <div class="paragraph"> -<p>A plugin is an OSGi bundle that register a Servlet as an OSGi service with some webconsole properties.</p> +<p>A plugin is an OSGi bundle that register a Servlet as an OSGi service with webconsole properties.</p> </div> </div> </div> </div> <div id="footer"> <div id="footer-text"> -Last updated 2017-11-22 15:12:31 +01:00 +Last updated 2018-08-17 21:42:57 +02:00 </div> </div> </body> Modified: karaf/site/production/manual/latest/failover.html URL: http://svn.apache.org/viewvc/karaf/site/production/manual/latest/failover.html?rev=1839907&r1=1839906&r2=1839907&view=diff ============================================================================== --- karaf/site/production/manual/latest/failover.html (original) +++ karaf/site/production/manual/latest/failover.html Mon Sep 3 06:10:48 2018 @@ -908,7 +908,7 @@ to update the slave configuration to bin </div> <div id="footer"> <div id="footer-text"> -Last updated 2017-07-26 16:36:29 +02:00 +Last updated 2018-05-18 16:02:21 +02:00 </div> </div> </body> Modified: karaf/site/production/manual/latest/github-contributions.html URL: http://svn.apache.org/viewvc/karaf/site/production/manual/latest/github-contributions.html?rev=1839907&r1=1839906&r2=1839907&view=diff ============================================================================== --- karaf/site/production/manual/latest/github-contributions.html (original) +++ karaf/site/production/manual/latest/github-contributions.html Mon Sep 3 06:10:48 2018 @@ -616,7 +616,7 @@ git format-patch archon/trunk</pre> </div> <div id="footer"> <div id="footer-text"> -Last updated 2017-07-26 16:36:29 +02:00 +Last updated 2018-05-18 16:02:21 +02:00 </div> </div> </body> Modified: karaf/site/production/manual/latest/http.html URL: http://svn.apache.org/viewvc/karaf/site/production/manual/latest/http.html?rev=1839907&r1=1839906&r2=1839907&view=diff ============================================================================== --- karaf/site/production/manual/latest/http.html (original) +++ karaf/site/production/manual/latest/http.html Mon Sep 3 06:10:48 2018 @@ -596,7 +596,7 @@ So it is much more convenient than regis </div> <div id="footer"> <div id="footer-text"> -Last updated 2017-07-26 16:36:29 +02:00 +Last updated 2018-05-18 16:02:21 +02:00 </div> </div> </body>
