Elastic is on FGB’s Best Tech Companies for Women of 2021.
FGB'ers gave this company a 4.8/5 in overall job satisfaction
FGB’ers working at Elastic rated their manager’s support a 4.7/5
Craft your calendar with flexible location and schedule for many roles
Minimum of 16 weeks of parental leave
Visible diversity makes for a safe work environment for all at Elastic
#3909388
Elastic is a search company built on a free and open heritage. Anyone can use Elastic products and solutions to get started quickly and frictionlessly. Elastic offers three solutions for enterprise search, observability, and security, built on one technology stack that can be deployed anywhere. From finding documents to monitoring infrastructure to hunting for threats, Elastic makes data usable in real time and at scale. Thousands of organizations worldwide, including Cisco, eBay, Goldman Sachs, Microsoft, The Mayo Clinic, NASA, The New York Times, Wikipedia, and Verizon, use Elastic to power mission-critical systems. Founded in 2012, Elastic is a distributed company with Elasticians around the globe and is publicly traded on the NYSE under the symbol ESTC. Learn more at elastic.co.
The Observability team is in charge of developing solutions that focus on application developers and engineers that run infrastructure and services supporting these applications. Elasticsearch is an efficient datastore for logs, metrics, and application traces, supporting the three pillars of observability. With the recent acquisition of Optimyze, the developers of Prodfiler, Elastic has added support for datacenter-wide, whole-system, continuous profiling. In the Profiling team within Observability our mission is to profile all your code, everywhere, all the time. Every programming language, every containerisation solution, userland and kernel.
As a Profiling Software Engineer you will be part of a team developing innovative, high quality solutions for CPU, memory and I/O profiling, aimed at helping our customers understand the performance characteristics of their applications down to the very lines of code responsible for consuming resources of all kinds. As a team we thrive on, and encourage, deep understanding of problems and well-engineered solutions. Our work is a mix of low level systems understanding and engineering, combined with large scale data transfer, storage and analysis. On a day-to-day basis this can involve reverse engineering the internals of a programming language runtime, debugging the Linux kernel, implementing ideas from state of the art research papers, developing novel approaches to systems engineering problems, code reviews, writing design documents, participating in our engineering mailing list, debugging issues in our production infrastructure, talking to customers and more.
The team is distributed across the world, predominantly in Europe, and collaborates on a daily basis over Github, mailing lists, Zoom, and Slack.
Work on hard problems - Our long term vision is observability both at scale (entire data center) and in depth (entire operating system). This requires solving a variety of problems involving large scale data gathering/transmission/storage as well as deep understanding of operating system and programming language internals. Along the way we are continuously looking for new technologies (e.g. ebpf) to help us solve these problems.
Work on meaningful problems - Deep/wide observability is a competitive differentiator. Companies that have it can detect problems and opportunities that their competitors cannot, leading to more efficient, scalable and better performing solutions. The margin/cost-of-goods-sold for SaaS companies is largely related to their cloud costs, and improvements on this is a C-level goal for many companies.
Work with smart and curious people - Our existing team has a background in diverse areas and technologies. We hire people with a love of deep understanding and building great software.
Work in a great environment - Elastic strives to ensure employees maintain work-life balance while still being ambitious and playing to win.
The mission of this role is to expand our capabilities for in-production profiling. As it stands we support always-on CPU profiling, and we wish to expand its capabilities while also extending our features to include memory profiling, I/O profiling, and network profiling. The goal is to enable our customers to get deep insights into their entire technology stack in production environments.
The problems that we address can be broadly broken down into the following two areas. Some of our engineers work across both areas, while others are specialized into one or the other. We are open to hiring people that would like to fit into either mould.
On-host agent - We have an on-host agent that combines an eBPF component that runs inside the Linux kernel, with a userland component that is written in Go. At a high level an engineer working on the agent is concerned with extracting as much profiling information as they can from the system with the lowest performance impact possible. We pride ourselves on our agent consuming < 1% of CPU, and ensuring we stay there, while also profiling every major language, requires deep systems and programming language runtime understanding, and a dedication to well engineered solutions.
Storage backend - Our profiling solution is designed with the goal to allow users to store everything, and filter later, instead of using aggregations or other solutions for reducing data intake at the expense of accuracy or explorative use-cases. This requires us to think carefully and from first principles about both the hardware and software aspects of how we ingest, store, transform and read data. If the idea of efficiently storing and querying billions of events per day excites you, then you’ll enjoy working here!
We believe that engineers that build software should have some hand in operating it. Operating a SaaS brings engineers closer to the consequences of their engineering decisions, and this feedback is invaluable when one needs to squeeze every ounce of performance from their platform. We encourage everyone to get involved with deployments and debugging platform issues.
We also believe that engineers should be in contact with the problems their software is solving. This feedback inspires new product ideas, shows up deficiencies, and generally ensures we’re building the right things. We encourage all our engineers to both use our software and to talk to our customers, understand their use cases, and help solve their problems.
Software quality is hugely important to us. We value high performance, stability and maintainability. In practice this means everyone participates in code reviews, and we encourage engineers to dedicate time to improving and adding to our automated testing and benchmarking pipelines.
We emphasize written documents for software design, and everyone participates in both the writing and reviewing of design documents. We also have an engineering mailing list for technical discussions in which everyone is encouraged to contribute.
Deep understanding of one or more of:
Operating system internals e.g. experience with the Linux kernel, eBPF
Programming language runtime internals e.g. OpenJDK, v8, Python, .NET
Compiler technologies and SDKs, e.g. profiling guided optimisation (PGO, AutoFDO), link time optimisation (LTO), JIT compilers, clang & gcc internals
Building high performance data ingestion, storage and querying platforms
Database internals e.g. Clickhouse, Scylla, Elasticsearch
5+ years of experience in developing and shipping software
A willingness to engage in all of the important tasks that are not purely writing code e.g. design documents, code reviews, debugging, interacting with customers, operations
Ability to work independently in a globally distributed team. We are predominantly based in Europe (Central European Time), and having 2-3 hours of overlap in your workday with 9-6 CET would be ideal.
As a distributed company, diversity drives our identity. Whether you’re looking to launch a new career or grow an existing one, Elastic is the type of company where you can balance great work with great life. Your age is only a number. It doesn’t matter if you’re just out of college or your children are; we need you for what you can do.
We strive to have parity of benefits across regions and while regulations differ from place to place, we believe taking care of our people is the right thing to do.
Elastic is a free and open search company that powers enterprise search, observability, and security solutions built on one technology stack that can be deployed anywhere. From finding documents to monitoring infrastructure to hunting for threats, Elastic makes data usable in real-time and at scale. Thousands of organizations worldwide, including Barclays, Cisco, eBay, Fairfax, ING, Goldman Sachs, Microsoft, The Mayo Clinic, NASA, The New ...