Quantcast
Channel: Blog O' Matty on Prefetch Technologies
Browsing all 58 articles
Browse latest View live

Seeing what changed in a docker containers file system

Docker has a number of nifty options to help investigate containers and container images. One option I have used over and over to debug issues is the docker “diff” command. This dumps out the files...

View Article


How the docker container creation process works (from docker run to runc)

Over the past few months I’ve been investing a good bit of personal time studying how Linux containers work. Specifically, what does docker run actually do. In this post I’m going to walk through what...

View Article


Converting X509 certificates to JSON objects

Years ago when I wrote ssl-cert-check I looked far and wide for an easy way to parse X509 certificates. I wasn’t able to find a utility so I ended up using a combination of sed and awk to extract...

View Article

Linting Jenkinsfiles to find syntax errors

As a long time Jenkins user I periodically need to add new steps or Groovy logic to my Jenkinsfiles. The last thing you want to do when updating your pipeline configuration is to make a typo which...

View Article

Notes from episode 70 of TGIK: Assuming AWS roles with kube2iam/kiam

Over the past few months I’ve been trying to learn everything there is to know about Kubernetes. Kubernetes is an amazing technology for deploying and scaling containers though it comes with a cost....

View Article


Using external-dns to managed DNS entries in Kubernetes clusters

Kubernetes provides a service resource to distribute traffic across one or more pods. I won’t go into detail on what a service is, since it’s covered in-depth elsewhere. For Internet-facing...

View Article

Exporting AWS Cloudwatch log streams to a local file

I love AWS, but when I’m debugging issues I prefer the Linux command line over Cloudwatch Logs Insights. Numerous AWS services store their log configuration inside cloudwatch, which presents a small...

View Article

Backing up your route53 zone configuration with the aws CLI

In a previous post, I discussed using the Kubernetes external-dns project to manage DNS changes. Prior to rolling it out, I needed a way to backup each zone prior to external-dns modifying it. I also...

View Article


Using audit2rbac to create RBAC policies from Kubernetes audit log

When I first started with Kubernetes, it took me some time to understand two things. One, how do I generate manifests to run my service. I tackled this in a previous blog post. The second was wrapping...

View Article


Using the profile module to time Ansible playbook runs

This past weekend I spent some time revamping a few playbooks. One of my playbooks was taking a while to run, and I wanted to see how much actual time was spent in each task. Luckily for me, Ansible...

View Article

Using the Ansible async module to perform synthetic health tests during...

I’ve become a huge fan of Ansible’s async support. This is incredibly useful for performing synthetic health tests on services after a task completes. A common use case is patching a server that hosts...

View Article

Listing Kubernetes nodes by label

When you support large Kubernetes clusters, you need efficient methods to list pods, nodes, and deployments when you are troubleshooting issues. Kubectl has a number of built-in methods to do this. You...

View Article

Using grpcurl to interact with gRPC applications

The past couple of weeks I have been digging into gRPC and HTTP2 in my spare time. I needed a way to review the requests and responses, and an easy way to explore gRPC servers. I also wanted something...

View Article


Using the terraform console to debug interpolation syntax

I am a long time Terraform user. The number of providers that are available for Terraform, and having a resource for pretty much every cloud service makes it super appealing. But even with several...

View Article

Adding default tags to AWS resources with Terraform

If you’ve worked with the various cloud providers, you’ve probably realized the value that comes with tagging resources. For billing and searching, I like to create a default set of tags that are...

View Article


Using Terraform for_each statements and dynamic nested blocks to simply AWS...

Over the past few months, I’ve been updating various Terraform modules to utilize the new features in 0.12. Among these, is the ability to iterate over dynamic blocks with for_each. Utilizing this new...

View Article

Finding Kubernetes issues with Popeye

Kubernetes is an incredible platform, but there are a lot of things that can go wrong. This is especially the case when you are new to K8S, and are overwhelmed with configuration options, deployment...

View Article


Managing multiple Kubernetes resources by label

Kubernetes labels are super useful. If you aren’t familiar with them, a label is a key/value pair assigned in the metadata section (either metadata.labels, or spec.template.metadata.labels) of a...

View Article

Disabling cron jobs globally on CentOS machines

As a long time CentOS user, I’ve always winced when I took ownership of new systems with e-mail notifications enabled. Whether this was through setting MAILTO to a distribution list, or using the...

View Article

TRIM support is enabled by default in Fedora 32

As a long time Fedora user, I like to keep up with the planning discussions that go into each release. These discussions are super useful for understanding what is coming to Redhat Enterprise Linux and...

View Article
Browsing all 58 articles
Browse latest View live