<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>Git | Luis Cacho</title><link>https://luiscachog.io/tag/git/</link><atom:link href="https://luiscachog.io/tag/git/index.xml" rel="self" type="application/rss+xml"/><description>Git</description><generator>Wowchemy (https://wowchemy.com)</generator><language>en-us</language><lastBuildDate>Thu, 22 Jun 2023 00:00:00 +0000</lastBuildDate><image><url>https://luiscachog.io/media/icon_hu4fa4dbbaafd6f1b45a88958b9b4a0dd0_11007_512x512_fill_lanczos_center_3.png</url><title>Git</title><link>https://luiscachog.io/tag/git/</link></image><item><title>Update all the git submodules</title><link>https://luiscachog.io/garden/update-git-submodules/</link><pubDate>Thu, 22 Jun 2023 00:00:00 +0000</pubDate><guid>https://luiscachog.io/garden/update-git-submodules/</guid><description>&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">&lt;span class="c1"># Example command&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">git submodule foreach git pull
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;p>&lt;strong>References:&lt;/strong>&lt;/p>
&lt;ul>
&lt;li>&lt;sup id="fnref:1">&lt;a href="#fn:1" class="footnote-ref" role="doc-noteref">1&lt;/a>&lt;/sup>How to update submodules in git?&lt;/li>
&lt;/ul>
&lt;div class="footnotes" role="doc-endnotes">
&lt;hr>
&lt;ol>
&lt;li id="fn:1">
&lt;p>&lt;a href="https://stackoverflow.com/questions/33714063/how-to-update-submodules-in-git" target="_blank" rel="noopener">https://stackoverflow.com/questions/33714063/how-to-update-submodules-in-git&lt;/a>&amp;#160;&lt;a href="#fnref:1" class="footnote-backref" role="doc-backlink">&amp;#x21a9;&amp;#xfe0e;&lt;/a>&lt;/p>
&lt;/li>
&lt;/ol>
&lt;/div></description></item><item><title>Change author email in commit</title><link>https://luiscachog.io/garden/change-author-in-commit/</link><pubDate>Tue, 30 Nov 2021 00:00:00 +0000</pubDate><guid>https://luiscachog.io/garden/change-author-in-commit/</guid><description>&lt;p>Just works in the last commit&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">git commit --amend --author&lt;span class="o">=&lt;/span>&lt;span class="s2">&amp;#34;John Doe &amp;lt;john@doe.org&amp;gt;&amp;#34;&lt;/span>
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;p>&lt;strong>References:&lt;/strong>&lt;/p>
&lt;ul>
&lt;li>&lt;sup id="fnref:1">&lt;a href="#fn:1" class="footnote-ref" role="doc-noteref">1&lt;/a>&lt;/sup>How can I change the author (name / email) of a commit?&lt;/li>
&lt;/ul>
&lt;div class="footnotes" role="doc-endnotes">
&lt;hr>
&lt;ol>
&lt;li id="fn:1">
&lt;p>&lt;a href="https://www.git-tower.com/learn/git/faq/change-author-name-email" target="_blank" rel="noopener">https://www.git-tower.com/learn/git/faq/change-author-name-email&lt;/a>&amp;#160;&lt;a href="#fnref:1" class="footnote-backref" role="doc-backlink">&amp;#x21a9;&amp;#xfe0e;&lt;/a>&lt;/p>
&lt;/li>
&lt;/ol>
&lt;/div></description></item><item><title>Update local branch with upstream content</title><link>https://luiscachog.io/garden/update-local-branch-upstream/</link><pubDate>Wed, 11 Aug 2021 00:00:00 +0000</pubDate><guid>https://luiscachog.io/garden/update-local-branch-upstream/</guid><description>&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">&lt;span class="nb">cd&lt;/span> &lt;span class="nv">$working_dir&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">git fetch upstream
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">git checkout main
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">git rebase upstream/main
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div></description></item><item><title>Gitkraken Ambassador</title><link>https://luiscachog.io/gitkraken-ambassador/</link><pubDate>Mon, 09 Aug 2021 00:00:00 +0000</pubDate><guid>https://luiscachog.io/gitkraken-ambassador/</guid><description>&lt;details class="toc-inpage d-print-none " open>
&lt;summary class="font-weight-bold">Table of Contents&lt;/summary>
&lt;nav id="TableOfContents">
&lt;ul>
&lt;li>&lt;a href="#gitkraken-ambassador">GitKraken Ambassador&lt;/a>&lt;/li>
&lt;li>&lt;a href="#what-is-gitkraken">What is GitKraken?&lt;/a>
&lt;ul>
&lt;li>&lt;a href="#what-i-like">What I like&lt;/a>&lt;/li>
&lt;li>&lt;a href="#what-i-dont-like">What I don&amp;rsquo;t like&lt;/a>&lt;/li>
&lt;/ul>
&lt;/li>
&lt;li>&lt;a href="#wrapping-up">Wrapping Up&lt;/a>&lt;/li>
&lt;/ul>
&lt;/nav>
&lt;/details>
&lt;p>Hello again,&lt;/p>
&lt;p>I&amp;rsquo;m happy to announce that I&amp;rsquo;m participating in the &lt;strong>&lt;a href="https://www.gitkraken.com/ambassador" target="_blank" rel="noopener">GitKraken Ambassador program&lt;/a>&lt;/strong>.&lt;/p>
&lt;p>For me, it is a joy that the GitKraken team trusts me for this work.&lt;/p>
&lt;h2 id="gitkraken-ambassador">GitKraken Ambassador&lt;/h2>
&lt;p>I have been a &lt;a href="https://www.gitkraken.com/" target="_blank" rel="noopener">GitKraken&lt;/a> advocate even before they launched this program.
I always recommend it to all my friends and colleges because I have loved it since the first time I used it, back in 2018.&lt;/p>
&lt;p>Now, I&amp;rsquo;m being named Ambassador to actively promote it in community events, meetings with other Ambassadors, beta-testing of new functionality, etc.
Also, I will create some post showing/explaining how I use GitKraken in my job, that is A LOT.&lt;/p>
&lt;p>For joining the GitKraken Ambassador team, I received:&lt;/p>
&lt;ul>
&lt;li>Free GitKraken Pro Account ($79 value)&lt;/li>
&lt;li>Ambassador Starter Kit: Stickers, Swag &amp;amp; Resources&lt;/li>
&lt;li>Access to a private Ambassador Slack Channel&lt;/li>
&lt;li>Exclusive Ambassador Content &amp;amp; early access to beta features&lt;/li>
&lt;li>Access to GitKraken Product Team to share feedback and get exclusive insight&lt;/li>
&lt;/ul>
&lt;figure id="figure-gitkraken-kit">
&lt;div class="d-flex justify-content-center">
&lt;div class="w-100" >&lt;img alt="GitKraken Ambassador Starter Kit" srcset="
/media/posts/gitkraken-ambassador/gitkraken-ambassador-kit_huf7d90c66abed3660249e00acc8390404_323786_54c4e42921fd0867b5ce5477527bdfd0.webp 400w,
/media/posts/gitkraken-ambassador/gitkraken-ambassador-kit_huf7d90c66abed3660249e00acc8390404_323786_5078962bd1bd3456a4ecea9235ef4152.webp 760w,
/media/posts/gitkraken-ambassador/gitkraken-ambassador-kit_huf7d90c66abed3660249e00acc8390404_323786_1200x1200_fit_q90_h2_lanczos.webp 1200w"
src="https://luiscachog.io/media/posts/gitkraken-ambassador/gitkraken-ambassador-kit_huf7d90c66abed3660249e00acc8390404_323786_54c4e42921fd0867b5ce5477527bdfd0.webp"
width="760"
height="570"
loading="lazy" data-zoomable class=" img-light" />&lt;/div>
&lt;/div>&lt;figcaption>
GitKraken Ambassador Starter Kit
&lt;/figcaption>&lt;/figure>
&lt;h2 id="what-is-gitkraken">What is GitKraken?&lt;/h2>
&lt;p>Let&amp;rsquo;s start defining what is GitKraken for me and how I use it.&lt;/p>
&lt;p>GitKraken provides me the easiest, safest, and most powerful way to interact/work with:&lt;/p>
&lt;ul>
&lt;li>&lt;a href="https://git-scm.com/" target="_blank" rel="noopener">Git&lt;/a>&lt;/li>
&lt;li>&lt;a href="https://github.com/" target="_blank" rel="noopener">GitHub&lt;/a>&lt;/li>
&lt;li>&lt;a href="https://gitlab.com/" target="_blank" rel="noopener">GitLab&lt;/a>,&lt;/li>
&lt;li>and more Source Code Management (VCS)&lt;/li>
&lt;/ul>
&lt;p>becoming the best complement to manage your source code.&lt;/p>
&lt;p>As an Infrastructure consultant, I contribute to Ansible playbooks/roles, Terraform provisioning, Kubernetes/OpenShift manifests, Documentation, and more, but my profile is not necessary as a &lt;code>Developer&lt;/code>.
I consider myself more a &lt;code>DevOps Practitioner&lt;/code> where, from my perspective, I write code for Infrastructure in a declarative way; that being said, my workflow is slightly different from a &lt;code>Developer&lt;/code>.&lt;/p>
&lt;p>That means I usually do all my code in VSCode. Sometimes I commit using the terminal and sometimes using the Kraken.
Once I&amp;rsquo;m ready to push my changes, I switch to GitKraken to review that I&amp;rsquo;m in the correct branch/tree/tag, if there are no conflicts, etc. and,
then I do push/merge it in a collaborative way and keeping the order that the project requires and that I want to show.
That personal workflow always helped me to avoid mistakes in my job.&lt;/p>
&lt;h3 id="what-i-like">What I like&lt;/h3>
&lt;ul>
&lt;li>
&lt;p>GitKraken has a pretty neat interface where it is easy to find all I need for that git workflow.&lt;/p>
&lt;figure id="figure-gitkraken-interface">
&lt;div class="d-flex justify-content-center">
&lt;div class="w-100" >&lt;img alt="GitKraken Interface" srcset="
/media/posts/gitkraken-ambassador/gitkraken-interface_hu540504d15ba8624c470cb1d3dc6ef633_30261_a9041ad587dd4e9887de8fd5f1daf3d4.webp 400w,
/media/posts/gitkraken-ambassador/gitkraken-interface_hu540504d15ba8624c470cb1d3dc6ef633_30261_0d06feefb3a90a18f4585d537f58fc5d.webp 760w,
/media/posts/gitkraken-ambassador/gitkraken-interface_hu540504d15ba8624c470cb1d3dc6ef633_30261_1200x1200_fit_q90_h2_lanczos_3.webp 1200w"
src="https://luiscachog.io/media/posts/gitkraken-ambassador/gitkraken-interface_hu540504d15ba8624c470cb1d3dc6ef633_30261_a9041ad587dd4e9887de8fd5f1daf3d4.webp"
width="760"
height="350"
loading="lazy" data-zoomable class=" img-dark" />&lt;/div>
&lt;/div>&lt;figcaption>
GitKraken Interface
&lt;/figcaption>&lt;/figure>
&lt;/li>
&lt;li>
&lt;p>Multiple git profiles support&lt;/p>
&lt;figure id="figure-gitkraken-profile-1">
&lt;div class="d-flex justify-content-center">
&lt;div class="w-100" >&lt;img alt="GitKraken Profiles 1/2" srcset="
/media/posts/gitkraken-ambassador/gitkraken-profiles_hu68cfcafd6d62723417a88074591da48e_119220_529569022b0d68eee4517c6404a87e4b.webp 400w,
/media/posts/gitkraken-ambassador/gitkraken-profiles_hu68cfcafd6d62723417a88074591da48e_119220_7cc430f8e189bb6efdd2b2cbb9169eb2.webp 760w,
/media/posts/gitkraken-ambassador/gitkraken-profiles_hu68cfcafd6d62723417a88074591da48e_119220_1200x1200_fit_q90_h2_lanczos_3.webp 1200w"
src="https://luiscachog.io/media/posts/gitkraken-ambassador/gitkraken-profiles_hu68cfcafd6d62723417a88074591da48e_119220_529569022b0d68eee4517c6404a87e4b.webp"
width="760"
height="428"
loading="lazy" data-zoomable class=" img-dark" />&lt;/div>
&lt;/div>&lt;figcaption>
GitKraken Profiles 1/2
&lt;/figcaption>&lt;/figure>
&lt;figure id="figure-gitkraken-profile-2">
&lt;div class="d-flex justify-content-center">
&lt;div class="w-100" >&lt;img alt="GitKraken Profiles 2/2"
src="https://luiscachog.io/media/posts/gitkraken-ambassador/gitkraken-profiles.gif"
loading="lazy" data-zoomable class=" img-light" />&lt;/div>
&lt;/div>&lt;figcaption>
GitKraken Profiles 2/2
&lt;/figcaption>&lt;/figure>
&lt;/li>
&lt;li>
&lt;p>Easy drag and drop Pull-Request/Merge-Request integration&lt;/p>
&lt;figure id="figure-gitkraken-pr">
&lt;div class="d-flex justify-content-center">
&lt;div class="w-100" >&lt;img alt="GitKraken Drag &amp;amp; Drop Pull Request"
src="https://luiscachog.io/media/posts/gitkraken-ambassador/gitkraken-pull-request.gif"
loading="lazy" data-zoomable class=" img-light" />&lt;/div>
&lt;/div>&lt;figcaption>
GitKraken Drag &amp;amp; Drop Pull Request
&lt;/figcaption>&lt;/figure>
&lt;/li>
&lt;/ul>
&lt;h3 id="what-i-dont-like">What I don&amp;rsquo;t like&lt;/h3>
&lt;ul>
&lt;li>Sometimes, when my computer has high resources usage, like when I&amp;rsquo;m running some containers/virtual machines, GitKraken produces a slow down for a bit like some other GUI&amp;rsquo;s.&lt;/li>
&lt;/ul>
&lt;h2 id="wrapping-up">Wrapping Up&lt;/h2>
&lt;p>So, starting today, I&amp;rsquo;m going to generate content related to Git/Gitkraken, and to achieve this, I will write about how I integrate GitKraken into my daily work.&lt;/p>
&lt;p>If you want to start using GitKraken, you can &lt;a href="https://www.gitkraken.com/download" target="_blank" rel="noopener">download the Kraken&lt;/a> and try it by yourself!
Furthermore, I recommend to use &lt;a href="https://www.gitkraken.com/invite/kkvpJVykg" target="_blank" rel="noopener">my referral code&lt;/a> when you sign in.&lt;/p>
&lt;p>Happy coding!&lt;/p></description></item><item><title>Delete git submodule</title><link>https://luiscachog.io/garden/delete-git-submodule/</link><pubDate>Sun, 08 Aug 2021 00:00:00 +0000</pubDate><guid>https://luiscachog.io/garden/delete-git-submodule/</guid><description>&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">git submodule deinit -f -- &amp;lt;name_of_submodule&amp;gt;
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">rm -rf .git/modules/&amp;lt;name_of_submodule&amp;gt;
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="c1"># Note: The &amp;lt;name_of_submodule&amp;gt; shouldn&amp;#39;t have the trailing slash&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">git rm -f &amp;lt;name_of_submodule&amp;gt;
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">git commit -m &lt;span class="s2">&amp;#34;Deleted submodule xyz&amp;#34;&lt;/span>
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;p>Example&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">git submodule deinit -f -- a/submodule
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">rm -rf .git/modules/a/submodule
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">git rm -f a/submodule
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">git commit -m &lt;span class="s2">&amp;#34;Deleted submodule a/submodule&amp;#34;&lt;/span>
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;p>&lt;strong>References:&lt;/strong>&lt;/p>
&lt;ul>
&lt;li>&lt;sup id="fnref:1">&lt;a href="#fn:1" class="footnote-ref" role="doc-noteref">1&lt;/a>&lt;/sup>How do I remove a submodule?&lt;/li>
&lt;/ul>
&lt;div class="footnotes" role="doc-endnotes">
&lt;hr>
&lt;ol>
&lt;li id="fn:1">
&lt;p>&lt;a href="https://stackoverflow.com/questions/1260748/how-do-i-remove-a-submodule#1260982" target="_blank" rel="noopener">https://stackoverflow.com/questions/1260748/how-do-i-remove-a-submodule#1260982&lt;/a>&amp;#160;&lt;a href="#fnref:1" class="footnote-backref" role="doc-backlink">&amp;#x21a9;&amp;#xfe0e;&lt;/a>&lt;/p>
&lt;/li>
&lt;/ol>
&lt;/div></description></item><item><title>Set a hugo blog on Kubernetes</title><link>https://luiscachog.io/blog-hugo-docker-k8s-quay/</link><pubDate>Mon, 18 Jun 2018 00:00:00 +0000</pubDate><guid>https://luiscachog.io/blog-hugo-docker-k8s-quay/</guid><description>&lt;details class="toc-inpage d-print-none " open>
&lt;summary class="font-weight-bold">Table of Contents&lt;/summary>
&lt;nav id="TableOfContents">
&lt;ul>
&lt;li>&lt;a href="#overview">Overview&lt;/a>
&lt;ul>
&lt;li>&lt;a href="#architecture">Architecture&lt;/a>&lt;/li>
&lt;/ul>
&lt;/li>
&lt;li>&lt;a href="#containerized">Containerized&lt;/a>
&lt;ul>
&lt;li>&lt;a href="#dockerfile">Dockerfile&lt;/a>&lt;/li>
&lt;/ul>
&lt;/li>
&lt;/ul>
&lt;/nav>
&lt;/details>
&lt;h2 id="overview">Overview&lt;/h2>
&lt;p>Since last year I been trying to become an SRE (Site Reliability Engineer), so I been involved with some emerging technologies, like ansible, docker and on this time with kubernetes.&lt;/p>
&lt;p>This time, I will try to explain how I containerized my blog using:&lt;/p>
&lt;ul>
&lt;li>&lt;a href="https://gohugo.io/" target="_blank" rel="noopener">Hugo&lt;/a>&lt;/li>
&lt;li>&lt;a href="https://www.docker.com/" target="_blank" rel="noopener">Docker&lt;/a>&lt;/li>
&lt;li>&lt;a href="https://kubernetes.io/" target="_blank" rel="noopener">Kubernetes&lt;/a>&lt;/li>
&lt;li>&lt;a href="https://quay.io/" target="_blank" rel="noopener">Quay&lt;/a>&lt;/li>
&lt;li>&lt;a href="https://github.com" target="_blank" rel="noopener">Git&lt;/a>&lt;/li>
&lt;/ul>
&lt;h3 id="architecture">Architecture&lt;/h3>
&lt;p>So, I take some ideas from &lt;a href="https://www.civo.com/learn/using-civo-k3s-service-to-host-your-blog-in-hugo-using-github-actions" target="_blank" rel="noopener">here&lt;/a> and I modify them and adapt the architecture described to my options.&lt;/p>
&lt;p>The principal changes that I made are:&lt;/p>
&lt;ul>
&lt;li>My Kubernetes cluster is running on 2 cloud server on Rackspace Public Cloud&lt;/li>
&lt;li>The container registry that I&amp;rsquo;m using is Quay&lt;/li>
&lt;li>Rackspace Public Cloud does not support a Kubernetes LoadBalancer service automatically,
so I simulate that behavior adding a Cloud Load Balancer manually after the Kubernetes service provide me the port.&lt;/li>
&lt;/ul>
&lt;figure id="figure-blog-hugo-architecture">
&lt;div class="d-flex justify-content-center">
&lt;div class="w-100" >&lt;img alt="Architecture" srcset="
/media/posts/blog-hugo-docker-k8s-quay/architecture_hu8b96b5b52b85b051d387a2869880f3ab_113861_90038fb3c81eb33b4ff587d44167dbfc.webp 400w,
/media/posts/blog-hugo-docker-k8s-quay/architecture_hu8b96b5b52b85b051d387a2869880f3ab_113861_422b03095e3febbbd91dbb98eee4f1ca.webp 760w,
/media/posts/blog-hugo-docker-k8s-quay/architecture_hu8b96b5b52b85b051d387a2869880f3ab_113861_1200x1200_fit_q90_h2_lanczos_3.webp 1200w"
src="https://luiscachog.io/media/posts/blog-hugo-docker-k8s-quay/architecture_hu8b96b5b52b85b051d387a2869880f3ab_113861_90038fb3c81eb33b4ff587d44167dbfc.webp"
width="760"
height="486"
loading="lazy" data-zoomable />&lt;/div>
&lt;/div>&lt;figcaption>
Architecture
&lt;/figcaption>&lt;/figure>
&lt;h2 id="containerized">Containerized&lt;/h2>
&lt;p>I use &lt;a href="https://gohugo.io/" target="_blank" rel="noopener">Hugo&lt;/a> to deploy my blog, I used to do it as mentioned on &lt;a href="https://luiscachog.io/deployment-hugo-site-git-hooks/" target="_blank" rel="noopener">this&lt;/a> previous post (In Spanish).&lt;/p>
&lt;p>Now, as a part of containerize the blog it make sense to me to create two stages as described &lt;a href="https://www.civo.com/learn/using-civo-k3s-service-to-host-your-blog-in-hugo-using-github-actions" target="_blank" rel="noopener">here&lt;/a>:&lt;/p>
&lt;ul>
&lt;li>The first stage is a defined build environment containing all required build tools (hugo, pygments) and the source of the website (Git repository).&lt;/li>
&lt;li>The second stage is the build artifact (HTML and assets), from the first stage and a webserver to serve the artifact over HTTP.&lt;/li>
&lt;/ul>
&lt;h3 id="dockerfile">Dockerfile&lt;/h3>
&lt;p>Here is the Dockerfile that containerize the blog:&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">FROM ubuntu:latest as STAGEONE
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="c1"># install hugo&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">ENV &lt;span class="nv">HUGO_VERSION&lt;/span>&lt;span class="o">=&lt;/span>0.41
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">ADD https://github.com/gohugoio/hugo/releases/download/v&lt;span class="si">${&lt;/span>&lt;span class="nv">HUGO_VERSION&lt;/span>&lt;span class="si">}&lt;/span>/hugo_&lt;span class="si">${&lt;/span>&lt;span class="nv">HUGO_VERSION&lt;/span>&lt;span class="si">}&lt;/span>_Linux-64bit.tar.gz /tmp/
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">RUN tar -xf /tmp/hugo_&lt;span class="si">${&lt;/span>&lt;span class="nv">HUGO_VERSION&lt;/span>&lt;span class="si">}&lt;/span>_Linux-64bit.tar.gz -C /usr/local/bin/
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="c1"># install syntax highlighting&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">RUN apt-get update
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">RUN apt-get install -y python3-pygments
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="c1"># build site&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">COPY &lt;span class="nb">source&lt;/span> /source
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">RUN hugo --source&lt;span class="o">=&lt;/span>/source/ --destination&lt;span class="o">=&lt;/span>/public/
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">FROM nginx:stable-alpine
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">RUN apk --update add curl bash
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">RUN rm /etc/nginx/conf.d/default.conf
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">COPY modules/nginx.luiscachog.io.conf /etc/nginx/conf.d/luiscachog.io.conf
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">COPY --from&lt;span class="o">=&lt;/span>STAGEONE /public/ /usr/share/nginx/html/
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">EXPOSE &lt;span class="m">80&lt;/span> &lt;span class="m">443&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">MAINTAINER Luis Cacho &amp;lt;luiscachog@gmail.com&amp;gt;
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;h4 id="first-stage">First Stage&lt;/h4>
&lt;ul>
&lt;li>Fetch the lastest Ubuntu image and name as &lt;strong>STAGEONE&lt;/strong>&lt;/li>
&lt;li>Install the last available &lt;strong>hugo&lt;/strong> version from source.&lt;/li>
&lt;li>Install &lt;strong>pygments&lt;/strong> library to use it for highlighting.&lt;/li>
&lt;li>Build the site with &lt;strong>hugo&lt;/strong> and the output is set on &lt;strong>/public&lt;/strong> as a build artifact.&lt;/li>
&lt;/ul>
&lt;h4 id="second-stage">Second Stage&lt;/h4>
&lt;ul>
&lt;li>Fetch the lastest stable nginx alpine image.&lt;/li>
&lt;li>Update the image and install some utilities.&lt;/li>
&lt;li>Delete the &lt;strong>default&lt;/strong> nginx configuration file.&lt;/li>
&lt;li>Copy the configuration files needed from the repository root directory.&lt;/li>
&lt;li>Copy the build artifact &lt;strong>/public&lt;/strong> from the previous stage (&lt;strong>STAGEONE&lt;/strong>)&lt;/li>
&lt;/ul></description></item><item><title>My First Contribution to OpenStack project</title><link>https://luiscachog.io/my-first-contribution-to-openstack/</link><pubDate>Thu, 15 Mar 2018 00:00:00 +0000</pubDate><guid>https://luiscachog.io/my-first-contribution-to-openstack/</guid><description>&lt;p>I been working since last year using &lt;a href="https://www.ansible.com/" target="_blank" rel="noopener">Ansible&lt;/a> for fun and to trying to get prepared to become a DevOps, so I found an excelent OpenStack project called &lt;a href="https://github.com/openstack/ara" target="_blank" rel="noopener">ARA Records Ansible&lt;/a>.&lt;/p>
&lt;figure id="figure-ansible-logo">
&lt;div class="d-flex justify-content-center">
&lt;div class="w-100" >&lt;img alt="Ansible Logo" srcset="
/media/posts/my-first-contribution-to-openstack/Ansible-Logo_hub884469535c087589ce6d86f0418926d_8020_e8654a6c9737fb6cf9a9d6a845d8f829.webp 400w,
/media/posts/my-first-contribution-to-openstack/Ansible-Logo_hub884469535c087589ce6d86f0418926d_8020_34c2626c3a799dab177de63acc44cc35.webp 760w,
/media/posts/my-first-contribution-to-openstack/Ansible-Logo_hub884469535c087589ce6d86f0418926d_8020_1200x1200_fit_q90_h2_lanczos_3.webp 1200w"
src="https://luiscachog.io/media/posts/my-first-contribution-to-openstack/Ansible-Logo_hub884469535c087589ce6d86f0418926d_8020_e8654a6c9737fb6cf9a9d6a845d8f829.webp"
width="760"
height="760"
loading="lazy" data-zoomable />&lt;/div>
&lt;/div>&lt;figcaption>
Ansible Logo
&lt;/figcaption>&lt;/figure>
&lt;figure id="figure-ara-logo">
&lt;div class="d-flex justify-content-center">
&lt;div class="w-100" >&lt;img alt="ARA Logo" srcset="
/media/posts/my-first-contribution-to-openstack/ARA-Logo_hu17e4256629a5c6ba45baa8e753225cf6_37253_b02dfcb5baf4780ab653a7834a9e4c0a.webp 400w,
/media/posts/my-first-contribution-to-openstack/ARA-Logo_hu17e4256629a5c6ba45baa8e753225cf6_37253_303171032104318092c9459674593e15.webp 760w,
/media/posts/my-first-contribution-to-openstack/ARA-Logo_hu17e4256629a5c6ba45baa8e753225cf6_37253_1200x1200_fit_q90_h2_lanczos_3.webp 1200w"
src="https://luiscachog.io/media/posts/my-first-contribution-to-openstack/ARA-Logo_hu17e4256629a5c6ba45baa8e753225cf6_37253_b02dfcb5baf4780ab653a7834a9e4c0a.webp"
width="760"
height="556"
loading="lazy" data-zoomable />&lt;/div>
&lt;/div>&lt;figcaption>
ARA Logo
&lt;/figcaption>&lt;/figure>
&lt;p>Basically it is a project from the OpenStack community that makes it easier to understand and troubleshoot your Ansible roles and playbooks.
If you want more information, please refer to the &lt;a href="http://ara.readthedocs.io/en/latest/" target="_blank" rel="noopener">Documentation Page&lt;/a>.&lt;/p>
&lt;p>Anyhow, I just found a little bug on the Ansible Role to install ARA &lt;a href="https://opendev.org/recordsansible/ansible-role-ara" target="_blank" rel="noopener">ansible-role-ara&lt;/a> on Debian based distros and just send the patch to fix it.&lt;/p>
&lt;p>Here is the link to my &lt;a href="https://opendev.org/recordsansible/ansible-role-ara/commit/3e194e169070213c0bcfd007c97222ce318c6556" target="_blank" rel="noopener">contribution&lt;/a>.&lt;/p>
&lt;p>And, as I am proud of my first commit on a big project here is the screenshot too:&lt;/p>
&lt;figure id="figure-first-openstack-contrib">
&lt;div class="d-flex justify-content-center">
&lt;div class="w-100" >&lt;img alt="My First OpenStack Contribution" srcset="
/media/posts/my-first-contribution-to-openstack/OpenStack-Contribution_hue50cae8c9a4f3ce2cc82fba8663fd3f2_54865_0af5728d9b6f3d8f558a246cb97b792f.webp 400w,
/media/posts/my-first-contribution-to-openstack/OpenStack-Contribution_hue50cae8c9a4f3ce2cc82fba8663fd3f2_54865_6aa243ac01ede5843567d9273ddd14a0.webp 760w,
/media/posts/my-first-contribution-to-openstack/OpenStack-Contribution_hue50cae8c9a4f3ce2cc82fba8663fd3f2_54865_1200x1200_fit_q90_h2_lanczos_3.webp 1200w"
src="https://luiscachog.io/media/posts/my-first-contribution-to-openstack/OpenStack-Contribution_hue50cae8c9a4f3ce2cc82fba8663fd3f2_54865_0af5728d9b6f3d8f558a246cb97b792f.webp"
width="748"
height="699"
loading="lazy" data-zoomable />&lt;/div>
&lt;/div>&lt;figcaption>
My First OpenStack Contribution
&lt;/figcaption>&lt;/figure>
&lt;p>I feel happy and motivated to still learn about this Open-Source project and a lot more.&lt;/p>
&lt;p>&amp;#x1f604;&lt;/p></description></item><item><title>Deployment de un sitio estatico con Hugo y Git Hooks</title><link>https://luiscachog.io/deployment-hugo-site-git-hooks/</link><pubDate>Mon, 05 Mar 2018 00:00:00 +0000</pubDate><guid>https://luiscachog.io/deployment-hugo-site-git-hooks/</guid><description>&lt;details class="toc-inpage d-print-none " open>
&lt;summary class="font-weight-bold">Table of Contents&lt;/summary>
&lt;nav id="TableOfContents">
&lt;ul>
&lt;li>&lt;a href="#motivación">Motivación&lt;/a>
&lt;ul>
&lt;li>&lt;a href="#consideraciones">Consideraciones&lt;/a>&lt;/li>
&lt;/ul>
&lt;/li>
&lt;li>&lt;a href="#instruciones">Instruciones&lt;/a>
&lt;ul>
&lt;li>&lt;a href="#consideraciones-técnicas">Consideraciones técnicas&lt;/a>&lt;/li>
&lt;li>&lt;a href="#autenticación-mediante-llaves-ssh">Autenticación mediante llaves SSH&lt;/a>&lt;/li>
&lt;li>&lt;a href="#configuración-sitio-con-hugo">Configuración sitio con Hugo&lt;/a>&lt;/li>
&lt;li>&lt;a href="#configuración-del-repositorio-git-en-el-servidor-de-desarrollo-1ra-parte">Configuración del repositorio Git en el servidor de desarrollo 1ra parte&lt;/a>&lt;/li>
&lt;li>&lt;a href="#configuración-del-repositorio-git-en-el-servidor-productivo">Configuración del repositorio Git en el servidor productivo&lt;/a>&lt;/li>
&lt;li>&lt;a href="#configuración-del-repositorio-git-en-el-servidor-de-desarrollo-2da-parte">Configuración del repositorio Git en el servidor de desarrollo 2da parte&lt;/a>&lt;/li>
&lt;/ul>
&lt;/li>
&lt;/ul>
&lt;/nav>
&lt;/details>
&lt;h2 id="motivación">Motivación&lt;/h2>
&lt;p>Estoy intentando escribir un poco más en mi blog, ya que noté que muchas veces no lo hacia muy a menudo
por que al llegar a la consola de administración de Wordpress, habia que dar bastantes clicks para llegar al menu de &amp;ldquo;Posts&amp;rdquo;,
además de que cada vez que entraba había un plugin diferente que actualizar, y verificar que nada se rompiera con
las nuevas actualizaciónes, en pocas palabras hay que darle bastante mantenimiento a un sitio con Wordpress,
y además de eso había que dedicarse a escribir el post.&lt;/p>
&lt;p>Otra razón por lo que opté hacer el cambio de plataforma, es que al estar tratando de convertirme en DevOps, es necesario,
desde mi punto de vista; tratar automatizar/scriptear la mayoria de tus tareas que realizas día a día, y con &lt;a href="https://gohugo.io/" title="Hugo" target="_blank" rel="noopener">Hugo&lt;/a> considero que se puede realizar este objetivo también.&lt;/p>
&lt;h3 id="consideraciones">Consideraciones&lt;/h3>
&lt;p>Una vez que decidí migrarme de Wordpress, el siguiente paso era decidir a que plataforma mudarme.
De entrada la plataforma que queria probar era un &lt;a href="https://en.wikipedia.org/wiki/Static_web_page" target="_blank" rel="noopener">Static Site Generator&lt;/a>,
aqui otro &lt;a href="https://cloudcannon.com/blog/what-is-a-static-website/" target="_blank" rel="noopener">link&lt;/a> de por que usar un Static Site Generator.&lt;/p>
&lt;p>Partiendo de lo anterior, las opciones que me parecieron interesantes fueron:&lt;/p>
&lt;ul>
&lt;li>&lt;a href="https://gohugo.io" target="_blank" rel="noopener">Hugo&lt;/a>&lt;/li>
&lt;li>&lt;a href="https://jekyllrb.com" target="_blank" rel="noopener">Jekyll&lt;/a>&lt;/li>
&lt;li>&lt;a href="http://octopress.org/" target="_blank" rel="noopener">Octopress&lt;/a>&lt;/li>
&lt;li>&lt;a href="https://hexo.io/" target="_blank" rel="noopener">Hexo&lt;/a>&lt;/li>
&lt;/ul>
&lt;p>Cada una de las opciones tiene diferentes caracteristicas, que no vamos a discutir en este post,
sin embargo las carteristicas que me convencieron de usar &lt;a href="https://gohugo.io/" title="Hugo" target="_blank" rel="noopener">Hugo&lt;/a> por encima de las otras alternativas fueron:&lt;/p>
&lt;ul>
&lt;li>Consta solamente de un binario, que comparado con las otras posibilidades hay que instalar todo un ambiente de desarrollo/producción.&lt;/li>
&lt;li>Es bastante rápido.&lt;/li>
&lt;li>Es Multi-plataforma&lt;/li>
&lt;li>Tiene diversos &lt;a href="https://themes.gohugo.io/" target="_blank" rel="noopener">temas&lt;/a>&lt;/li>
&lt;/ul>
&lt;h2 id="instruciones">Instruciones&lt;/h2>
&lt;h3 id="consideraciones-técnicas">Consideraciones técnicas&lt;/h3>
&lt;p>El ambiente consta de:&lt;/p>
&lt;ul>
&lt;li>1 servidor productivo donde esta instalado hugo, git y un servidor web (apache o nginx) , haremos todos los deployments usando el usuario admin, ojo que no es el usuario root.&lt;/li>
&lt;li>1 servidor/equipo de desarrollo, de igual forma que cuenta con hugo y git, en mi caso, es mi computadora personal y mi usuario es luiscachog.&lt;/li>
&lt;li>1 cuenta de &lt;a href="https://github.com" target="_blank" rel="noopener">github.com&lt;/a>&lt;/li>
&lt;/ul>
&lt;h3 id="autenticación-mediante-llaves-ssh">Autenticación mediante llaves SSH&lt;/h3>
&lt;p>El primer paso es realizar el intercambio de llaves SSH entre el equipo de desarrollo y el equipo productivo. Para ello seguimos los siguientes pasos:&lt;/p>
&lt;ol>
&lt;li>
&lt;p>Generar la llave SSH, tendrás que contestar algunas preguntas, entre las cuales está si quieres ponerle un password, a lo cual deberas dejarlo en blanco para que no te pida contraseña.&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">luiscachog@dev-server:~$ ssh-keygen
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;/li>
&lt;li>
&lt;p>Copiar la llave SSH hacia el equipo productivo:&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">luiscachog@dev-server:~$ ssh-copy-id admin@IP_servidor_productivo
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;/li>
&lt;li>
&lt;p>Verificar que te puedas conectar desde tu servidor de desarrollo, con tu usuario al servidor productivo, con el usuario que realizará los deployments.&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">luiscachog@dev-server:~$ ssh admin@162.125.2.30 hostname
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;p>En este caso, debera de mostrarte el hostname del servidor productivo sin pedirte el password.&lt;/p>
&lt;/li>
&lt;/ol>
&lt;h3 id="configuración-sitio-con-hugo">Configuración sitio con Hugo&lt;/h3>
&lt;p>El siguiente paso es configurar nuestro ambiente de desarrollo con Hugo y Git.&lt;/p>
&lt;ol>
&lt;li>
&lt;p>Para instalar ambos en Ubuntu o derivados debes de ejecutar:&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">luiscachog@dev-server:~$ sudo apt install hugo git
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;p>Para tener la version más actualizada de hugo puedes seguir los pasos descritos en este &lt;a href="https://gohugo.io/getting-started/installing/" target="_blank" rel="noopener">link&lt;/a>&lt;/p>
&lt;/li>
&lt;li>
&lt;p>Vamos a crear un directorio de trabajo para nuestro sitio estatico&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">luiscachog@dev-server:~$ mkdir ~/sites
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">luiscachog@dev-server:~$ &lt;span class="nb">cd&lt;/span> ~/sites
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;/li>
&lt;li>
&lt;p>Crearemos un nuevo sitio usando el comando hugo&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">luiscachog@dev-server:~$ hugo new site luiscachog.io
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">Congratulations! Your new Hugo site is created in /home/luiscachog/sites/luiscachog.io.
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">Just a few more steps and you&lt;span class="err">&amp;#39;&lt;/span>re ready to go:
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">1.- Download a theme into the same-named folder.
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl"> Choose a theme from https://themes.gohugo.io/, or
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl"> create your own with the &lt;span class="s2">&amp;#34;hugo new theme &amp;lt;THEMENAME&amp;gt;&amp;#34;&lt;/span> command.
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">2.- Perhaps you want to add some content. You can add single files
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl"> with &lt;span class="s2">&amp;#34;hugo new &amp;lt;SECTIONNAME&amp;gt;/&amp;lt;FILENAME&amp;gt;.&amp;lt;FORMAT&amp;gt;&amp;#34;&lt;/span>.
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">3.- Start the built-in live server via &lt;span class="s2">&amp;#34;hugo server&amp;#34;&lt;/span>.
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">Visit https://gohugo.io/ &lt;span class="k">for&lt;/span> quickstart guide and full documentation.
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;/li>
&lt;li>
&lt;p>Cuando termine de correr el comando se podra apreciar los siguientes directorios y archivos&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">luiscachog@dev-server:~$ &lt;span class="nb">cd&lt;/span> luiscachog.io
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">luiscachog@dev-server:~$ ls
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">archetypes config.toml content data layouts static themes
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">luiscachog@dev-server:~$ tree
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">.
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">├── archetypes
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">│   └── default.md
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">├── config.toml
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">├── content
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">├── data
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">├── layouts
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">├── static
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">└── themes
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="m">6&lt;/span> directories, &lt;span class="m">2&lt;/span> files
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;/li>
&lt;li>
&lt;p>El siguiente paso es agregar un tema, puedes encontrar uno que te guste en &lt;a href="https://themes.gohugo.io/" target="_blank" rel="noopener">https://themes.gohugo.io/&lt;/a>&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">git init
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">git submodule add https://github.com/budparr/gohugo-theme-ananke.git themes/ananke
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="c1"># Edit your config.toml configuration file&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="c1"># and add the new theme.&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="nb">echo&lt;/span> &lt;span class="s1">&amp;#39;theme = &amp;#34;ananke&amp;#34;&amp;#39;&lt;/span> &amp;gt;&amp;gt; config.toml
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;p>Como recomendación adicional en este paso, puedes realizar un fork del tema que te guste en github para poder realizar modificaciones y proponer cambios al mismo,
contribuyendo de esa forma a su desarrollo, para hacerlo, sigue los pasos:&lt;/p>
&lt;ol>
&lt;li>Realizar un fork del tema, sigue esta &lt;a href="https://docs.github.com/en/get-started/quickstart/contributing-to-projects" target="_blank" rel="noopener">guia&lt;/a> para hacerlo.&lt;/li>
&lt;li>Al realizar el fork, tendras en tus repositorios de github el tema que quieras, por lo que tendras que ejecutar los mismos comandos del punto anterior,
pero el repositorio del tema apuntara a tu usario en github&lt;/li>
&lt;/ol>
&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">git init
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">git submodule add https://github.com/luiscachog/gohugo-theme-ananke.git themes/ananke
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="c1"># Edit your config.toml configuration file&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="c1"># and add the new theme.&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="nb">echo&lt;/span> &lt;span class="s1">&amp;#39;theme = &amp;#34;ananke&amp;#34;&amp;#39;&lt;/span> &amp;gt;&amp;gt; config.toml
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;/li>
&lt;li>
&lt;p>Vamos a crear un post de prueba para verificar que todo esta funcionando correctamente&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">hugo new posts/my-first-post.md
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="nb">echo&lt;/span> &lt;span class="s2">&amp;#34;Hola Mundo&amp;#34;&lt;/span> &amp;gt;&amp;gt; content/posts/my-first-post.md
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;p>El comando anterior creara un archivo en la ruta content/posts/my-first-post.md, y el contenido será:&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-yaml" data-lang="yaml">&lt;span class="line">&lt;span class="cl">&lt;span class="nn">---&lt;/span>&lt;span class="w">
&lt;/span>&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="w">&lt;/span>&lt;span class="nt">title&lt;/span>&lt;span class="p">:&lt;/span>&lt;span class="w"> &lt;/span>&lt;span class="s2">&amp;#34;My First Post&amp;#34;&lt;/span>&lt;span class="w">
&lt;/span>&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="w">&lt;/span>&lt;span class="nt">date&lt;/span>&lt;span class="p">:&lt;/span>&lt;span class="w"> &lt;/span>&lt;span class="ld">2018-02-28T12:02:38&lt;/span>&lt;span class="m">-06&lt;/span>&lt;span class="p">:&lt;/span>&lt;span class="m">00&lt;/span>&lt;span class="w">
&lt;/span>&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="w">&lt;/span>&lt;span class="nt">draft&lt;/span>&lt;span class="p">:&lt;/span>&lt;span class="w"> &lt;/span>&lt;span class="kc">true&lt;/span>&lt;span class="w">
&lt;/span>&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="w">&lt;/span>&lt;span class="nn">---&lt;/span>&lt;span class="w">
&lt;/span>&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="w">&lt;/span>&lt;span class="l">Hola Mundo!!!&lt;/span>&lt;span class="w">
&lt;/span>&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;/li>
&lt;li>
&lt;p>Finalmente, probaremos que nuestro sitio estatico con nuestro post se muestren de manera local, en nuestro servidor de desarrollo.
Cabe mencionar, que por defecto el comando &amp;lsquo;hugo server&amp;rsquo; no mostrará los posts que tengan la opción &amp;lsquo;draft: true&amp;rsquo;, por ello se agrega la bandera -D&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">luiscachog@dev-server:~$ hugo server -D
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;/li>
&lt;/ol>
&lt;h3 id="configuración-del-repositorio-git-en-el-servidor-de-desarrollo-1ra-parte">Configuración del repositorio Git en el servidor de desarrollo 1ra parte&lt;/h3>
&lt;p>En el paso pasado, realizamos la inicialización del repositorio dentro del directorio del sitio estatico:&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">luiscachog@dev-server:~$ &lt;span class="nb">pwd&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">/home/luiscachog/sites/luiscachog.io
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">luiscachog@dev-server:~$ git status
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">On branch master
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">Initial commit
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">Changes to be committed:
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl"> &lt;span class="o">(&lt;/span>use &lt;span class="s2">&amp;#34;git rm --cached &amp;lt;file&amp;gt;...&amp;#34;&lt;/span> to unstage&lt;span class="o">)&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl"> new file: .gitmodules
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl"> new file: themes/ananke
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">Untracked files:
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl"> &lt;span class="o">(&lt;/span>use &lt;span class="s2">&amp;#34;git add &amp;lt;file&amp;gt;...&amp;#34;&lt;/span> to include in what will be committed&lt;span class="o">)&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl"> archetypes/
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl"> config.toml
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl"> content/
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl"> themes/ananke/
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;p>Ahora, para tener el repositorio publico, tenemos que &lt;a href="https://docs.github.com/en/repositories/creating-and-managing-repositories/creating-a-new-repository" target="_blank" rel="noopener">crear&lt;/a> el repositorio
en &lt;a href="https://github.com" target="_blank" rel="noopener">github.com&lt;/a> y configurarlo como un repositorio remoto&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">luiscachog@dev-server:~$ git add *
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">luiscachog@dev-server:~$ git commit -m &lt;span class="s2">&amp;#34;First commit&amp;#34;&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">luiscachog@dev-server:~$ git remote add origin https://github.com/luiscachog/luiscachog.io
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">luiscachog@dev-server:~$ git push -u origin master
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;h3 id="configuración-del-repositorio-git-en-el-servidor-productivo">Configuración del repositorio Git en el servidor productivo&lt;/h3>
&lt;p>Para poder ocupar los hooks de git es necesario hacer una primera copia inicial del repositorio en el que vamos a trabajar, con la particularidad de que el repositorio clonado debe ser del tipo &lt;a href="http://www.saintsjd.com/2011/01/what-is-a-bare-git-repository/" target="_blank" rel="noopener">bare&lt;/a>.&lt;/p>
&lt;p>En nuestro servidor productivo haremos:&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">admin@prod-server:~$ mkdir sites
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">admin@prod-server:~$ &lt;span class="nb">cd&lt;/span> sites
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">admin@prod-server:~$ git clone --bare https://github.com/luiscachog/luiscachog.io luiscachog.io.git
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;h4 id="configuración-del-hook">Configuración del hook&lt;/h4>
&lt;ol>
&lt;li>
&lt;p>Ya que tenemos nuestro repositorio tipo bare en el servidor productivo vamos a crear el script que mandará a llamar el hook de git.&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">admin@prod-server:~$ &lt;span class="nb">cd&lt;/span> sites/luiscachog.io.git/hooks
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">admin@prod-server:~$ vim post-update
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;/li>
&lt;li>
&lt;p>Y agregamos algo asi:&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">&lt;span class="cp">#!/bin/bash
&lt;/span>&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="cp">&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="nv">GIT_REPO&lt;/span>&lt;span class="o">=&lt;/span>&lt;span class="nv">$HOME&lt;/span>/luiscachog.io.git
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="nv">WORKING_DIRECTORY&lt;/span>&lt;span class="o">=&lt;/span>/var/www/vhosts/luiscachog.io/working_hugo
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="nv">PUBLIC_WWW&lt;/span>&lt;span class="o">=&lt;/span>/var/www/vhosts/luiscachog.io/public_html
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="nv">BACKUP_WWW&lt;/span>&lt;span class="o">=&lt;/span>/var/www/vhosts/luiscachog.io/backup_html
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="nv">MY_DOMAIN&lt;/span>&lt;span class="o">=&lt;/span>luiscachog.io
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="nb">set&lt;/span> -e
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">rm -rf &lt;span class="nv">$WORKING_DIRECTORY&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">rsync -aqz &lt;span class="nv">$PUBLIC_WWW&lt;/span>/ &lt;span class="nv">$BACKUP_WWW&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="nb">trap&lt;/span> &lt;span class="s2">&amp;#34;echo &amp;#39;A problem occurred. Reverting to backup.&amp;#39;; rsync -aqz --del &lt;/span>&lt;span class="nv">$BACKUP_WWW&lt;/span>&lt;span class="s2">/ &lt;/span>&lt;span class="nv">$PUBLIC_WWW&lt;/span>&lt;span class="s2">; rm -rf &lt;/span>&lt;span class="nv">$WORKING_DIRECTORY&lt;/span>&lt;span class="s2">&amp;#34;&lt;/span> EXIT
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">git clone &lt;span class="nv">$GIT_REPO&lt;/span> &lt;span class="nv">$WORKING_DIRECTORY&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">mkdir -p &lt;span class="nv">$WORKING_DIRECTORY&lt;/span>/themes
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">rm -rf &lt;span class="nv">$PUBLIC_WWW&lt;/span>/*
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">/home/admin/bin/hugo -v -s &lt;span class="nv">$WORKING_DIRECTORY&lt;/span> -d &lt;span class="nv">$PUBLIC_WWW&lt;/span> -b &lt;span class="s2">&amp;#34;http://&lt;/span>&lt;span class="si">${&lt;/span>&lt;span class="nv">MY_DOMAIN&lt;/span>&lt;span class="si">}&lt;/span>&lt;span class="s2">&amp;#34;&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="nb">trap&lt;/span> - EXIT
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;/li>
&lt;li>
&lt;p>Damos permisos de ejecución al script&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">admin@prod-server:~$ chmod +x post-update
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;/li>
&lt;li>
&lt;p>Probamos que nuestro script funcione adecuadamente:&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">admin@prod-server:~$ ~/sites/luiscachog.io.git/hooks/post-update
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">Cloning into &lt;span class="s1">&amp;#39;/var/www/vhosts/luiscachog.io/working_hugo&amp;#39;&lt;/span>...
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="k">done&lt;/span>.
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="m">0&lt;/span> draft content
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="m">0&lt;/span> future content
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="m">4&lt;/span> pages created
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="m">0&lt;/span> paginator pages created
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="m">0&lt;/span> tags created
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">&lt;span class="m">1&lt;/span> categories created
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">in &lt;span class="m">26&lt;/span> ms
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;/li>
&lt;li>
&lt;p>Podras verificar tu nuevo post en la URL de su sitio:&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">http://production_domain_or_IP
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;/li>
&lt;/ol>
&lt;h3 id="configuración-del-repositorio-git-en-el-servidor-de-desarrollo-2da-parte">Configuración del repositorio Git en el servidor de desarrollo 2da parte&lt;/h3>
&lt;p>Una vez tenemos configurado nuestro repositorio en el servidor de producción, procedemos a agregarlo como repositorio remoto en nuestro servidor de desarrollo&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">luiscachog@dev-server:~$ &lt;span class="nb">cd&lt;/span> /home/luiscachog/sites/luiscachog.io
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">luiscachog@dev-server:~$ git remote add prod admin@IP_servidor_productivo:luiscachog.io
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">luiscachog@dev-server:~$ git ls-remote prod
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">d1b0b73528ab3117170ef74e133d0194dd2bc88a HEAD
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">d1b0b73528ab3117170ef74e133d0194dd2bc88a refs/heads/master
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;p>Puedes verificar los repositorios remotos con el comando:&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">luiscachog@dev-server:~$ git remote -v
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">origin git@github.com:luiscachog/luiscachog.io.git &lt;span class="o">(&lt;/span>fetch&lt;span class="o">)&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">origin git@github.com:luiscachog/luiscachog.io.git &lt;span class="o">(&lt;/span>push&lt;span class="o">)&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">prod admin@IP_servidor_productivo:luiscachog.io.git &lt;span class="o">(&lt;/span>fetch&lt;span class="o">)&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">prod admin@IP_servidor_productivo:luiscachog.io.git &lt;span class="o">(&lt;/span>push&lt;span class="o">)&lt;/span>
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;p>Ahora cada vez que realizemos un push hacia el remote llamado &amp;lsquo;prod&amp;rsquo; se llamara la función del hook.&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">luiscachog@dev-server:~$ &lt;span class="nb">cd&lt;/span> /home/luiscachog/sites/luiscachog.io
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">luiscachog@dev-server:~$ hugo new posts/Testing-Deployment.md
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">luiscachog@dev-server:~$ &lt;span class="nb">echo&lt;/span> &lt;span class="s2">&amp;#34;Deployment Test&amp;#34;&lt;/span> &amp;gt;&amp;gt; content/posts/Testing-Deployment.md
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">luiscachog@dev-server:~$ git add *
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">luiscachog@dev-server:~$ git commit -m &lt;span class="s1">&amp;#39;Deployment test with git hooks&amp;#39;&lt;/span>
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;p>Este es el comando que hace la magia:&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">luiscachog@dev-server:~$ git push prod master
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">Counting objects: 3, &lt;span class="k">done&lt;/span>.
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">Delta compression using up to &lt;span class="m">8&lt;/span> threads.
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">Compressing objects: 100% &lt;span class="o">(&lt;/span>3/3&lt;span class="o">)&lt;/span>, &lt;span class="k">done&lt;/span>.
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">Writing objects: 100% &lt;span class="o">(&lt;/span>3/3&lt;span class="o">)&lt;/span>, &lt;span class="m">310&lt;/span> bytes &lt;span class="p">|&lt;/span> &lt;span class="m">0&lt;/span> bytes/s, &lt;span class="k">done&lt;/span>.
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">Total &lt;span class="m">3&lt;/span> &lt;span class="o">(&lt;/span>delta 2&lt;span class="o">)&lt;/span>, reused &lt;span class="m">0&lt;/span> &lt;span class="o">(&lt;/span>delta 0&lt;span class="o">)&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">remote: Cloning into &lt;span class="s1">&amp;#39;/var/www/vhosts/luiscachog.io/working_hugo&amp;#39;&lt;/span>...
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">remote: &lt;span class="k">done&lt;/span>.
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">remote: Cloning into &lt;span class="s1">&amp;#39;/var/www/vhosts/luiscachog.io/working_hugo/themes/hugo-future-imperfect&amp;#39;&lt;/span>...
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">remote: INFO 2018/03/01 03:12:34 Using config file: /var/www/vhosts/luiscachog.io/working_hugo/config.toml
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">remote: Building sites … INFO 2018/03/01 03:12:34 syncing static files to /var/www/vhosts/luiscachog.io/public_html/
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">remote:
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">remote: &lt;span class="p">|&lt;/span> EN
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">remote: +------------------+----+
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">remote: Pages &lt;span class="p">|&lt;/span> &lt;span class="m">10&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">remote: Paginator pages &lt;span class="p">|&lt;/span> &lt;span class="m">0&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">remote: Non-page files &lt;span class="p">|&lt;/span> &lt;span class="m">0&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">remote: Static files &lt;span class="p">|&lt;/span> &lt;span class="m">3&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">remote: Processed images &lt;span class="p">|&lt;/span> &lt;span class="m">0&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">remote: Aliases &lt;span class="p">|&lt;/span> &lt;span class="m">1&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">remote: Sitemaps &lt;span class="p">|&lt;/span> &lt;span class="m">1&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">remote: Cleaned &lt;span class="p">|&lt;/span> &lt;span class="m">0&lt;/span>
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">remote:
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">remote: Total in &lt;span class="m">44&lt;/span> ms
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl">To admin@IP_servidor_productivo:luiscachog.io.git
&lt;/span>&lt;/span>&lt;span class="line">&lt;span class="cl"> d5b0671..cvc4dee master -&amp;gt; master
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;p>Listo ya podemos probar nuestro sitio&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" class="chroma">&lt;code class="language-shell" data-lang="shell">&lt;span class="line">&lt;span class="cl">http://luiscachog.io
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;p>Con esto el siguiente paso que realizare es hacer el deployment de mi servidor para el blog usando Ansible.&lt;/p>
&lt;p>Nos Vemos!!!&lt;/p>
&lt;p>&lt;strong>References:&lt;/strong>
Digital Ocean blog post &lt;sup id="fnref:1">&lt;a href="#fn:1" class="footnote-ref" role="doc-noteref">1&lt;/a>&lt;/sup>&lt;/p>
&lt;div class="footnotes" role="doc-endnotes">
&lt;hr>
&lt;ol>
&lt;li id="fn:1">
&lt;p>&lt;a href="https://www.digitalocean.com/community/tutorials/how-to-deploy-a-hugo-site-to-production-with-git-hooks-on-ubuntu-14-04" target="_blank" rel="noopener">Digital Ocean&lt;/a>&amp;#160;&lt;a href="#fnref:1" class="footnote-backref" role="doc-backlink">&amp;#x21a9;&amp;#xfe0e;&lt;/a>&lt;/p>
&lt;/li>
&lt;/ol>
&lt;/div></description></item></channel></rss>