Posts by tags
  • Popular
  • Kubernetes 73
  • tools 25
  • databases 24
  • migrations 13
  • observability 12
  • A-Z
  • AIOps 1
  • ARM 1
  • AWS 3
  • benchmarking 2
  • best practices 7
  • business 4
  • caching 3
  • Calico 1
  • Cassandra 2
  • Ceph 5
  • cert-manager 1
  • CI/CD 9
  • CLI 4
  • ClickHouse 3
  • CNI 2
  • CockroachDB 1
  • comparison 9
  • databases 24
  • eBPF 2
  • Elasticsearch 5
  • etcd 4
  • failures 11
  • FinOps 1
  • Fluentd 1
  • GitLab 4
  • Helm 5
  • hyperconvergence 1
  • Ingress 3
  • Kafka 2
  • Keycloak 1
  • KeyDB 3
  • Kubernetes 73
  • Kubernetes operators 11
  • Linux 4
  • logging 5
  • Logstash 1
  • market 5
  • memcached 1
  • migrations 13
  • MongoDB 2
  • MySQL 2
  • networking 7
  • nginx 1
  • observability 12
  • Palark 7
  • PHP 1
  • PostgreSQL 10
  • Prometheus 4
  • Python 4
  • RabbitMQ 1
  • Redis 4
  • Rook 3
  • security 7
  • serverless 2
  • software development 2
  • SSL 1
  • storage 10
  • success stories 2
  • Terraform 3
  • tools 25
  • troubleshooting 8
  • Vault 1
  • Vector 2
  • virtualization 1
  • VPN 1
  • werf 3
  • YAML 2
  • ZooKeeper 1

How our DevOps-as-a-Service offering fits into the DevOps Team Topologies paradigm

Pioneered by esteemed DevOps veterans, DevOps Team Topologies classifies and consolidates nine team models and DevOps practices for modern software delivery.

It describes DevOps anti-types and DevOps team topologies opposed to them. The latter start from Dev and Ops Collaboration (Type 1) and go through other options till Dev and DBA Collaboration (Type 9). These types vary in how they work when they can be applied, and their potential effectiveness.

According to this classification, our model is formally called DevOps-as-an-External-Service (Type 4) since the external resources are utilized for successful implementation, yet internal control is still maintained over its cycle completion.

DevOps as an External Service as a basis

“For smaller teams or organizations with limited experience of operational issues.”

“What might be called DevOps-as-a-Service could be a useful and pragmatic way for a small organization or team to learn about automation, monitoring, and configuration management.”

(from DevOps Topologies, Type 4)

Palark is generally perceived as an outsourced DevOps team (and for good reason). That’s what we basically do: providing DevOps & SRE as a ready-to-use service for our clients’ needs. However, the way we operate and the benefits we provide are more than just DevOps-as-an-External-Service, as described in DevOps Topologies.

Years of experience working with clients of all sizes allowed us to cover a much broader range of business needs as a part of our DaaS (DevOps as a Service). That’s why we prefer to say we follow a hybrid DevOps & SRE model that extends formal Type 4.

Our hybrid model

In our DaaS, DevOps and SRE services provide invaluable assistance to clients of all sizes, covering multiple areas, including application architecture, containerization, building CI/CD processes, operating Kubernetes, databases, and much more. Even companies with full-time Ops and DevOps teams don’t always have the resources to cover all those areas. When it comes to smaller companies, this is even more so the case.

Another important point is our strategic stance with regard to cooperation. First and foremost, we aim to achieve the desired business outcome and long-term collaboration rather than earning an hourly rate. This renders our approach very close to that of an in-house team that just happens to work remotely.

If you keep this in mind while looking at DevOps Topologies, you will see that we apply principles embedded in some other topologies along with the DevOps-as-an-External-Service.

Ops as Infrastructure-as-a-Service

“For organizations with several different products and services, with a traditional Ops department, or whose applications run entirely in the public cloud.”

“The internal Ops team is thus directly equivalent to Amazon EC2, or Infrastructure-as-a-Service… This team is still a Dev team, however, following standard practices like TDD, CI, iterative development, coaching, etc.”

(from DevOps Topologies, Type 3)

We manage the infrastructure by following the Ops as Infrastructure-as-a-Service model: we design, build, and maintain all the things you need to run your applications. We also interact with all related providers and vendors. We believe creating and maintaining infrastructure is not a core competency but a commodity, even for clients with a technical background who develop their own software products.

To further explain this, we can use utilities as an analogy: an apartment owner buys water, electricity, heating, and other ready-made services from a third-party utility company since it makes no sense to generate and maintain it all yourself. The same can be said regarding the platform on which customers run their applications. The top priority for the business is implementing the features of the application that are in high demand among users and generate revenue.

At the same time, it is essential to emphasize that we do not limit our customers in their infrastructure choices. The platform we are developing supports various public cloud providers, private clouds, and bare metal.

Container-driven collaboration

“Containers remove the need for some kinds of collaboration between Dev and Ops by encapsulating the deployment and runtime requirements of an app into a container. In this way, the container acts as a boundary on the responsibilities of both Dev and Ops.”

(from DevOps Topologies, Type 8)

All of our customers either use Kubernetes, or we are currently integrating it into their workflow. But you have to containerize an application in order to (efficiently) run it in such an environment. Fortunately, there are best practices — mostly related to SRE (Site Reliability Engineering) — to make this possible and fruitful. We share them with our customers and encourage them to adopt them where appropriate.

Containers become the basic building blocks that we get from the Dev team, which we then run on the infrastructure. Meanwhile, Kubernetes becomes the language of communication between Dev and Ops.

And even more

The Type 6, DevOps Advocacy Team, is another integral part of DevOps as a Service from Palark. We actively advocate industry best practices for the benefit of our clients, striving to help them achieve their business goals. Having been in the market for so many years and participated in many projects of different scales, fields, and underlying tech stacks, we have accumulated experience and automated it in our own Open Source solutions, configurations, and processes.

We strive to bring the quintessence of this experience by delivering it both verbally (via communication with the Dev team) and practically (via the technical solutions we apply).

The Type 7’s SRE Team (or Google Model) is also a part of our DaaS. Our engineers handle SRE-related tasks by helping to fix code problems that affect application availability, performance, and other business-critical metrics.

We coordinate these metrics with business representatives and then track them with powerful observability tools. We report the detected problems to the client’s Dev team. Together, we troubleshoot these issues, whether they are related to the application architecture/code or the infrastructure solutions used.

Takeaways

At Palark, we treat DevOps-as-a-Service not just as an ordinary offering of DevOps Type 4 topology but as a comprehensive, innovative hybrid DevOps + SRE model unlike others. It integrates several formal topologies and is based on the following principles:

  • Provide infrastructure as a service tailored to real customer needs.
  • Focus on key business objectives and long-term cooperation.
  • Work closely with the client’s Dev team; promote the industry’s best practices and foster their implementation.

Such an approach makes implementing the ideas inherent in the Dev and Ops Collaboration (Type 1) model possible – to the best of our abilities as an external team.

“This is the ‘promised land’ of DevOps: smooth collaboration between Dev teams and Ops teams, each specializing where needed, but also sharing where needed. There are likely many separate Dev teams, each working on a separate or semi-separate product stack.”

(from DevOps Topologies, Type 1)

Our mission is to offer you the promised land of DaaS service with our expertise. We incorporate and continually review all the lessons we’ve learned as well as the experience, best practices, processes, and technical tools we’ve accumulated. To get top-notch service for your project, contact us today for a consultation.

We have been working with Palark for the last six months. Their DevOps team was really involved in the project we delegated to them from the very beginning. We came to Palark after seeing one of David Magton’s [their CTO] talks. At that moment, we realized it was the partner of our choice. They have a vast experience, a well-coordinated team, their own versatile set of tools to implement convenient and efficient software delivery and manage all the machinery under the hood of our apps.

Dmitry Malyshev, CTO, S.C. MNG Production S.R.L.

P. S. Interested in how our DaaS model is applied in real life? Find more details about its practical implications in the following article: 4 real cases from our DevOps as a Service hybrid model.

Comments

Your email address will not be published. Required fields are marked *