Find your next role

Discover amazing opportunities across our network of companies committed to gender equality in the workplace.

CephFS Kernel Developer

IBM

IBM

Software Engineering
San Jose, CA, USA
Posted on Wednesday, August 14, 2024
Introduction
At IBM, work is more than a job – it’s a calling: To build. To design. To code. To consult. To think along with clients and sell. To make markets. To invent. To collaborate. Not just to do something better, but to attempt things you’ve never thought possible. Are you ready to lead in this new era of technology and solve some of the world’s most challenging problems? If so, lets talk.

Your Role and Responsibilities
IBM’s Ceph[1] engineering organization is looking for a senior software engineer to join the CephFS team as a kernel developer. In this role you will collaborate with our worldwide Ceph engineering team to develop and enhance CephFS[2], the file system component of the Ceph software-defined storage system, with a focus on our Linux kernel client[3]. You will design and implement new capabilities and features to enable new use cases while improving scalability, performance and efficiency. You will participate in a vibrant and active open source community[4] to deliver enterprise-quality software.

CephFS comprises a wide-ranging software suite including its Linux kernel client, a clustered userspace metadata server, and a messaging layer for storing data with Ceph’s native object store (“RADOS”), in addition to higher-level APIs for integrating with other systems (OpenStack, Kubernetes, an NFS-Ganesha gateway cluster, etc). As a member of the CephFS engineering team, you will have the opportunity to learn and work in many of these areas according to your experience and technical background.

You will work remotely with a worldwide team so communication is key. You will collaborate with others using modern open source tools including git (and GitHub), Jenkins, Redmine, and community-developed testing and validation tools.

[1]: https://ceph.io/en/news/publications/, https://www.youtube.com/c/Cephstorage
[2]https://docs.ceph.com/en/quincy/cephfs/, https://youtu.be/cNAxNSzZqzo?t=1311
[3]: https://www.youtube.com/watch?v=ecbtfgumG34&list=PLrBUGiINAakOXvawFetHtUGYi2HlK6HGE&index=1
[4]:https://github.com/ceph/ceph, https://tracker.ceph.com/projects/cephfs

Primary responsibilities
* Develop and debug the CephFS kernel client
* Test new features with Ceph’s Python-language testing infrastructure (“teuthology”)
* Occasionally, coordinate protocol changes with the Ceph Metadata Server (MDS) using C++
* Support the Ceph community through engagement on mailing lists, IRC, and other public discussions

In your role, you will work closely with the global Ceph open-source, multi-company engineering team to develop and enhance CephFS, in particular its upstream Linux kernel client. You will collaborate with other developers and users by attending online meetings, participating in email lists and online chat rooms, preparing written documentation, and giving presentations about your work. You will be expected to work proactively with other team members, the community, and the Linux upstream to develop your own knowledge, and to be ready to mentor new contributors as you develop expertise.

As a member of the team, you will contribute to the development of CephFS by designing and implementing new functionalities that enable innovative use cases. You will work principally on the upstream Linux kernel client to implement features in coordination with our existing maintainers. You may also design new distributed algorithms and implement them across the client and our C++ userspace servers (if interested and able), and will write automated test cases to demonstrate functionality and prevent regressions. You will also identify and fix bugs and propose performance enhancements.


Required Technical and Professional Expertise
* Experience in Linux kernel development, or demonstrated proficiency in C and a strong interest
* Good debugging skills. Experience with live systems (via logging and interrogation) and examining core files.
* Experience reading C++ codebases
* Basic knowledge of Python, to use and enhance testing

Preferred Technical and Professional Expertise
* Experience with data storage and/or file systems
* Experience working on distributed teams is a plus
* Past contribution to open source projects is favorable
* Knowledge of distributed systems