Sr. Software Engineer - Backend - Consul Ecosystem, Kubernetes
HashiCorp is a fast-growing startup that solves development, operations, and security challenges in infrastructure so organizations can focus on business-critical tasks. We build products to give organizations a consistent way to manage their move to cloud-based IT infrastructures for running their applications. Our products enable companies large and small to mix and match AWS, Microsoft Azure, Google Cloud, and other clouds as well as on-premises environments, easing their ability to deliver new applications for their business.
About the team
The Consul team, like all of HashiCorp, is fully distributed (100% remote). We have been a remote company since our founding in 2012.
Consul helps organizations automate network configurations, discover services, and enable secure connectivity across any cloud or runtime. The charter of the Consul Ecosystem team is to support platforms and runtimes that integrate with Consul with a focus on delivering a seamless UX for our practitioners and customers.
About the role
On the Consul team, we help organizations automate network configurations, discover services, and enable secure connectivity across any cloud or runtime. The customers and large community of users of our tools are operators, infrastructure engineers, and software developers that encounter novel performance, scaling, and usability challenges that we help them solve.
Consul started as an infrastructure management tool for service discovery and health checking, and has evolved to become a full-featured service mesh. You’ll be an active contributor to the service mesh ecosystem, following new developments in emerging technology and competitive offerings, looking for opportunities for product differentiation, and rethinking product architecture to meet new global scale and organizational demands.
In this role you can expect to:
- Build and architect distributed systems for service connectivity focusing on Kubernetes
- Interface directly with internal teams, users and HashiCorp customers, as well as the larger Consul community.
- Participate in user research studies and discussions with product managers and customers to better understand the network topologies, challenges, and constraints for which operators are trying to solve, and leverage those insights when approaching feature design and implementation.
- Propose new functionality or substantive changes through written documents in an async process, describing the problem background, proposed implementation and example UX, then iterating on peer feedback collaboratively.
- Own the full lifecycle of feature development from design through testing and release
- Program mostly in Golang, learning from and contributing to a team committed to continually improving their skills.
- Coach and mentor other team members within HashiCorp's engineering teams
You may be a good fit for our team if you have:
- Familiarity with service-oriented architectures, and ideally have worked on an infrastructure or platform team building internal tooling to deploy, connect and monitor them.
- Empathy for the people operating, learning, teaching and supporting software you write, and consider their experience when making design decisions and performance, security or complexity tradeoffs.
- Experience in a lower-level language like Go.
- Awareness of the broader service mesh ecosystem and an interest in contributing to a full-featured product offering while reducing complexity and barriers to adoption for practitioners.
- Curiosity for academic computer science research, particularly distributed systems papers such as Raft and Paxos variants, and enjoy learning more about the challenges of consistency at global scale.
- You have expertise with Kubernetes/K8s, or deep experience working with other container orchestrator platforms (e.g., Docker, Mesos, ECS, EKS, GKE, etc).
What is our hiring process like?
The below serves as a basic outline; we may choose to add or remove steps based on the information that we gather during the process.
- Introductory Call with someone from our recruiting team.
- First Interview with an Engineering Manager
- Interview Loop with additional team members, with the following panel:
- Technical Code Pairing interview
- Code Review interview
- Communication and Collaboration interview
- Systems and architecture interview
- If applicable, a final conversation with the Engineering Manager for the team you would be joining
- Offer
We do our best to accommodate your programming language of choice for technical interviews.
About the application process
Please note, as collaboration and communication are a critical aspect of how we work, a cover letter is a great way to provide a sample of how you communicate.
In your cover letter, please describe why you're interested in working at HashiCorp, and what draws you to this role in particular. Specifics of your past experience that are relevant to this role are great to include, too.
#LI-TW1
#LI-Remote
HashiCorp embraces diversity and equal opportunity. We are committed to building a team that represents a variety of backgrounds, perspectives, and skills. We believe the more inclusive we are, the better our company will be.
For more information regarding how HashiCorp collects, uses, and manages personal information, please review our Privacy Policy.