<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Sachin Deshpande</title>
    <description>The latest articles on DEV Community by Sachin Deshpande (@techamigo).</description>
    <link>https://dev.to/techamigo</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F893841%2F516de262-c958-4760-b15c-97a676980a12.jpg</url>
      <title>DEV Community: Sachin Deshpande</title>
      <link>https://dev.to/techamigo</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/techamigo"/>
    <language>en</language>
    <item>
      <title>Preview environments in Kubernetes</title>
      <dc:creator>Sachin Deshpande</dc:creator>
      <pubDate>Sun, 18 Sep 2022 09:27:41 +0000</pubDate>
      <link>https://dev.to/techamigo/preview-environments-in-kubernetes-i0</link>
      <guid>https://dev.to/techamigo/preview-environments-in-kubernetes-i0</guid>
      <description>&lt;p&gt;If you’re developing on Kubernetes, we’d love to hear your feedback 🙏&lt;/p&gt;

&lt;p&gt;We have a new feature (almost) ready for release: Kubernetes Preview Environments.&lt;/p&gt;

&lt;p&gt;➡️ &lt;strong&gt;The problem with previews in Kubernetes:&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;One of the major challenges we’re seeing is the lack of any concept of native preview environments in Kubernetes. &lt;/p&gt;

&lt;p&gt;When a feature has a lot of dependencies and related infrastructure, setting up a test environment can require an unreasonable amount of DevOps effort. Our new feature lets you automate that effort away.&lt;/p&gt;

&lt;p&gt;The Tech Amigos team has been working hard on this one, and now we’re at the stage where we want to hear from some actual users!&lt;/p&gt;

&lt;p&gt;➡️ &lt;strong&gt;How Diego Preview Environments work:&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;With Diego Preview Environments, you can easily test new features and verify changes within a production-like Kubernetes environment, without actually disrupting production.&lt;/p&gt;

&lt;p&gt;Diego allows you to define a “recipe” for your preview environment that includes dependent applications and services, in a simple &lt;code&gt;diego.yaml&lt;/code&gt; file. &lt;/p&gt;

&lt;p&gt;Based on this recipe, Diego instantly spins up an ephemeral containerised environment (including dependencies!), without having to manually set up any of the infrastructure. Diego will check the version that needs to run and provision the required resources and test data.&lt;/p&gt;

&lt;p&gt;➡️ We’d love hear from you 👇&lt;/p&gt;

&lt;p&gt;_Is this a challenge you’re facing? &lt;br&gt;
_&lt;br&gt;
Would you be willing to spend a few minutes playing with the new feature and telling us what you think?&lt;/p&gt;

&lt;p&gt;⚠️ &lt;strong&gt;This is not a sales pitch - we do not have a commercial model yet…&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;Any feedback is greatly appreciated 🙏&lt;/p&gt;

</description>
      <category>kubernetes</category>
      <category>gitops</category>
      <category>aws</category>
      <category>devops</category>
    </item>
    <item>
      <title>DevOps complexity is grinding software development to a halt. Is there a way to simplify cloud tooling?</title>
      <dc:creator>Sachin Deshpande</dc:creator>
      <pubDate>Sat, 17 Sep 2022 09:32:00 +0000</pubDate>
      <link>https://dev.to/techamigo/devops-complexity-is-grinding-software-development-to-a-halt-is-there-a-way-to-simplify-cloud-tooling-2cgf</link>
      <guid>https://dev.to/techamigo/devops-complexity-is-grinding-software-development-to-a-halt-is-there-a-way-to-simplify-cloud-tooling-2cgf</guid>
      <description>&lt;p&gt;&lt;strong&gt;Software might be eating the world, but DevOps complexity is grinding it to a halt&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;Releasing software was supposed to be easier by now. We’ve got all these tools, we’ve got resources like Stack Overflow, and we’ve got the cloud. But somehow, most engineering leaders we talk to feel it’s only gotten more complicated&lt;/p&gt;

&lt;p&gt;Why has shipping software gotten more difficult and error prone? It’s not writing new features that’s causing the bottleneck - but rather the complexity of deploying code to the cloud.&lt;/p&gt;

&lt;p&gt;Yes, you might be able to release an MVP quickly, but creating repeatable and scalable processes is an entire different story. Talking with CTOs and heads of engineering, we keep running into the same issues:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;p&gt;&lt;strong&gt;Skilled DevOps engineers are hard to come by:&lt;/strong&gt; A majority of IT leaders have reported that hiring skilled DevOps people is a challenge, according to a 2021 survey (PDF). For smaller companies that can’t afford to keep up with the salary arms race, this is an even bigger problem.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;&lt;strong&gt;Dealing with tooling sprawl:&lt;/strong&gt; Everything you can do on the cloud nowadays comes in dozens of different flavours - from your choice of cloud provider to your container orchestration platform. Tooling choices are endless and confusing; evaluating software becomes a costly distraction.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;&lt;strong&gt;Configuring the cloud stack correctly:&lt;/strong&gt; Every platform under the sun promises a complete self-service experience, but the reality is often less straightforward. Something as simple as setting up an S3 bucket to store some documents comes with a host of configuration choices, and the same applies to every microservice, database, and component you use. Many of the people we spoke to had nagging suspicions that things were set up incorrectly and that this would come back to haunt them (they were usually right).&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;DevOps issues such as managing dependencies, Kubernetes configuration, and CI/CD pipelines end up eating 10-30% of development resources - slowing down the company’s core revenue-generating activities (as was covered in &lt;a href="https://garden.io/blog/developer-productivity-survey-report-2021/"&gt;this report from 2021&lt;/a&gt;). &lt;/p&gt;

&lt;p&gt;For a small company that just needs to ship an app today, getting started can be extremely difficult. &lt;/p&gt;

&lt;p&gt;&lt;strong&gt;The Pareto Principle and 3 Ways to Overcome DevOps Complexity&lt;/strong&gt;&lt;br&gt;
The &lt;a href="https://en.wikipedia.org/wiki/Pareto_principle"&gt;Pareto principle&lt;/a&gt; tells us that roughly 80% of consequences come from 20% of actions. In software development, the first 20% of correct design choices will give you most of the benefits when it comes to performance, security, and stability; the rest you can optimise later.&lt;/p&gt;

&lt;p&gt;While no two projects are identical, we’ve found that many early stage companies or smaller software teams are implementing the same patterns:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;p&gt;&lt;strong&gt;Standard open-source toolchain:&lt;/strong&gt; For most companies and most projects, there is a set of open source tools that strikes the right balance between control and usability. GitHub, Kubernetes, ArgoCD, Prometheus and Grafana give you what you need to write well-structured code and push it to the cloud.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;&lt;strong&gt;Good-enough configuration rather than perfectly-tuned everything:&lt;/strong&gt; Options are endless and fiddling with them might eventually produce a cleaner pipeline or reduce milliseconds of latency, but that’s rarely what makes or breaks a startup. Instead, start with an MVP-type setup that ticks just-enough boxes to enable short cycle times without jeopardising security, stability or resilience.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;&lt;strong&gt;Best practices for development workflows:&lt;/strong&gt; There are right and wrong ways to handle namespace management, resource provisioning and dependencies. We would review the way things that were done in the past, fix them when necessary, and ensure that best practices are adhered to moving forward.&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;After dozens of projects with different companies, we found that these basic patterns are repeated time and again - right down to the choice of naming conventions. Which leads us to ask: Why repeat a process manually, when you can automate it?&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Diego - Productizing the 20/80 Stack&lt;/strong&gt;&lt;br&gt;
&lt;a href="https://techamigos.co/product"&gt;Diego&lt;/a&gt; is our answer to the DevOps challenge that’s paralysing smaller software teams. Diego is a platform that provides an end-to-end development workflow using a set of open-source tools, mainly Kubernetes and ArgoCD. With Diego in place, developers can build, deploy, and monitor containerised applications in the cloud - on a solid foundation of enterprise-grade DevOps infrastructure.&lt;/p&gt;

&lt;p&gt;With Diego, our software would handle cloud and Kubernetes setup, security, infrastructure management, application management, deployment, and observability. You can &lt;a href="https://techamigos.co/product"&gt;find the details here&lt;/a&gt;.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--lBLRUGmN--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/c985z7lvhjbcvtsg9vfq.jpg" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--lBLRUGmN--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/c985z7lvhjbcvtsg9vfq.jpg" alt="Diego Concept" width="880" height="539"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Our vision is to give smaller teams the ability to ship high-quality software quickly, even if they don’t have large DevOps teams to optimise their cloud deployments. No more trial and error or whim-based configuration decisions that end up creating a mess of repos and dependencies. Instead, Diego provisions the resources and environments needed for each feature, app, or microservice - and lets developers work their magic from there.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;We’d love your feedback.&lt;/strong&gt;&lt;br&gt;
Diego is a new product. We’ve just launched with a small group of design partners and would love to hear your feedback - are we in the right direction? What else would you like to see? How can we further simplify the process of building, deploying, and monitoring apps for organisations like yours? Tell us in the comments.&lt;/p&gt;

&lt;p&gt;And if you’re ready to give Diego a spin, get in touch &lt;a href="https://diegocloud.io/access"&gt;here&lt;/a&gt; and we’ll set you up with a free trial.&lt;/p&gt;

</description>
      <category>cloudnative</category>
      <category>kubernetes</category>
      <category>deployments</category>
      <category>productivity</category>
    </item>
  </channel>
</rss>
