Enable job alerts via email!

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

Canonical

Muscat

On-site

USD 60,000 - 100,000

Full time

30+ days ago

Boost your interview chances

Create a job specific, tailored resume for higher success rate.

Job summary

Join a pioneering tech firm at the forefront of open source innovation! This remote position offers a unique opportunity to work on dqlite, a distributed SQLite database, and engage with cutting-edge technologies. You'll design and implement enhancements, debug issues, and participate in code reviews, all while collaborating with a talented team. Canonical fosters a culture of learning and development, providing a personal budget for your growth and annual compensation reviews. With a focus on diversity and inclusion, this is your chance to make a meaningful impact in modern computing while enjoying a supportive work environment.

Benefits

Distributed work environment
Personal learning budget of USD 2,000
Annual compensation review
Recognition rewards
Annual holiday leave
Maternity and paternity leave
Employee Assistance Programme
Opportunity to travel
Priority Pass for travel upgrades

Qualifications

  • Experience with distributed systems, preferably Raft.
  • Good C programming experience is essential.

Responsibilities

  • Design and implement features across dqlite.
  • Debug and fix issues encountered by users.

Skills

Distributed Systems
C Programming
Asynchronous Programming
Concurrency Patterns
Communication Skills

Education

Bachelor's in Computer Science
STEM Degree

Tools

dqlite
libraft
MicroK8s
LXD

Job description

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:
We consider geographical location, experience, and performance in shaping compensation worldwide. We revisit compensation annually (and more often for graduates and associates) to ensure we recognize outstanding performance. In addition to base pay, we offer a performance-driven annual bonus. We provide all team members with additional benefits, which reflect our values and ideals. We balance our programs to meet local needs and ensure fairness globally.

  • 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.
Get your free, confidential resume review.
or drag and drop a PDF, DOC, DOCX, ODT, or PAGES file up to 5MB.