Principal Software Engineer - Elastic Search
Engineering | Sydney, Australia | Full-Time
Atlassian Cloud Storage Engineering (ACSE) is composed of infrastructure teams tasked with developing and upkeeping the persistent data stores used by Atlassian's product and platform teams. The Managed Search team has set ambitious goals, including enhancing Search operational efficiencies company-wide, improving cluster reliability, cutting down the Total Cost of Ownership (Search TCO) across Atlassian, and enhancing Trust (Security & Compliance).
In pursuit of these goals, the Managed Search team is developing a self-hosted search platform for use within Atlassian, aiming to achieve the ACSE vision to improve the clock speed of Atlassian by providing reliable, secure and cost-effective storage solutions.
This position is for a Principal Engineer on the ACSE Kratos (Managed Search team ~15 engineers) reporting to Senior Engineering Manager. This role will require deep, hands-on operational work to run high-quality search infrastructure, outstanding collaboration skills to work effectively within a distributed team and engage with a broad range of internal customers, solid industry knowledge and technical curiosity to assess when best to build, and great design and hands-on development skills to build automation and peripheral tooling.
As a Principal Engineer, you will contribute to the architectural and technical direction of the Managed Search team, help set the standard for engineering practices and provide mentoring to more junior team members. You will also work with teams across Atlassian to provide guidance around search solutions, identify cross-cutting areas where the platform can be enhanced and design platform capabilities.
Here, you'll collaborate with and provide guidance to experienced and inquisitive engineers to build the infrastructure that enables thousands of Atlassians to deploy and operate search applications in the cloud.
Responsibilities & Activities:
1. Design, implementation and operation of new and existing Managed Search components.
2. Operating search clusters at high load.
3. Deep understanding of managing high numbers of clusters for reliability, such as ensuring reliable version upgrades and effective cluster configuration management.
4. Building tooling and automation to facilitate the provisioning and operation of increasing numbers of clusters.
5. Advanced understanding of cluster capacity management to ensure optimal performance and resource allocation within a system.
6. Understanding of encryption at rest including KMS/data key management and BYOK.
7. Engagement with product teams to support and guide them as they onboard the service to the self-hosted search platform.
8. Adapt the platform to cater for their use cases without compromising other customers.
9. Tuning and hardening the clusters based on a deep understanding of their data and query patterns.
10. Contributing to the definition of appropriate SLAs that are suitable for customers and realistic for the Managed Search team.
11. Contributions towards technical leadership within the team.
12. Driving & documenting key technical decisions.
13. Identifying opportunities & mitigating risks based on deep knowledge of the Managed Search systems and adjacent systems.
Key Results Areas:
1. Quality: The Managed Search team will be key to both customer-facing functionality and internal business-critical workflows, so the platform's reliability and quality are essential metrics.
2. Scale: The Managed Search team must be able to scale out clusters as customers' workloads increase and add clusters as the number of customers increases.
3. Adoption: The Managed Search team is responsible for building a platform that is desirable to its consumers, engaging with customers to build trust in its product, and shipping in a sufficiently timely and incremental manner to enable dev teams to build on their components.
Technical Requirements:
1. Deep Elasticsearch/OpenSearch skills, including operating and tuning large clusters, implementing backup and recovery mechanisms, predicting and preventing cluster issues via monitoring, diagnosing and fixing unhealthy clusters, and implementing preventative solutions to avoid repeat failures.
2. Experience with a range of AWS services, their advantages and limitations, and understanding when to use specific services.
3. Experience building operationally mature systems with appropriate logging, monitoring, SLAs, alerting, and runbooks.
4. A high standard for quality software engineering (CI/CD, testing).
5. Experience progressively and safely rolling out changes to complex live systems.
6. Experience with Java/Kotlin.
7. Experience with Docker, Kubernetes.
8. Knowledge of Golang.
9. Experience with Micros or PaaS platform.
Less Technical Requirements:
1. Must be used to ownership of large deliverables and complex problems.
2. Must be a top-notch team worker, exemplary in communicating progress and risks.
3. Experience working with remote teams.
4. Experience engaging with and building trust amongst internal customers.
5. Excellent communication skills when engaging with customers and in written communication with the wider organization.
6. Experience with incident management processes.
7. Experience participating in 24/7 on-call rosters.
8. Non-hero attitude: Engaging in engineering practices that avoid incidents in the first place.
Don’t see an exact role match? No problem! Join our Talent Community and stay up-to-date on company and careers updates relevant to your career.
#J-18808-Ljbffr