C, Golang Software Engineer working on dqlite, a Raft extension for SQLite
C, Golang Software Engineer working on dqlite, a Raft extension for SQLite

C, Golang Software Engineer working on dqlite, a Raft extension for SQLite

London Full-Time 28800 - 42000 £ / year (est.) No home office possible
Go Premium
C

At a Glance

  • Tasks: Design and implement features for dqlite, a distributed SQLite database.
  • Company: Join Canonical, the creators of Ubuntu, leading the open source revolution.
  • Benefits: Enjoy remote work, a personal development budget, and annual bonuses.
  • Why this job: Make a real impact on modern tech while collaborating globally with a diverse team.
  • Qualifications: Experience in distributed systems and C programming; a degree in Computer Science or STEM is preferred.
  • Other info: This is a fully remote role available in EMEA, with opportunities for travel.

The predicted salary is between 28800 - 42000 £ 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

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

Canonical is an exceptional employer that champions a remote-first work culture, allowing you to thrive in a flexible environment while collaborating with a diverse team across the globe. With a strong focus on personal development, employees benefit from a generous learning budget and annual compensation reviews, ensuring recognition for outstanding performance. The opportunity to engage with cutting-edge technologies and participate in team sprints in exciting locations makes Canonical a truly rewarding place to advance your career.
C

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 the Raft consensus algorithm. Understanding how these technologies work will not only help you in interviews but also demonstrate your genuine interest in the role.

✨Tip Number 2

Engage with the open source community related to dqlite and similar projects. Contributing to discussions or even small code contributions can showcase your skills and commitment to potential employers.

✨Tip Number 3

Prepare to discuss your experience with distributed systems and concurrency patterns. Be ready to provide examples of past projects where you've successfully implemented these concepts.

✨Tip Number 4

Network with current or former employees of Canonical on platforms like LinkedIn. They can provide insights into the company culture and the specific expectations for the C, Golang Software Engineer role.

We think you need these skills to ace C, Golang Software Engineer working on dqlite, a Raft extension for SQLite

C Programming
Golang
Distributed Systems
Raft Protocol
Asynchronous Programming
Concurrency Patterns
Debugging Skills
Problem-Solving Skills
Code Review
Architectural Review
Communication Skills
User Support
Open Source Engagement
Microservices Architecture
Testing Methodologies

Some tips for your application 🫡

Tailor Your CV: Make sure your CV highlights your experience with distributed systems, C programming, and any relevant projects involving Raft. Use specific examples to demonstrate your skills and achievements.

Craft a Compelling Cover Letter: In your cover letter, express your enthusiasm for working on dqlite and how your background aligns with the role. Mention your understanding of asynchronous programming and concurrency patterns, as well as your ability to learn quickly.

Showcase Your Communication Skills: Since strong written and verbal communication skills are essential, ensure your application is clear and concise. Use proper grammar and structure to convey your ideas effectively.

Engage with Open Source: If you have contributed to open source projects, mention this in your application. Highlight any relevant experiences that demonstrate your engagement with the community and your ability to collaborate with others.

How to prepare for a job interview at Canonical

✨Understand dqlite and Raft

Before the interview, make sure you have a solid understanding of dqlite and the Raft consensus algorithm. Familiarise yourself with how they work together, as this will likely be a key topic during your discussion.

✨Showcase Your C and Go Skills

Prepare to discuss your experience with C and Go programming. Be ready to provide examples of projects you've worked on, particularly those involving distributed systems or asynchronous programming, as these are crucial for the role.

✨Engage with Open Source

Since Canonical values community engagement, demonstrate your involvement in open source projects. Share any contributions you've made, especially if they relate to databases or distributed systems, to show your passion and commitment.

✨Prepare for Technical Questions

Expect technical questions that assess your problem-solving skills and understanding of concurrency patterns. Practice coding challenges or system design questions that might come up, as this will help you feel more confident during the interview.

C, Golang Software Engineer working on dqlite, a Raft extension for SQLite
Canonical
Location: London
Go Premium

Land your dream job quicker with Premium

You’re marked as a top applicant with our partner companies
Individual CV and cover letter feedback including tailoring to specific job roles
Be among the first applications for new jobs with our AI application
1:1 support and career advice from our career coaches
Go Premium

Money-back if you don't land a job in 6-months

C
  • C, Golang Software Engineer working on dqlite, a Raft extension for SQLite

    London
    Full-Time
    28800 - 42000 £ / year (est.)
  • C

    Canonical

    250-500
Similar positions in other companies
UK’s top job board for Gen Z
discover-jobs-cta
Discover now
>