Golang / Go Job: Principal Software Engineer - Elastic Search

Atlassian

Principal Software Engineer - Elastic Search at Atlassian

🇦🇺 Australia › Sydney
  (Posted Oct 25 2024)

Please mention that you found the job at Golangprojects.com

Apply now!  

Job description
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:

Design, implementation and operation of new and existing Managed Search components. For example:

Operating search clusters at high load.

Deep understanding of managing high numbers of clusters for reliability, such as ensuring reliable version upgrades and effective cluster configuration management.

Building tooling and automation to facilitate the provisioning and operation of increasing numbers of clusters.

Advanced understanding of cluster capacity management to ensure optimal performance and resource allocation within a system. This involves monitoring and analyzing the resources available within a cluster to effectively plan and manage workload distribution.

Understanding of encryption at rest including KMS/data key management and BYOK

(NB: there is no current plan for this team to build an abstraction layer for search on top of Elasticsearch APIs - this is intentionally not included in the expected activities/responsibilities).

Engagement with product teams – for example Search Platform/JSIS/CPUS – to:

Support and guide them as they onboard the service to the self-hosted search platform.

Adapt the platform to cater for their use cases – without compromising other customers.

Tuning and hardening the clusters based on a deep understanding of their data and query patterns.

Contributing to the definition of appropriate SLAs that are suitable for customers and realistic for the Managed Search team.

Contributions towards technical leadership within the team

Determining and understanding priorities based on the broader view of Managed Search within Atlassian.

Driving & documenting key technical decisions

Identifying opportunities & mitigating risks based on deep knowledge of the Managed Search systems, as well as broad knowledge of adjacent systems (such as the consumers' systems) and underlying infra (such as AWS).

Key Results Areas:

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.

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.

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:

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.

Experience with a range of AWS services, their advantages and limitations, and understanding when to use specific services.

Experience building operationally mature systems with appropriate logging, monitoring, SLAs, alerting, and runbooks.

A high standard for quality software engineering (CI/CD, testing).

Experience progressively and safely rolling out changes to complex live systems.

Experience with Java/Kotlin.

Experience with Docker, Kubernetes.

Knowledge of Golang.

Experience with Micros or PaaS platform

Less technical:

Must be used to ownership of large deliverables and complex problems, and be able to do any of the following as appropriate to the situation:

clearly break up the work into smaller tasks to be carried out with the rest of the team

do a significant portion of the work themselves

enlist help/advice from other teams

demonstrate early that the task is not feasible / not the right focus.

Must be a top-notch team worker. Will work within the team's agreed processes (that they may help define); will be exemplary in communicating progress and risks, and helping to co-ordinate incremental deliverables within the team.

Experience working with remote teams.

Experience engaging with and building trust amongst internal customers. Excellent communication skills when engaging with customers and in written communication with the wider organisation.

Experience with incident management processes.

Experience participating in 24/7 on-call rosters (and willingness to do so on this team).

Non-hero attitude: Rather than celebrating a heroic effort to resolve an incident, I prefer engaging in engineering practices that avoid the incidents in the first place.

Please mention that you found the job at Golangprojects.com

Apply now!  
 

Company: Atlassian

Atlassian
job info / career page
Linkedin profile
Location: Sydney, Australia

map of company location

Skills wanted, in addition to Golang:
aws docker elasticsearch golang java
kotlin kubernetes

Golangprojects

All golang developer jobs
This is a job listing at Golangprojects,
the website dedicated to Golang jobs only.

Not the job you are looking for?
Browse all Golang jobs

Other interesting golang jobs

Golang job Senior Backend Engineer (Go) at GlassFlow Senior Backend Engineer (Go) - GlassFlow
Berlin, Germany
Berlin, Germany (hybrid) GlassFlow is building a hands free data streaming infrastructure for modern data teams. We are an early stage VC backed startup from Berlin that is building a category defin...

Golang job Senior Platform Engineer - Cloud Platform (open to remote ANZ) at Canva Senior Platform Engineer - Cloud Platform (open to remote ANZ) - Canva   (October 2024)
Sydney, Australia (Remote work possible)
Join the team redefining how the world experiences design. Hey, g'day, mabuhay, kia ora, 你好, hallo, vítejte! Thanks for stopping by. We know job hunting can be a little time consuming and you...
Golang job GO Developers for several projects at TRON Enterprise Services SRL GO Developers for several projects - TRON Enterprise Services SRL   (November 2024)
Hamburg, Germany (Remote work possible)
Non stop searching for GO Developers for several projects We are stuffing at the moment 3 projects and getting every month more requests. At the moment we need 1 Lead Architect (E4) 5 Senior Dev...

Golang job Senior Back-End Engineer at Adobe Senior Back-End Engineer - Adobe   (October 2024)
Clermont-Ferrand, France
Changing the world through digital experiences is what Adobe’s all about. We give everyone—from emerging artists to global brands—everything they need to design and deliver exceptional digital e...
Golang job Senior Fullstack Engineer at Epidemic Sound Senior Fullstack Engineer - Epidemic Sound   (October 2024)
Stockholm, Sweden
Join our global force of 500+ innovators, blending the latest in tech with the greatest in soundtracking, from our Stockholm HQ to offices in London, New York, Los Angeles, Berlin, Oslo, and Seoul. We...
Not the Go job you are looking for?
Browse all Golang jobs and we're sure you will find a suitable one!
Browse Golang Jobs with similar combinations of skills
Golang jobs with aws Golang jobs with docker Golang jobs with elasticsearch Golang jobs with java Golang jobs with kotlin Golang jobs with kubernetes