At a Glance
- Tasks: Design and implement features for dqlite, a distributed SQLite database.
- Company: Canonical is a leading open source software provider, known for Ubuntu.
- Benefits: Enjoy remote work, a personal development budget, and annual bonuses.
- Why this job: Make a meaningful impact on modern computing in a fast-paced, innovative environment.
- Qualifications: Experience with distributed systems and C programming; strong communication skills required.
- Other info: Remote position available in EMEA; join a diverse, global team.
The predicted salary is between 28800 - 48000 £ per year.
Canonical is a leading provider of open source software and operating systems to the global enterprise and technology markets. Our platform, Ubuntu, is very widely used in breakthrough enterprise initiatives such as public cloud, data science, AI, engineering innovation and IoT. Our customers include the world's leading public cloud and silicon providers, and industry leaders in many sectors. The company is a pioneer of global distributed collaboration, with 1000+ colleagues in 70+ countries and very few office based roles. Teams meet two to four times yearly in person, in interesting locations around the world, to align on strategy and execution. The company is founder led, profitable and growing.
We are hiring a software developer to focus on dqlite, our distributed SQLite database which uses our own Raft library for establishing consensus and replication. Dqlite is available as a pure C library or through a Go package that we also maintain, and we intend to provide bindings for Python and other languages. You will design and implement enhancements to the libraft, dqlite and go-dqlite components which we consume in MicroK8s, LXD and other projects. Work includes development in those pieces of software as well as responding to issues and user inquiries. This is an excellent opportunity for someone who wants to have a meaningful impact on modern computing technologies. Canonical offers a fast-paced team environment and a career full of learning and development opportunities.
Location: This is a remote position available in EMEA
What you will focus on:
- Design and implement features across dqlite
- Debug and fix issues encountered by your users
- Improve Jepsen tests, traditional HA database automated testing and stress tests
- Participate in our engineering process through code and architectural review
- Engage with the open source community and commercial partners
What we are looking for in you:
- Experience with distributed systems (preferably with Raft)
- Good C programming experience
- Solid understanding of asynchronous programming and concurrency patterns a plus
- Capacity to learn quickly about new systems and techniques
- Strong written and verbal communication skills
- Bachelor's or equivalent in Computer Science, STEM or similar degree
What we offer you:
- Distributed work environment with twice-yearly team sprints in person
- Personal learning and development budget of USD 2,000 per year
- Annual compensation review
- Recognition rewards
- Annual holiday leave
- Maternity and paternity leave
- Employee Assistance Programme
- Opportunity to travel to new locations to meet colleagues
- Priority Pass, and travel upgrades for long haul company events
About Canonical: Canonical is a pioneering tech firm at the forefront of the global move to open source. As the company that publishes Ubuntu, one of the most important open source projects and the platform for AI, IoT and the cloud, we are changing the world on a daily basis. We recruit on a global basis and set a very high standard for people joining the company. We expect excellence - in order to succeed, we need to be the best at what we do. Canonical has been a remote-first company since its inception in 2004. Working here is a step into the future, and will challenge you to think differently, work smarter, learn new skills, and raise your game.
Canonical is an equal opportunity employer. We are proud to foster a workplace free from discrimination. Diversity of experience, perspectives, and background create a better work environment and better products. Whatever your identity, we will give your application fair consideration.
C, Golang Software Engineer working on dqlite, a Raft extension for SQLite employer: Canonical
Contact Detail:
Canonical Recruiting Team
StudySmarter Expert Advice 🤫
We think this is how you could land C, Golang Software Engineer working on dqlite, a Raft extension for SQLite
✨Tip Number 1
Familiarise yourself with dqlite and its architecture. Understanding how dqlite integrates with Raft and SQLite will give you a solid foundation to discuss your ideas and improvements during interviews.
✨Tip Number 2
Engage with the open source community around dqlite. Contributing to discussions or even submitting small patches can demonstrate your commitment and understanding of the project, making you a more attractive candidate.
✨Tip Number 3
Brush up on your knowledge of distributed systems, particularly Raft consensus algorithms. Being able to articulate your understanding of these concepts will set you apart from other candidates.
✨Tip Number 4
Prepare to discuss your experience with C and Go programming languages in detail. Be ready to share specific examples of projects where you've implemented asynchronous programming and concurrency patterns, as this is crucial for the role.
We think you need these skills to ace C, Golang Software Engineer working on dqlite, a Raft extension for SQLite
Some tips for your application 🫡
Tailor Your CV: Make sure your CV highlights your experience with C and Golang, as well as any work you've done with distributed systems or Raft. Use specific examples to demonstrate your skills and achievements.
Craft a Strong Cover Letter: In your cover letter, express your enthusiasm for working on dqlite and how your background aligns with Canonical's mission. Mention any relevant projects or contributions to open source that showcase your capabilities.
Showcase Communication Skills: Since strong written and verbal communication skills are essential, ensure your application is clear and concise. Avoid jargon unless necessary, and make your points easy to understand.
Highlight Problem-Solving Experience: Discuss any past experiences where you debugged issues or improved existing systems. This will demonstrate your ability to tackle challenges effectively, which is crucial for the role.
How to prepare for a job interview at Canonical
✨Showcase Your Distributed Systems Knowledge
Make sure to highlight your experience with distributed systems, especially if you have worked with Raft. Be prepared to discuss specific projects or challenges you've faced in this area, as it will demonstrate your understanding and capability.
✨Demonstrate C and Golang Proficiency
Since the role focuses on C and Golang, brush up on your coding skills in both languages. You might be asked to solve problems or write code during the interview, so practice common algorithms and data structures in these languages.
✨Prepare for Technical Questions
Expect technical questions related to asynchronous programming and concurrency patterns. Review key concepts and be ready to explain how you've applied them in past projects, as this will show your depth of knowledge.
✨Engage with Open Source Community
As Canonical values engagement with the open source community, be prepared to discuss any contributions you've made or projects you've been involved in. This shows your passion for the field and aligns with the company's ethos.