Multiple employees collaborating on work
Atlassian Logo

Atlassian

Principal Software Engineer - Kubernetes Storage

Reposted 8 Days Ago
Be an Early Applicant
Sydney, New South Wales
Senior level
Sydney, New South Wales
Senior level
The Principal Software Engineer will develop and manage cloud storage solutions using Kubernetes, ensuring reliability, scalability, and strong partnerships across product teams for enhanced search functionality.
The summary above was generated by AI

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 in Kubernetes, outstanding collaboration skills to work effectively within a distributed team and engage with a broad range of internal customers, solid industry knowledge on building stateful application in Kubernetes and Multicloud technologies, 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 and AI 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 the 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 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.
    • Advanced understanding of Kubernetes ecosystem, Kubernetes operator, and managing stateful application in Kubernetes.
    • Understanding of encryption at rest including KMS/data key management and BYOK, and other enterprise requirement.
  • Engagement with product teams (JIRA/Confluence/Opsgenie team) 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 Kubernetes).


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 Multi Cloud 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 experience with building and operating stateful application in Kubernetes with high load, including operating and tuning large clusters, capacity planning, 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.
  • 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, prefer engaging in engineering practices that avoid the incidents in the first place.

Top Skills

AWS
Docker
Go
Java
Kotlin
Kubernetes

Similar Jobs at Atlassian

16 Hours Ago
Remote
Sydney, New South Wales, AUS
Senior level
Senior level
Cloud • Information Technology • Productivity • Security • Software • App development • Automation
The Principal Engineer will build scalable client code, collaborate with teams, lead reviews, mentor juniors, and drive project success.
Top Skills: AngularjsChaiCSSCypressHTML5JavaScriptJestMochaReactTypescriptVue
Yesterday
Remote
Sydney, New South Wales, AUS
Senior level
Senior level
Cloud • Information Technology • Productivity • Security • Software • App development • Automation
Design and develop high-quality big data and software solutions, collaborating with teams to improve operational excellence and ensure code quality.
Top Skills: AWSDatabricksEmrFlinkJavaKotlinPythonScalaSparkStarrocks
2 Days Ago
Remote
Sydney, New South Wales, AUS
Junior
Junior
Cloud • Information Technology • Productivity • Security • Software • App development • Automation
The role involves developing and maintaining high-quality software services for Atlassian's data platform, requiring collaboration with engineers and expertise in big data technologies.
Top Skills: AWSBig DataFlaskFlinkGitJavaKotlinMicroservicesPythonRestful ApisScalaSpark

What you need to know about the Melbourne Tech Scene

Home to 650 biotech companies, 10 major research institutes and nine universities, Melbourne is among one of the top cities for biotech. In fact, some of the greatest medical advancements were conceptualized and developed here, including Symex Lab's "lab-on-a-chip" solution that monitors hormones to predict ovulation for conception, and Denteric's vaccine for periodontal gum disease. Yet, the thousands of people working in the city's healthtech sector are just getting started, to say nothing of the tech advancements across all other sectors.

Sign up now Access later

Create Free Account

Please log in or sign up to report this job.

Create Free Account