Ahrefs is looking for a backend developer with a deep understanding of networks, distributed systems, OS fundamentals and taste for simple and efficient architectural designs. Our system high-level logic is implemented in OCaml, while lower-level and performance critical parts are implemented in C++ and recently in Rust. We are looking to gradually switch legacy C++ components to Rust and further performance sensitive parts to be implemented in Rust too. Understanding of functional programming in general and/or experience with other FP languages (F#,Haskell,Scala,Scheme,etc) will help a lot. Knowledge of OCaml and/or C++ is a big plus.
Every day the candidate will have to deal with:
The ideal candidate is expected to:
These requirements stem naturally from our approach to development with fast feedback cycle, highly-focused personal areas of responsibility and strong tendency to vertical component splitting.
Ahrefs runs an internet-scale bot that crawls the whole Web 24/7, storing huge volumes of information to be indexed and structured in a timely fashion. Backend system is powered by a custom petabyte-scale distributed key-value storage to accommodate all that data coming in at high speed. With that data Ahrefs is building analytics services for end-users and web-scale search platform.
We are a small team and strongly believe in better technology leading to better solutions for real-world problems. We worship functional languages and static typing, extensively employ code generation and meta-programming, value code clarity and predictability, and are constantly seeking to automate repetitive tasks and eliminate boilerplate, guided by DRY and following KISS. If there is any new technology that will make our life easier - no doubt, we'll give it a try. We rely heavily on opensource code (as the only viable way to build maintainable system) and contribute back, see e.g. https://github.com/ahrefs. It goes without saying that our team is all passionate and experienced OCaml programmers, ready to lend a hand and explain that intricate ocamlbuild rule or track down a CPU bug.
Our motto is "first do it, then do it right, then do it better".
Interested? Tell us why you are the best choice for this role, your CV, desired salary and date of availability via email: firstname.lastname@example.org